/* LexRio — Geist System
 * Ported wholesale from the canonical Vercel/Geist design language.
 * - Pure white canvas, near-black text, hairline rules, no card chrome
 * - Geist Sans + Geist Mono, OpenType "liga" globally
 * - Shadow-as-border (--ring-light) instead of CSS borders for surfaces
 * - Tokenized radii, sentence-case chips with tinted soft fills + darker text
 *
 * Original spec: /design system root → README.md, colors_and_type.css, preview/*.html
 * Disciplined target: ~v1 LexRio styles.css (~190 lines). v3 compatibility classes
 * below funnel into the same vocabulary so all screens render uniformly.
 */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600&family=Geist+Mono:wght@400;500;600&display=swap');

/* ============================================================
 * 1. TOKENS
 * ============================================================ */
:root {
  /* Surfaces — pure achromatic */
  --bg:        #FFFFFF;
  --bg-deep:   #FAFAFA;
  --surface:   #FFFFFF;
  --surface-2: #FAFAFA;
  --surface-3: #F4F4F4;
  --hover:     #FAFAFA;
  --hover-2:   #F4F4F4;
  --nav-bg:     var(--bg-deep);
  --canvas-bg:  #F5F5F5;
  --chrome-bg:  var(--nav-bg);
  --page-header-bg: var(--surface);
  --section-bg: var(--surface);
  --widget-bg:  var(--section-bg);
  --space-rhythm: 18px;
  --widget-padding-y: var(--space-rhythm);
  --widget-padding-x: var(--space-rhythm);
  --widget-padding: var(--widget-padding-y) var(--widget-padding-x);
  --widget-gap: var(--space-rhythm);
  --widget-gutter: var(--widget-gap);
  --canvas-gutter-top: var(--space-rhythm);
  --canvas-gutter-side: var(--space-rhythm);
  --claim-header-tab-gap: var(--space-rhythm);
  --claim-nav-group-gap: var(--widget-gap);
  --claim-tab-header-padding: var(--space-rhythm) var(--space-9) 0;
  --table-shell-padding-x: 0px;
  --table-row-indicator-offset-x: 12px;
  --table-row-indicator-width: 2px;
  --widget-divider: var(--rule);
  --widget-header-bg: var(--surface-2);
  --widget-shadow:
    0 0 0 0.5px rgba(0, 0, 0, 0.04),
    0 1px 2px rgba(0, 0, 0, 0.04),
    0 8px 24px rgba(0, 0, 0, 0.06);

  /* Hairline / shadow-as-border tokens */
  --rule:        #EBEBEB;
  --rule-soft:   #F0F0F0;
  --rule-firm:   #E5E5E5;
  --border:      #EBEBEB;
  --border-soft: #F0F0F0;
  --border-firm: #E5E5E5;

  /* Ink — Geist gray scale */
  --text:    #171717;   /* gray-900 */
  --text-2:  #4D4D4D;   /* gray-600 */
  --text-3:  #666666;   /* gray-500 */
  --text-4:  #737373;   /* gray-450, raised for icon/text contrast */
  --muted:        #666666;
  --muted-strong: #4D4D4D;

  /* Semantic */
  --critical:      #C0291F;  --critical-soft: #FFEAE7;  --critical-fg: #FFFFFF;
  --warn:          #8B6914;  --warn-soft:     #FEF6DD;
  --success:       #1A7D3A;  --success-soft:  #E7F8ED;
  --info:          #0068D6;  --info-soft:     #EBF5FF;

  /* Calendar taxonomy accents — restrained Geist-compatible range */
  --calendar-red:        var(--critical);
  --calendar-amber:      var(--warn);
  --calendar-blue:       var(--info);
  --calendar-purple:     #7928CA;
  --calendar-pink:       #DE1D8D;
  --calendar-green:      var(--success);
  --calendar-gray:       #525252;
  --calendar-gray-muted: #737373;

  /* Primary CTA — near-black ink, the Geist signature */
  --ink:        #171717;
  --ink-hover:  #000000;
  --ink-soft:   #FAFAFA;
  --ink-fg:     #FFFFFF;

  /* Accent — alias to ink so legacy JSX works; not a brand color */
  --accent:        #171717;
  --accent-hover:  #000000;
  --accent-fg:     #FFFFFF;
  --accent-soft:   #F4F4F4;
  --accent-bg:     #FAFAFA;
  --filter-active-bg:   #F3EBFF;
  --filter-active-bg-hover: #EEE2FF;
  --filter-active-text: #6B29C0;
  --filter-control-height: 30px;
  --filter-control-gap: 5px;
  --filter-control-padding-x: var(--space-4);
  --filter-control-radius: var(--radius-pill);
  --filter-control-font-size: 12px;
  --filter-control-font-weight: 500;
  --filter-control-active-font-weight: 600;

  /* Shape */
  --radius-square: 1px;
  --radius-xs:   2px;
  --radius-sm:   4px;
  --radius-md:   10px;
  --radius-lg:   14px;
  --radius-pill: 9999px;
  --radius: var(--radius-sm);
  --radius-xl: var(--radius-lg);
  --radius-label: var(--radius-xs);
  --radius-control: var(--radius-sm);
  --radius-widget: var(--radius-md);
  --radius-container: var(--radius-lg);
  --radius-tab-track: 8px;
  --radius-connected-control: var(--radius-control);
  --radius-connected-top: var(--radius-connected-control) var(--radius-connected-control) 0 0;
  --radius-connected-bottom: 0 0 var(--radius-connected-control) var(--radius-connected-control);
  --radius-segment-start: var(--radius-pill) 0 0 var(--radius-pill);
  --radius-segment-end: 0 var(--radius-pill) var(--radius-pill) 0;

  /* Dense product spacing */
  --space-1: 4px;
  --space-2: 6px;
  --space-3: 8px;
  --space-4: 10px;
  --space-5: 12px;
  --space-6: 14px;
  --space-7: 16px;
  --space-8: 20px;
  --space-9: 24px;
  --space-widget: var(--space-rhythm);
  --button-height: 30px;
  --button-sm-height: 26px;
  --button-padding-x: 12px;
  --button-sm-padding-x: 10px;
  --button-icon-size: var(--button-height);
  --button-icon-sm-size: var(--button-sm-height);
  --tabs-track-padding: 3px;
  --tabs-item-min-height: 28px;
  --tabs-item-padding: 5px 10px;
  --tabs-item-gap: 6px;
  --tabs-icon-only-size: var(--tabs-item-min-height);
  --tabs-item-font-size: 13px;
  --tabs-item-font-weight: 450;
  --tabs-active-font-weight: 500;
  --tabs-control-height: 36px;
  --tabs-leading-label-max-width: 116px;
  --tabs-floating-label-gap: 10px;
  --tabs-floating-label-padding: 6px 9px;
  --tabs-floating-label-pointer-size: 6px;
  --tabs-floating-label-radius: var(--radius-control);
  --tabs-floating-label-bg: var(--ink);
  --tabs-floating-label-color: var(--ink-fg);
  --tabs-floating-label-shadow: 0 8px 22px rgba(0,0,0,0.18);
  --work-widget-row-gap: var(--widget-gap);
  --work-widget-column-gap: var(--widget-gap);
  --work-widget-intro-gap: 0px;
  --headline-icon-size: 18px;

  /* Geist signature shadows */
  --ring:        rgba(0,0,0,0.08) 0px 0px 0px 1px;
  --ring-light:  rgb(235,235,235) 0px 0px 0px 1px;
  --shadow-hair: 0 0 0 1px rgba(0,0,0,0.04);
  --shadow-sm:   0 1px 2px rgba(0,0,0,0.04);
  --shadow-card: rgba(0,0,0,0.08) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 2px;
  --shadow-md:   0 1px 2px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.06);
  --shadow-pop:  0 1px 2px rgba(0,0,0,0.04), 0 12px 32px rgba(0,0,0,0.10);

  /* Focus */
  --focus: hsla(212, 100%, 48%, 1);

  /* Type families */
  --font-sans:  'Geist', ui-sans-serif, -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-serif: 'Geist', ui-sans-serif, system-ui, sans-serif; /* alias */
  --font-mono:  'Geist Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, monospace;

  /* Layout */
  --sidebar-w: 220px;
  --header-h:  48px;
  --subheader-h: 40px;
  --data-widget-scroll-h: clamp(280px, 34vh, 460px);

  /* Shared blurred-backdrop modal motion */
  --modal-motion-open-duration: 540ms;
  --modal-motion-close-duration: 300ms;
  --modal-motion-backdrop-in-duration: 180ms;
  --modal-motion-backdrop-out-duration: 220ms;
  --modal-motion-open-easing: cubic-bezier(0.72, 0, 0.18, 1);
  --modal-motion-close-easing: cubic-bezier(0.4, 0, 1, 1);
  --z-modal-backdrop: 900;
  --z-modal: 901;
}

/* ============================================================
 * 2. RESET / BASE
 * ============================================================ */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "liga";
}
button { font-family: inherit; font-size: inherit; color: inherit; cursor: pointer; border: 0; background: transparent; padding: 0; }
button:disabled { cursor: not-allowed; opacity: 0.55; }
input, textarea, select { font-family: inherit; font-size: inherit; color: inherit; }
a { color: #0072F5; text-decoration: none; }
a:hover { text-decoration: underline; }

/* Headings — Geist compression curve */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0;
  line-height: 1.25;
}

.serif { font-family: var(--font-sans); font-weight: 600; letter-spacing: -0.02em; }
.mono  { font-family: var(--font-mono); font-feature-settings: "liga","tnum"; }
.muted { color: var(--text-3); }
.small { font-size: 13px; }
.tabular { font-feature-settings: "tnum"; }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0;
  font-weight: 500;
  color: var(--text-3);
  line-height: 1;
}

/* Display ramp (mirrors design-system spec) */
.h-display { font-size: 32px; font-weight: 600; letter-spacing: -0.04em; line-height: 1.2; margin: 0; }
.h1        { font-size: 24px; font-weight: 600; letter-spacing: -0.04em; line-height: 1.25; margin: 0; }
.h2        { font-size: 18px; font-weight: 600; letter-spacing: -0.03em; margin: 0; }
.h3        { font-size: 14px; font-weight: 600; letter-spacing: -0.02em; margin: 0; }

/* Tabular numerals on data */
.cell-mono, .mono, .kbd, .chip, .tab-count, .inbox-tab-count,
.deadline-when, .deadline-when-date, .sidebar-item-count, .activity-time,
.hub-stat-value, .convert-step-num, .metric-value {
  font-variant-numeric: tabular-nums lining-nums;
}

/* Force sans + clean weight on common label/name elements so they
   never fall back to italic, serif, or different weights */
.name, .dir-row-value, .metric-label, .deadline-label,
.cell-strong, .empty-state-title, .conv-empty-title, .conv-fresh-title,
.modal-title, .source-viewer-title, .card-head-title,
.template-card > div:first-child {
  font-family: var(--font-sans);
  font-style: normal;
}

/* Focus ring */
button:focus-visible,
input:focus-visible, textarea:focus-visible, select:focus-visible,
.btn:focus-visible, .sidebar-item:focus-visible, .inbox-tab:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 1px;
}

/* ============================================================
 * 3. APP SHELL
 * ============================================================ */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  height: 100vh;
  min-height: 0;
  overflow: hidden;
  background: var(--canvas-bg);
}

.sidebar {
  background: var(--nav-bg);
  box-shadow: inset -1px 0 0 var(--rule);
  display: flex;
  flex-direction: column;
  padding: 16px 12px;
  gap: 12px;
  overflow: hidden;
}
.sidebar-brand { display: flex; align-items: center; gap: 10px; padding: 0 6px 4px; }
.sidebar-brand-logo {
  width: 26px; height: 26px;
  background: var(--ink);
  border-radius: var(--radius-label);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-fg);
  font-weight: 600; font-size: 13px; letter-spacing: -0.04em;
}
.sidebar-brand-name { font-family: var(--font-sans); font-weight: 600; font-size: 15px; letter-spacing: -0.03em; color: var(--text); }
.sidebar-brand-firm {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px; text-transform: uppercase;
  color: var(--text-3); font-weight: 500; line-height: 1;
}

.sidebar-nav { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 16px; }
.sidebar-section { display: flex; flex-direction: column; gap: 1px; }
.sidebar-section-label {
  font-family: var(--font-sans);
  font-size: 11px; text-transform: none; letter-spacing: 0;
  font-weight: 500; color: var(--text-4);
  padding: 8px 8px 4px; line-height: 1;
}
.sidebar-item {
  display: flex; align-items: center; gap: 9px;
  padding: 6px 10px;
  border-radius: var(--radius-control);
  color: var(--text-2);
  text-align: left;
  text-decoration: none;
  font-size: 13px; font-weight: 500;
  width: 100%; height: 30px;
  position: relative;
}
.sidebar-item > span:not(.sidebar-item-count):not(.dot) {
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sidebar-item:hover { background: var(--hover-2); color: var(--text); }
.sidebar-item.active { background: var(--surface); color: var(--text); box-shadow: var(--ring-light); font-weight: 500; }
.sidebar-icon { width: 14px; height: 14px; flex-shrink: 0; opacity: 0.7; }
.sidebar-item-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px; color: var(--text-3); font-weight: 400;
  flex-shrink: 0;
}

.sidebar-user {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 8px;
  border-top: 1px solid var(--rule);
  margin-top: 4px;
}

/* Main pane */
.main { display: flex; flex-direction: column; overflow: hidden; min-width: 0; min-height: 0; }
.header {
  height: var(--header-h);
  box-shadow: inset 0 -1px 0 var(--rule);
  display: flex; align-items: center;
  padding: 0 20px; gap: 16px;
  background: var(--chrome-bg);
  flex-shrink: 0;
}
.header-title { display: flex; align-items: center; min-width: 0; overflow: hidden; }
.crumb { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; font-size: 13px; color: var(--text-3); font-weight: 500; }
.crumb-sep  { color: var(--text-4); display: inline-flex; align-items: center; }
.crumb-item { color: var(--text-2); cursor: pointer; }
.crumb-item:hover { color: var(--text); }
.crumb-item.current,
.crumb strong { color: var(--text); font-weight: 500; }

.header-actions { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.command-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: 30px;
  padding: 0 9px 0 10px;
  border-radius: var(--radius-pill);
  background: var(--bg-deep);
  box-shadow: var(--ring-light);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
}
.command-trigger:hover {
  background: var(--hover);
  color: var(--text);
}
.command-trigger:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 2px var(--focus);
}
.command-trigger-label {
  line-height: 1;
}
.search-bar {
  flex: 1; max-width: 380px;
  display: flex; align-items: center; gap: 7px;
  height: 30px; padding: 0 10px;
  background: var(--bg-deep);
  box-shadow: var(--ring-light);
  border-radius: var(--radius-pill);
  color: var(--text-3);
}
.search-bar input { flex: 1; border: 0; outline: 0; background: transparent; font-size: 13px; color: var(--text); }
.kbd {
  font-family: var(--font-mono);
  font-size: 11px; color: var(--text-3);
  box-shadow: var(--ring-light);
  border-radius: var(--radius-control);
  padding: 1px 5px;
  background: var(--surface);
  font-weight: 500;
}

.content {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  background: var(--canvas-bg);
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}
.content:focus { outline: none; }
.content:has(> .claim-identity-header) {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.content > .claim-identity-header {
  flex: 0 0 auto;
}
.content > .lx-1youv2o {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.app-page-scaffold {
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  background: var(--canvas-bg);
  overflow: hidden;
}
.page-header-surface {
  background: var(--page-header-bg);
}

.app-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 24px 16px;
  box-shadow: inset 0 -1px 0 var(--rule);
  background: var(--page-header-bg);
}
.app-page-heading {
  flex: 1;
  min-width: 0;
}
.app-page-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.app-page-title {
  margin: 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: 0;
}
.app-page-meta {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
}
.app-page-subtitle {
  margin-top: 5px;
  color: var(--text-3);
  font-size: 13px;
  line-height: 1.4;
}
.app-page-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: min(360px, 42%);
}
.app-page-actions .header-actions {
  width: 100%;
  justify-content: flex-end;
}
.app-page-body {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.app-page-body:has(> .reference-ui) {
  display: block;
  overflow: auto;
  scrollbar-gutter: stable;
}
.app-page-body > .lx-28v4rf,
.app-page-body > .lx-51qana,
.app-page-body > .lx-yn6tld {
  padding: var(--space-widget);
  flex: 1;
  min-height: 0;
  overflow: auto;
}
.app-page-body > .lx-28v4rf:has(.table-shell-with-rail),
.app-page-body > .lx-28v4rf:has(.data-list-card),
.app-page-body > .lx-51qana:has(.table-shell-with-rail),
.app-page-body > .lx-yn6tld:has(.table-shell-with-rail) {
  overflow: hidden;
}
.app-page-body > .lx-yn6tld {
  align-content: start;
  align-items: start;
}
.app-page-body > .my-work-root {
  padding-top: var(--space-widget);
}
.app-page-body > .lx-1qcw925,
.app-page-body > .my-work-root {
  flex: 1;
  min-height: 0;
  overflow: auto;
}
.app-page-body > .my-work-root {
  display: flex;
  flex-direction: column;
  gap: var(--widget-gap);
  overflow: auto;
}
.app-page-body > .lx-28v4rf.my-work-root {
  overflow: auto;
}
.my-work-root .work-widget-grid {
  display: grid;
  flex: 0 0 auto;
  grid-auto-rows: minmax(220px, auto);
  min-height: max-content;
  align-items: stretch;
}
@media (min-width: 1920px) {
  .my-work-root .work-widget-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 1351px) {
  .my-work-root .work-widget-grid {
    grid-template-columns: 1fr;
  }
}
.my-work-root > .lx-15kjdyn {
  flex: 0 0 auto;
  margin-bottom: 0;
}
.my-work-root .work-widget-grid > .data-list-card {
  flex: 0 1 auto;
  min-height: 220px;
  height: 100%;
}
.my-work-root .work-widget-grid > .data-list-card > .card-body.tight {
  flex: 1 1 auto;
  min-height: 0;
}
.my-work-root .widget-scroll-region {
  flex: 1 1 auto;
  min-height: 132px;
  max-height: var(--data-widget-scroll-h);
}
.my-work-enter-list .work-row {
  animation: my-work-row-drop-in 460ms cubic-bezier(0.18, 0.9, 0.2, 1) both;
  transform-origin: top center;
  will-change: transform, opacity;
}
.my-week-grid {
  overflow: hidden;
}
.my-week-day {
  animation: my-week-day-drop-in 500ms cubic-bezier(0.18, 0.9, 0.2, 1) both;
  transform-origin: top center;
  will-change: transform, opacity;
}
.my-week-event {
  animation: my-week-event-settle-in 360ms cubic-bezier(0.18, 0.9, 0.2, 1) both;
  will-change: transform, opacity;
}
.my-week-day:nth-child(1) { animation-delay: 0ms; }
.my-week-day:nth-child(2) { animation-delay: 48ms; }
.my-week-day:nth-child(3) { animation-delay: 96ms; }
.my-week-day:nth-child(4) { animation-delay: 144ms; }
.my-week-day:nth-child(5) { animation-delay: 192ms; }
.my-week-day:nth-child(6) { animation-delay: 240ms; }
.my-week-day:nth-child(7) { animation-delay: 288ms; }
.my-week-day:nth-child(1) .my-week-event { animation-delay: 120ms; }
.my-week-day:nth-child(2) .my-week-event { animation-delay: 168ms; }
.my-week-day:nth-child(3) .my-week-event { animation-delay: 216ms; }
.my-week-day:nth-child(4) .my-week-event { animation-delay: 264ms; }
.my-week-day:nth-child(5) .my-week-event { animation-delay: 312ms; }
.my-week-day:nth-child(6) .my-week-event { animation-delay: 360ms; }
.my-week-day:nth-child(7) .my-week-event { animation-delay: 408ms; }
@keyframes my-work-row-drop-in {
  0% {
    opacity: 0;
    transform: translateY(-18px) scale(0.985);
  }
  58% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes my-week-day-drop-in {
  0% {
    opacity: 0;
    transform: translateY(-16px) scale(0.988);
  }
  64% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes my-week-event-settle-in {
  0% {
    opacity: 0;
    transform: translateY(-7px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .my-work-enter-list .work-row,
  .my-week-day,
  .my-week-event,
  .overview-work-grid .overview-row-section .card-body.tight > .work-row,
  .overview-work-grid .overview-row-section .card-body.tight > .list-row,
  .overview-work-grid .overview-row-section .card-body.tight > .overview-activity-compact-row,
  .overview-stickies .claim-sticky-note {
    animation: none;
  }
}
.my-work-perspective-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  flex: 0 0 auto;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}
.my-work-perspective-main {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.my-work-perspective-avatar {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  background: var(--accent-bg);
  color: var(--accent);
  font-size: 12px;
  font-weight: 750;
  flex: 0 0 auto;
}
.my-work-perspective-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.my-work-perspective-control {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 600;
}
.my-work-perspective-control > span {
  flex: 0 0 auto;
  white-space: nowrap;
}
.my-work-perspective-control select {
  height: 32px;
  min-width: 220px;
  padding: 0 30px 0 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}
.awaiting-review-card {
  flex: 0 0 auto;
  min-height: 0;
}
.awaiting-review-card .card-body.tight {
  flex: 0 0 auto;
  min-height: auto;
}
.awaiting-review-card .card-head {
  gap: 12px;
}
.awaiting-review-title-link {
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
}
.awaiting-review-title-link:hover,
.awaiting-review-title-link:focus-visible {
  color: var(--accent);
  outline: none;
}
.awaiting-review-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
  color: var(--text-3);
  font-size: 12px;
}
.awaiting-review-list {
  flex: 0 0 auto;
  height: clamp(260px, 38vh, 360px);
  max-height: 360px;
}
.awaiting-review-table {
  min-width: 900px;
}
.awaiting-review-table tbody tr.critical,
.awaiting-review-table tbody tr.warn {
  box-shadow: inset 2px 0 0 var(--warn);
}
.awaiting-review-table tbody tr.critical {
  box-shadow: inset 2px 0 0 var(--critical);
}
.awaiting-review-col-urgency { width: 76px; }
.awaiting-review-col-route { width: 122px; }
.awaiting-review-col-received { width: 108px; }
.awaiting-review-col-source { width: 30px; }
.awaiting-review-col-from { width: 142px; }
.awaiting-review-col-subject { width: 27%; }
.awaiting-review-col-claim { width: 23%; }
.awaiting-review-col-status { width: 118px; }
.awaiting-review-table th:nth-child(4),
.awaiting-review-table td:nth-child(4) {
  padding-left: 4px;
  padding-right: 2px;
}
.awaiting-review-table th:nth-child(5),
.awaiting-review-table td:nth-child(5) {
  padding-left: 2px;
}
.awaiting-review-source-cell .source-chip {
  justify-content: center;
  width: 18px;
}
.awaiting-review-date-cell {
  white-space: nowrap;
}
.awaiting-review-subject-cell {
  font-weight: 500;
  max-width: 32ch;
}
.awaiting-review-claim-cell {
  max-width: 34ch;
  min-width: 0;
}
.awaiting-review-claim-match {
  margin-right: 4px;
}
.awaiting-review-table .chip {
  font-size: 12px;
}
.awaiting-review-table td.muted,
.awaiting-review-claim-match,
.awaiting-review-claim-cell .muted {
  font-size: 12px;
}
.awaiting-review-claim-separator {
  margin: 0 3px;
}
.awaiting-review-row {
  display: grid;
  grid-template-columns: minmax(62px, .48fr) minmax(104px, .78fr) minmax(74px, .52fr) minmax(92px, .68fr) minmax(128px, .95fr) minmax(230px, 1.85fr) minmax(170px, 1.15fr) minmax(92px, .68fr);
  align-items: center;
  width: 100%;
  column-gap: 10px;
  min-height: 42px;
  padding-top: 5px;
  padding-bottom: 5px;
  color: inherit;
  font-size: 13px;
  line-height: 1.2;
  text-align: left;
}
.awaiting-review-row:hover,
.awaiting-review-row:focus-visible {
  outline: none;
}
.awaiting-review-main,
.awaiting-review-urgency,
.awaiting-review-role,
.awaiting-review-received-cell,
.awaiting-review-source,
.awaiting-review-from,
.awaiting-review-meta,
.awaiting-review-action {
  min-width: 0;
}
.awaiting-review-urgency,
.awaiting-review-role,
.awaiting-review-received-cell,
.awaiting-review-source,
.awaiting-review-from,
.awaiting-review-main,
.awaiting-review-meta,
.awaiting-review-action {
  display: flex;
  align-items: center;
}
.awaiting-review-source {
  gap: 5px;
  color: var(--text-2);
}
.awaiting-review-received {
  color: var(--text-3);
  font-size: 13px;
  font-weight: 400;
  white-space: nowrap;
}
.awaiting-review-from {
  color: var(--text);
  font-size: 13px;
  font-weight: 400;
}
.awaiting-review-title-line {
  min-width: 0;
  flex-wrap: nowrap;
  align-items: center;
}
.awaiting-review-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.awaiting-review-meta {
  flex-wrap: nowrap;
  gap: 6px;
  margin-top: 0;
  justify-content: flex-start;
  color: var(--text-3);
  font-size: 13px;
}
.awaiting-review-meta > span {
  min-width: 0;
}
.awaiting-review-action {
  gap: 8px;
  color: var(--text-2);
  justify-content: flex-start;
}
@media (max-width: 920px) {
  .my-work-perspective-card {
    align-items: stretch;
    flex-direction: column;
  }
  .my-work-perspective-control {
    align-items: stretch;
    flex-direction: column;
  }
  .my-work-perspective-control select {
    min-width: 0;
    width: 100%;
  }
  .awaiting-review-row {
    grid-template-columns: minmax(62px, .5fr) minmax(104px, .9fr) minmax(74px, .6fr) minmax(92px, .75fr) minmax(128px, 1fr) minmax(210px, 1.6fr);
    align-items: center;
  }
  .awaiting-review-meta,
  .awaiting-review-action {
    grid-column: 5 / -1;
  }
  .widget-header-actions.header-checkbox-actions {
    width: 100%;
    justify-content: flex-start;
  }
  .awaiting-review-action {
    justify-content: flex-start;
  }
}
.app-page-body > .canvas-table-page,
.app-page-body > .lx-tthces {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-rhythm);
  overflow: hidden;
}
.app-page-body > .lx-1youv2o {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.app-page-body > .filter-bar,
.app-page-body .filter-bar {
  background: var(--canvas-bg);
}
.app-page-body > .inbox-toolbar,
.app-page-body .inbox-toolbar {
  background: var(--chrome-bg);
}
.app-page-body .table-wrap {
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}
.app-page-body > .tabs {
  align-self: flex-start;
  max-width: calc(100% - (var(--space-widget) * 2));
  margin: var(--space-widget) var(--space-widget) 0;
}
.app-page-body .card {
  border-radius: 0;
}
.content:has(.knowledge-page-root) {
  overflow: hidden;
}
.app-page-scaffold:has(.knowledge-page-root) {
  height: 100%;
  min-height: 0;
}
.app-page-body:has(> .knowledge-page-root) {
  display: flex;
  min-height: 0;
  overflow: hidden;
}
.app-page-body:has(> .knowledge-page-root) > .knowledge-page-root {
  flex: 1;
}
.app-page-body > .lx-yn6tld .table-wrap {
  border: 0;
  border-radius: 0;
}

/* ============================================================
 * 4. BUTTONS
 * ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  box-sizing: border-box;
  padding: 0 var(--button-padding-x);
  font-size: 13px; font-weight: 500;
  border-radius: var(--radius-control);
  background: var(--surface);
  color: var(--text);
  height: var(--button-height);
  min-height: var(--button-height);
  white-space: nowrap;
  box-shadow: var(--ring-light);
  font-family: inherit;
  line-height: 1;
  border: 0;
}
.btn:hover { background: var(--hover); }
.btn:active { transform: translateY(0.5px); }
.btn-sm { height: var(--button-sm-height); min-height: var(--button-sm-height); padding: 0 var(--button-sm-padding-x); font-size: 12px; }
.btn-icon { padding: 0; width: var(--button-icon-size); justify-content: center; }
.btn-icon.btn-sm { width: var(--button-icon-sm-size); }
.btn-primary, .btn-accent { background: var(--ink); color: var(--ink-fg); box-shadow: none; }
.btn-primary:hover, .btn-accent:hover { background: var(--ink-hover); }
.btn-ghost { background: transparent; box-shadow: none; }
.btn-ghost:hover { background: var(--hover-2); }
.btn-ghost.active { background: var(--surface); color: var(--text); box-shadow: var(--ring-light); }
.btn .spinner {
  width: 12px;
  height: 12px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: var(--radius-pill);
  animation: spin 0.75s linear infinite;
}
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: var(--radius-control);
  color: var(--text-3);
  background: transparent;
}
.icon-btn:hover { background: var(--hover-2); color: var(--text); }
.btn[aria-expanded="true"],
.icon-btn[aria-expanded="true"] { background: var(--surface-3); color: var(--text); }

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ============================================================
 * 5. CHIPS — canonical Geist pill
 * Soft tinted bg + darker text, no border, sentence-case
 * ============================================================ */
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12px; font-weight: 500;
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  background: var(--surface-3);
  color: var(--text-2);
  white-space: nowrap;
  text-transform: none;
  letter-spacing: 0;
  line-height: 1.5;
  font-family: inherit;
  border: 0;
}
.chip.outline   { background: var(--surface); color: var(--text); box-shadow: var(--ring-light); }
.chip-dot       { width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex-shrink: 0; opacity: 0.85; }
.chip-critical  { background: var(--critical-soft); color: var(--critical); }
.chip-warn      { background: var(--warn-soft); color: var(--warn); }
.chip-success   { background: var(--success-soft); color: var(--success); }
.chip-info      { background: var(--info-soft); color: var(--info); }
.chip-accent    { background: var(--filter-active-bg); color: var(--filter-active-text); }
.chip-pink      { background: #FCE8F4; color: #B1227A; }
.chip-neutral   { background: var(--surface-3); color: var(--text-2); }
.chip-active    { background: var(--surface); color: var(--text); box-shadow: 0 0 0 1px var(--text); font-weight: 600; }
.chip svg       { flex-shrink: 0; }
.chip-compact-wrap {
  align-items: center;
  max-width: 100%;
  min-height: 22px;
  height: auto;
  padding: 3px 7px;
  border-radius: 6px;
  line-height: 1.18;
  white-space: normal;
  vertical-align: middle;
}
.claim-header-id-box {
  position: relative;
  width: fit-content;
  max-width: min(360px, 100%);
  min-width: 0;
  flex: 0 0 auto;
}
.claim-header-id-box:has(.claim-facts-trigger.active) {
  z-index: 320;
}
.claim-header-id-box .claim-facts-trigger {
  appearance: none;
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-2);
  align-items: center;
  min-width: 142px;
  max-width: min(360px, 100%);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--rule);
  border-radius: var(--radius-tab-track);
  color: inherit;
  background: linear-gradient(180deg, var(--surface-2) 0%, var(--surface-3) 100%);
  cursor: pointer;
  font: inherit;
  text-align: left;
  transition:
    background 250ms ease,
    border-color 250ms ease,
    box-shadow 250ms ease;
}
.claim-header-id-box .claim-facts-trigger:hover,
.claim-header-id-box .claim-facts-trigger:focus-visible,
.claim-header-id-box .claim-facts-trigger.active {
  border-color: var(--text-2);
  background: var(--surface-2);
}
.claim-header-id-box .claim-facts-trigger:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--text-2) 12%, transparent);
}
.claim-header-id-box .claim-facts-trigger:active {
  transform: translateY(0.5px);
}
.claim-header-id-box .claim-facts-popover {
  top: calc(100% + 8px);
  right: auto;
  left: 0;
  animation-name: claim-facts-panel-unfurl;
}
.claim-header-id-row {
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  gap: var(--space-2);
  min-width: 0;
  font-size: 11px;
}
.claim-facts-icon {
  display: inline-grid;
  width: 24px;
  height: 28px;
  place-items: center;
  color: var(--text-2);
}
.claim-facts-label-stack {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.claim-header-id-label {
  min-width: 0;
  overflow: hidden;
  color: var(--text-4);
  font-size: 11px;
  font-weight: 400;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.claim-header-id-value {
  display: block;
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.claim-facts-info-indicator {
  position: absolute;
  top: 50%;
  right: var(--space-3);
  display: grid;
  width: 18px;
  height: 18px;
  place-items: center;
  color: var(--text-2);
  transform: translateY(-50%);
}
.claim-header-claim-number {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  border-radius: var(--radius-pill);
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.4;
  white-space: nowrap;
}
.claim-header-claim-number strong {
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
}
.claim-header-cac {
  font-weight: 500;
}
.claim-header-cac svg {
  flex-shrink: 0;
}
.claim-header-status {
  font-weight: 500;
}
.claim-header-title-stack {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.claim-header-main-row {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}
.claim-header-status-stack {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.claim-header-tags-row {
  display: flex;
  min-width: 0;
}
.claim-header-meta-item {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}
.claim-header-doi.is-missing strong {
  color: var(--text-3);
  font-weight: 500;
}
.claim-header-meta-item + .claim-header-meta-item::before {
  content: "";
  flex: 0 0 3px;
  width: 3px;
  height: 3px;
  align-self: center;
  margin: 0 12px;
  border-radius: var(--radius-pill);
  background: var(--text-4);
}
.claim-header-main-row .claim-tags-wrap {
  flex-shrink: 0;
}
.claim-header-main-row .claim-tag-row,
.claim-header-tags-row .claim-tag-row {
  margin-top: 0;
}
.claim-facts-anchor {
  position: relative;
  perspective: 720px;
}
.claim-facts-trigger {
  color: var(--text-2);
}
.claim-facts-trigger.active,
.claim-facts-trigger:hover,
.claim-facts-trigger:focus-visible {
  color: var(--text);
}
.claim-facts-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 260;
  display: flex;
  flex-direction: column;
  width: min(420px, calc(100vw - 32px));
  max-height: min(72vh, 720px);
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 0;
  background: var(--bg);
  box-shadow: var(--shadow-pop);
  transform-origin: top left;
  backface-visibility: hidden;
  will-change: transform, opacity;
  animation: claim-facts-panel-unfurl 210ms cubic-bezier(0.32, 0, 0.15, 1);
}
.claim-facts-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 38px;
  padding: 8px 10px 7px 12px;
  border-bottom: 1px solid var(--border);
}
.claim-facts-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.25;
}
.claim-facts-title-link {
  text-decoration: none;
}
.claim-facts-title-link:hover,
.claim-facts-title-link:focus-visible {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.claim-facts-subtitle {
  max-width: 320px;
  overflow: hidden;
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.claim-fact-list {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: auto;
  overscroll-behavior: contain;
  padding: 6px;
}
.claim-header-id-box .claim-fact-list,
.claim-fact-list {
  border-radius: 0;
}
.claim-fact-row {
  display: grid;
  grid-template-columns: minmax(118px, 0.74fr) minmax(0, 1fr) 28px;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 5px 6px;
  border-radius: var(--radius);
}
.claim-fact-row:hover {
  background: var(--surface);
}
@media (prefers-reduced-motion: reduce) {
  .claim-facts-popover {
    animation: none;
  }
}
.claim-fact-label-group {
  display: flex;
  flex-direction: column;
  min-width: 0;
  gap: 2px;
}
.claim-fact-label {
  overflow: hidden;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.claim-fact-source {
  width: max-content;
  max-width: 100%;
  overflow: hidden;
  color: var(--text-4);
  font-size: 10px;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.claim-fact-value {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.3;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.claim-fact-value.is-missing {
  color: var(--text-4);
  font-weight: 500;
}
.claim-fact-copy,
.claim-fact-copy-spacer {
  width: 26px;
  height: 26px;
}
.claim-fact-copy {
  color: var(--text-3);
}
.claim-fact-copy.copied {
  color: var(--success);
}
@media (max-width: 760px) {
  .claim-facts-anchor {
    align-items: flex-end;
  }
  .claim-facts-popover {
    position: fixed;
    top: auto;
    right: 12px;
    bottom: 12px;
    left: 12px;
    width: auto;
    max-height: min(78vh, 680px);
  }
  .claim-header-id-box .claim-facts-popover {
    top: auto;
    right: 12px;
    left: 12px;
  }
  .claim-fact-row {
    grid-template-columns: minmax(96px, 0.66fr) minmax(0, 1fr) 28px;
  }
}
@media (min-width: 1450px) {
  .claim-header-title-stack {
    flex-direction: row;
    align-items: center;
    gap: 18px;
  }
  .claim-header-main-row {
    flex: 0 0 auto;
  }
  .claim-header-tags-row {
    flex: 1 1 auto;
    justify-content: center;
    overflow: hidden;
  }
  .claim-header-tags-row .claim-tags-wrap {
    max-width: 100%;
  }
}
.chip-select {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--filter-control-gap);
  height: var(--filter-control-height);
  max-width: 100%;
  padding: 0;
  border: 1px solid transparent;
  border-radius: var(--filter-control-radius);
  background: var(--surface-3);
  box-shadow: none;
  color: var(--text-2);
  font-size: var(--filter-control-font-size);
  font-weight: var(--filter-control-font-weight);
  line-height: 1.5;
  white-space: nowrap;
  overflow: visible;
}
.chip-select:hover {
  background: var(--hover);
}
.chip-select:focus-within {
  border-color: var(--focus);
  box-shadow: 0 0 0 1px var(--focus);
}
.chip-select.is-active {
  border-color: transparent;
  box-shadow: none;
  font-weight: var(--filter-control-active-font-weight);
}
.chip-select-tone-success { background: var(--success-soft); color: var(--success); }
.chip-select-tone-info { background: var(--info-soft); color: var(--info); }
.chip-select-tone-warn { background: var(--warn-soft); color: var(--warn); }
.chip-select-tone-accent { background: var(--filter-active-bg); color: var(--filter-active-text); }
.chip-select-tone-critical { background: var(--critical-soft); color: var(--critical); }
.chip-select-tone-neutral,
.chip-select-tone-muted { background: var(--surface-3); color: var(--text-2); }
.chip-select-label {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 100%;
  height: 100%;
  overflow: hidden;
  line-height: 1;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.chip-select-trigger {
  all: unset;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 calc(var(--filter-control-padding-x) + 16px) 0 var(--filter-control-padding-x);
  border: 0 !important;
  border-radius: var(--filter-control-radius);
  background: transparent !important;
  box-shadow: none !important;
  color: inherit;
  font: inherit;
  line-height: inherit;
  outline: 0 !important;
  cursor: pointer;
}
.chip-select-trigger:focus,
.chip-select-trigger:focus-visible {
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
}
.chip-select-chevron {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: currentColor;
  opacity: 0.65;
}
.chip-select-popover {
  position: absolute;
  z-index: 90;
  top: calc(100% + 6px);
  left: 0;
  min-width: max(100%, 188px);
  max-width: min(320px, calc(100vw - 32px));
  padding: 5px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-container);
  background: var(--surface);
  box-shadow: var(--shadow-pop);
}
.chip-select-option {
  all: unset;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  min-height: 30px;
  padding: 6px 8px;
  border-radius: var(--radius-control);
  color: var(--text);
  cursor: pointer;
  font-size: 12px;
  font-weight: 500;
  line-height: 16px;
}
.chip-select-menu-heading {
  margin: 0 -5px 4px;
  padding: 6px 13px 9px;
  box-shadow: inset 0 -1px 0 var(--rule);
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
  line-height: 16px;
}
.chip-select-option.is-active,
.chip-select-option:hover {
  background: var(--surface-2);
}
.chip-select-option.is-list-heading {
  margin: 0 -5px 4px;
  width: calc(100% + 10px);
  padding: 6px 13px 9px;
  border-radius: 0;
  box-shadow: inset 0 -1px 0 var(--rule);
  color: var(--text-3);
  font-weight: 650;
}
.chip-select-option.is-list-heading.is-active,
.chip-select-option.is-list-heading:hover {
  background: transparent;
  color: var(--text-2);
}
.chip-select-option.is-selected {
  color: currentColor;
  font-weight: 600;
}
.chip-select-option.is-list-heading.is-selected {
  font-weight: 650;
}
.chip-select-option-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.chip-select-option-check {
  flex: 0 0 auto;
  opacity: 0.75;
}
.filter-chip-select {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 260px;
}
.source-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  white-space: nowrap;
  font-family: inherit;
  letter-spacing: 0;
}
.source-chip svg {
  flex-shrink: 0;
}
.source-chip-compact {
  font-size: 12px;
}
.source-label {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 500;
}
.source-chip-critical { color: var(--critical); }
.source-chip-warn     { color: var(--warn); }
.source-chip-success  { color: var(--success); }
.source-chip-info     { color: var(--info); }
.source-chip-accent   { color: var(--calendar-purple); }
.source-chip-pink     { color: var(--calendar-pink); }
.source-chip-neutral  { color: var(--text-2); }
.source-label-critical { color: var(--critical); }
.source-label-warn     { color: var(--warn); }
.source-label-success  { color: var(--success); }
.source-label-info     { color: var(--info); }
.source-label-accent   { color: var(--calendar-purple); }
.source-label-pink     { color: var(--calendar-pink); }
.source-label-neutral  { color: var(--text-2); }

/* Source citation pill used by the assistant composer. App state labels use .chip. */
.src, .src-chip {
  border: 0;
  height: 20px; padding: 0 10px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0;
  border-radius: var(--radius-pill);
  flex-shrink: 0; line-height: 1; width: auto;
  background: var(--surface-3); color: var(--text-2);
  cursor: pointer;
  vertical-align: baseline;
}
.src-fax    { background: var(--critical-soft); color: var(--critical); }
.src-email  { background: var(--info-soft); color: var(--info); }
.src-scan   { background: var(--warn-soft); color: var(--warn); }
.src-cac    { background: var(--filter-active-bg); color: var(--filter-active-text); }
.src-efile  { background: #FCE8F4; color: #B1227A; }
.src-upload { background: var(--surface-3); color: var(--text-2); }


.comms-new-message-wrap {
  position: relative;
}

.comms-new-message-menu {
  right: 0;
  top: calc(100% + 4px);
  z-index: 12;
}

/* ============================================================
 * 6. TABLES — flat, hairline rules, no wrapper chrome
 * ============================================================ */
.table-wrap { background: transparent; border: 0; border-radius: 0; overflow: visible; }

.table-shell {
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.table-shell-with-rail {
  flex: 1;
}
.table-shell-with-rail > .table-wrap {
  flex: 1;
  min-height: 0;
  overflow: auto;
  scrollbar-gutter: stable;
}
.table-shell-with-rail .table thead th,
.table-shell-with-rail .tbl thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}
.table-scroll-region {
  flex: 1;
  min-height: 0;
  overflow: auto;
  scrollbar-gutter: stable;
}
.widget-table {
  table-layout: auto;
}
.widget-table-headless thead {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
}
.widget-table-compact th,
.widget-table-compact td {
  height: 40px;
  padding: 6px 8px;
  font-size: 13px;
  line-height: 1.2;
  text-align: left;
  vertical-align: middle;
}
.widget-table-compact th {
  height: 30px;
  background: var(--bg);
  color: var(--text-3);
  font-size: 12px;
  font-weight: 600;
}
.widget-table-compact tbody tr.is-clickable {
  cursor: pointer;
}
.widget-table-compact tbody tr.is-clickable:hover,
.widget-table-compact tbody tr.is-clickable:focus-visible {
  background: var(--hover);
  outline: none;
}
@media (max-width: 1550px) {
  .awaiting-review-col-from {
    width: 92px;
  }
  .awaiting-review-col-subject {
    width: 31%;
  }
  .awaiting-review-col-claim {
    width: 26%;
  }
  .awaiting-review-table th.widget-table-optional-wide,
  .awaiting-review-table td.widget-table-optional-wide {
    max-width: 92px;
  }
}
.widget-scroll-region {
  max-height: var(--data-widget-scroll-h);
}
.data-list-card {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.data-list-card > .card-body,
.data-list-card .card-body.tight {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
.data-list-card.awaiting-review-card {
  flex: 0 0 auto;
}
.data-list-card.awaiting-review-card > .card-body.tight {
  flex: 0 0 auto;
  min-height: auto;
}
.awaiting-review-card .awaiting-review-list {
  flex: 0 0 auto;
  height: clamp(240px, 36vh, 320px);
  max-height: 320px;
}
.data-view-rail {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 44px;
  padding: 10px 0;
  border-top: 1px solid var(--widget-divider);
  color: var(--text-3);
  font-size: 12.5px;
  background: var(--chrome-bg);
}
.data-view-rail-compact {
  min-height: 36px;
  padding: 8px 0 0;
}
.data-view-rail-copy,
.data-view-rail-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  flex-wrap: wrap;
}
.data-view-rail-copy span + span::before {
  content: "•";
  margin-right: 10px;
  color: var(--text-4);
}
.data-view-rail-actions {
  justify-content: flex-end;
  flex-shrink: 0;
}

.tbl, .table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.tbl th, .table th {
  text-align: left;
  padding: 12px 16px;
  font-family: var(--font-sans);
  font-size: 13px;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-3);
  font-weight: 500;
  box-shadow: inset 0 -1px 0 var(--rule);
  background: var(--bg);
  white-space: nowrap;
}
.tbl td, .table td {
  padding: 14px 16px;
  box-shadow: inset 0 -1px 0 var(--rule);
  vertical-align: middle;
  border: 0;
  font-size: 14px;
}
.tbl tr, .table tr { cursor: default; }
.tbl tr.is-clickable,
.table tr.is-clickable,
.tbl tr[tabindex],
.table tr[tabindex],
.tbl tr[role="button"],
.table tr[role="button"] { cursor: pointer; }
.table-text-button {
  display: inline-flex;
  align-items: baseline;
  height: auto;
  padding: 0;
  border: 0;
  border-radius: var(--radius-label);
  background: transparent;
  box-shadow: none;
  color: var(--text);
  font: inherit;
  line-height: 1.3;
}
.table-text-button:not(:disabled):hover {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.table-text-button:disabled {
  color: var(--text-3);
  cursor: default;
  opacity: 0.65;
}
.tbl tbody tr:hover td, .table tbody tr:hover td { background: #FAFAFA; }
.tbl tbody tr:last-child td, .table tbody tr:last-child td { box-shadow: none; }

/* Critical / warn / accent row tinting */
.tbl tr.crit td,    .table tr.crit td    { background: #FFFAF9; box-shadow: inset 0 -1px 0 var(--rule); }
.tbl tr.warn td,    .table tr.warn td    { background: #FFFCF3; box-shadow: inset 0 -1px 0 var(--rule); }
.tbl tr.accent td,  .table tr.accent td  { background: #FAFAFA; box-shadow: inset 0 -1px 0 var(--rule); }

.row-list {
  display: grid;
  box-shadow: inset 0 1px 0 var(--rule), inset 0 -1px 0 var(--rule);
}
.list-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px 0;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.list-row:last-child {
  box-shadow: none;
}
.list-row.is-clickable {
  cursor: pointer;
}
.list-row.is-clickable:hover {
  background: var(--hover);
}
.list-row.selected {
  background: var(--hover-2);
}
.list-row-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-3);
}
.list-row-icon.tone-accent { color: var(--accent); }
.list-row-icon.tone-info { color: var(--info); }
.list-row-icon.tone-success { color: var(--success); }
.list-row-icon.tone-warn { color: var(--warn); }
.list-row-icon.tone-critical { color: var(--critical); }
.list-row-icon.tone-pink { color: var(--calendar-pink); }
.list-row-icon.tone-neutral { color: var(--text-3); }
.list-row-main {
  display: grid;
  gap: 7px;
  min-width: 0;
}
.list-row-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}
.list-row-title-wrap {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.list-row-title {
  color: var(--text);
  font-size: 13.5px;
  font-weight: 600;
  line-height: 1.3;
}
.list-row-title > .input {
  width: 100%;
}
.list-row-meta,
.list-row-body {
  color: var(--text-3);
  font-size: 12.5px;
  line-height: 1.45;
}
.list-row-aside {
  flex: 0 0 auto;
  color: var(--text-2);
  font-size: 12.5px;
  text-align: right;
}
.list-row-body {
  display: grid;
  gap: 8px;
}
.row-list-reasons {
  margin: 0;
  padding-left: 16px;
}

.claims-table {
  table-layout: fixed;
  min-width: 1380px;
}
.claims-table-shell {
  min-width: 0;
  container-type: inline-size;
}
.app-page-body .claims-table-shell .claims-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  overscroll-behavior-x: contain;
}
.claims-table th,
.claims-table td {
  padding: 14px 9px;
  min-width: 0;
  overflow: hidden;
  vertical-align: middle;
}
.claims-col-claim { width: 92px; }
.claims-col-claimant { width: 180px; }
.claims-col-employer { width: 175px; }
.claims-col-lni { width: 118px; }
.claims-col-status { width: 160px; }
.claims-col-cac { width: 164px; }
.claims-col-nextAction,
.claims-col-deadline { width: 180px; }
.claims-col-issues { width: 82px; }
.claims-col-team { width: 70px; }
.claims-col-activity { width: 126px; }
.claims-table col[data-col="select"] { width: 34px; }
.claims-table col[data-col="claim"] { width: 78px; }
.claims-table col[data-col="lni"] { width: 100px; }
.claims-table col[data-col="claimant"] { width: 116px; }
.claims-table col[data-col="doi"] { width: 62px; }
.claims-table col[data-col="tags"] { width: 112px; }
.claims-table col[data-col="note"] { width: 134px; }
.claims-table col[data-col="employer"] { width: 140px; }
.claims-table col[data-col="status"] { width: 138px; }
.claims-table col[data-col="nextAction"],
.claims-table col[data-col="deadline"] { width: 178px; }
.claims-table col[data-col="timeline"] { width: 104px; }
.claims-table col[data-col="issues"] { width: 64px; }
.claims-table col[data-col="team"] { width: 56px; }
.claims-table col[data-col="activity"] { width: 70px; }
.claim-id-cell {
  color: var(--text-2);
}
.claim-ref-id {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13.5px;
  font-weight: 650;
  letter-spacing: 0;
}
.claim-ref-claimant {}
.claim-ref-meta {
  margin-top: 1px;
}
.claims-table .cell-muted,
.claims-table .cell-strong {
  min-width: 0;
  max-width: 100%;
}
.claims-table .chip {
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}
.claims-table td[data-col="employer"],
.claims-table td[data-col="claimant"],
.claims-table td[data-col="tags"],
.claims-table td[data-col="note"],
.claims-table td[data-col="status"],
.claims-table td[data-col="nextAction"],
.claims-table td[data-col="deadline"] {
  overflow-wrap: anywhere;
}
.claims-table td[data-col="status"] .chip {
  display: inline-flex;
  line-height: 1.25;
  white-space: normal;
}
.claims-table td[data-col="claim"],
.claims-table td[data-col="lni"],
.claims-table td[data-col="doi"],
.claims-table td[data-col="timeline"],
.claims-table td[data-col="issues"] {
  white-space: nowrap;
}
.claims-table td[data-col="issues"] {
  padding-left: 8px;
  padding-right: 8px;
}
.claims-table td[data-col="issues"] .chip {
  padding-left: 8px;
  padding-right: 8px;
  white-space: nowrap;
}
.claims-table th[data-col="select"],
.claims-table td[data-col="select"] {
  padding-left: 4px;
  padding-right: 8px;
  text-align: right;
  vertical-align: middle;
}
.claims-table th[data-col="select"] input,
.claims-table td[data-col="select"] input {
  display: block;
  width: 14px;
  height: 14px;
  margin: 0 0 0 auto;
}
.claims-table tr:is(.claim-row-overdue, .claim-row-critical, .claim-row-warn) td:first-child {
  position: relative;
  padding-left: 18px;
  padding-right: 8px;
}
.claims-table tr:is(.claim-row-overdue, .claim-row-critical, .claim-row-warn) td:first-child::before {
  content: "";
  position: absolute;
  left: var(--table-row-indicator-offset-x);
  top: 10px;
  bottom: 10px;
  width: var(--table-row-indicator-width);
  border-radius: var(--radius-pill);
  background: var(--warn);
}
.claims-table tr:is(.claim-row-overdue, .claim-row-critical) td:first-child::before {
  background: var(--critical);
}
.claim-action-stack {
  display: grid;
  gap: 4px;
  align-content: start;
}
.claim-action-heading {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}
.claim-action-heading .cell-strong {
  min-width: 90px;
  flex: 1 1 110px;
}
.claim-action-heading .chip {
  flex: 0 0 auto;
}
.claims-table td[data-col="timeline"] .deadline-when-days {
  font-size: 15px;
  line-height: 1.05;
}
.claims-table td[data-col="timeline"] .deadline-when {
  justify-content: center;
  min-height: 44px;
  padding: 6px 8px;
  border-radius: 0;
}
.claims-table .claim-row-overdue td[data-col="timeline"] .deadline-when {
  background: color-mix(in srgb, var(--critical-soft) 58%, transparent);
}
.claims-table td[data-col="timeline"] .deadline-when-date {
  margin-top: 2px;
  white-space: nowrap;
}
.claims-table td[data-col="tags"] .claim-tag-row {
  margin-top: 0;
}
.claims-table td[data-col="tags"] .claim-tag {
  max-width: 100%;
}
.claim-note-preview {
  display: -webkit-box;
  overflow: hidden;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.25;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.table th[data-align="end"],
.table td[data-align="end"] { text-align: right; }
.table th[data-align="center"],
.table td[data-align="center"] { text-align: center; }
.table th[data-align="numeric"],
.table td[data-align="numeric"] {
  text-align: right;
  font-variant-numeric: tabular-nums lining-nums;
}
.table th[data-align="data"],
.table td[data-align="data"] {
  font-variant-numeric: tabular-nums lining-nums;
}
.claims-table th:first-child,
.claims-table td:first-child {
  padding-left: 14px;
}
.claims-table th[data-col="select"],
.claims-table td[data-col="select"],
.claims-table tr:is(.claim-row-overdue, .claim-row-critical, .claim-row-warn) td[data-col="select"] {
  padding-left: 4px;
  padding-right: 1px;
  text-align: right;
}

.cell-mono   { font-family: var(--font-mono); font-size: 13px; color: var(--text-2); }
.cell-strong { font-family: var(--font-sans); font-weight: 500; color: var(--text); font-size: 14px; letter-spacing: -0.01em; }
.cell-muted  { color: var(--text-3); }

.feedback-table {
  table-layout: fixed;
}
.feedback-table col[data-col="when"] { width: 180px; }
.feedback-table col[data-col="who"] { width: 180px; }
.feedback-table col[data-col="status"] { width: 150px; }
.feedback-comment {
  color: var(--text);
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.feedback-status-select {
  width: auto;
  min-width: 112px;
  height: 28px;
  padding: 0 26px 0 10px;
  border: 0;
  box-shadow: none;
  font-size: 12px;
  font-weight: 600;
}
.feedback-widget-button {
  position: fixed;
  z-index: 39;
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--ink);
  color: var(--ink-fg);
  box-shadow: var(--shadow-pop);
  cursor: grab;
  touch-action: none;
}
.feedback-widget-button:hover,
.feedback-widget-button:focus-visible {
  background: var(--accent);
}
.feedback-widget-button.is-dragging {
  cursor: grabbing;
}
.feedback-modal-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.feedback-form textarea {
  min-height: 118px;
}

/* ============================================================
 * 7. CARDS — hairline ruled, no fill
 * Every card variant in v3 funnels into this one pattern.
 * ============================================================ */
.card,
.card-rule {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}
.card-head {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 2px 12px;
  box-shadow: inset 0 -1px 0 var(--widget-divider);
  margin-bottom: 4px;
}
.card-head-title {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-sans);
  font-size: 18px; font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--text);
  margin: 0;
  line-height: 1.3;
  min-height: 24px;
}
.card-head-title svg { width: var(--headline-icon-size); height: var(--headline-icon-size); flex-shrink: 0; color: var(--text-3); }
.card-head-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: var(--radius-pill);
  background: var(--accent-soft);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
}
.card-head-actions,
.widget-header-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 4px;
}
.header-checkbox-actions {
  gap: var(--space-rhythm);
  flex-wrap: wrap;
  justify-content: flex-end;
}
.header-checkbox-action {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  min-height: 28px;
  padding: 0 2px;
  border: 0;
  background: transparent;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
}
.header-checkbox-action:hover,
.header-checkbox-action:focus-within {
  color: var(--text);
}
.header-checkbox-action input {
  width: 13px;
  height: 13px;
  margin: 0;
  accent-color: var(--accent);
}
.btn.widget-header-action {
  height: 24px;
  padding-inline: 8px;
  font-size: 12px;
}
.btn-icon.widget-header-action,
.btn-icon.btn-sm.widget-header-action {
  width: 24px;
  padding: 0;
}
.card-body { padding: 14px 2px; }
.card-body.tight { padding: 0; }

.widget,
.widget-surface {
  background: var(--widget-bg);
  box-shadow: var(--widget-shadow);
  padding: var(--widget-padding);
}

/* Boxed card variant — only for drawers/modals/popovers where containment is needed */
.card-boxed {
  background: var(--surface);
  border-radius: var(--radius-widget);
  box-shadow: var(--shadow-card);
}

/* ============================================================
 * 7a. SHARED FLAT PRIMITIVES
 * ============================================================ */
.metric-strip {
  --metric-columns: 4;
  display: grid;
  grid-template-columns: repeat(var(--metric-columns), minmax(0, 1fr));
  border-block: 1px solid var(--rule);
  background: transparent;
}
.metric-strip-2 { --metric-columns: 2; }
.metric-strip-3 { --metric-columns: 3; }
.metric-strip-4 { --metric-columns: 4; }
.metric-strip-5 { --metric-columns: 5; }
.metric-strip-6 { --metric-columns: 6; }
.metric-item {
  min-width: 0;
  display: grid;
  gap: 5px;
  padding: 14px 12px;
  border: 0;
  border-right: 1px solid var(--rule);
  background: transparent;
  color: inherit;
  text-align: left;
}
.metric-item:last-child { border-right: 0; }
.metric-item.is-clickable { cursor: pointer; }
.metric-item.is-clickable:hover { background: var(--hover); }
.metric-item-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  color: var(--text-3);
  font-size: 13px;
  font-weight: 500;
}
.metric-item-value {
  min-width: 0;
  color: var(--text);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.12;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.metric-item-subtext {
  color: var(--text-3);
  font-size: 13px;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.metric-item-warn .metric-item-value { color: var(--warn); }
.metric-item-critical .metric-item-value { color: var(--critical); }
.metric-item-success .metric-item-value { color: var(--success); }

.navigator-list {
  display: grid;
  border-block: 1px solid var(--rule);
}
.navigator-row {
  width: 100%;
  min-height: 44px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 0;
  border-bottom: 1px solid var(--rule);
  border-radius: 0;
  background: transparent;
  color: var(--text-2);
  text-align: left;
  cursor: pointer;
}
.navigator-row:last-child { border-bottom: 0; }
.navigator-row:hover,
.navigator-row:focus-visible,
.navigator-row.active {
  background: var(--hover);
  color: var(--text);
}
.navigator-row.disabled {
  cursor: default;
  opacity: 0.55;
}
.navigator-row-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.navigator-row-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 600;
}
.navigator-row-meta {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-3);
  font-size: 12px;
}
.navigator-row-count {
  min-width: 22px;
  padding: 2px 6px;
  border-radius: var(--radius-pill);
  background: var(--surface-3);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  text-align: center;
}
.navigator-row.active .navigator-row-count { color: var(--text); }

.review-row {
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px 0;
  border: 0;
  border-bottom: 1px solid var(--rule);
  background: transparent;
  color: inherit;
  text-align: left;
}
.review-row:last-child { border-bottom: 0; }
.review-row-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}
.review-row-title {
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.35;
}
.review-row-detail,
.review-row-meta {
  color: var(--text-3);
  font-size: 13px;
  line-height: 1.35;
}
.list-row-right,
.review-row-action {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  justify-content: flex-end;
}
.review-needed-list {
  display: grid;
  border-block: 1px solid var(--rule);
}
.review-row {
  padding: 12px 2px;
}
.review-row-warn > svg { color: var(--warn); }
.review-row-critical > svg { color: var(--critical); }
.review-row-success > svg { color: var(--success); }
.provenance-row .list-row-right {
  flex-wrap: wrap;
}
.quiet-sync-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 0;
  border-top: 1px solid var(--rule);
}
.quiet-sync-status {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
}
.quiet-sync-detail {
  margin-top: 3px;
  color: var(--text-3);
  font-size: 12px;
}
.flat-table-section + .flat-table-section {
  margin-top: 18px;
}

/* ============================================================
 * 8. AVATARS
 * ============================================================ */
.avatar {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--ring-light);
  border-radius: 50%;
  font-family: var(--font-sans);
  font-style: normal;
  font-size: 12px; font-weight: 500;
  letter-spacing: -0.02em;
  width: 28px; height: 28px;
  flex-shrink: 0;
}
.avatar.xs   { width: 20px; height: 20px; font-size: 10px; }
.avatar.sm   { width: 24px; height: 24px; font-size: 11px; }
.avatar.md   { width: 28px; height: 28px; font-size: 12px; }
.avatar.lg   { width: 36px; height: 36px; font-size: 14px; }
.avatar.xl   { width: 48px; height: 48px; font-size: 18px; font-weight: 600; letter-spacing: -0.04em; }
.avatar.filled { background: var(--ink); color: var(--ink-fg); box-shadow: none; font-weight: 600; }

/* ============================================================
 * 9. FORMS
 * ============================================================ */
.input, .textarea, .select,
input[type="text"], input[type="search"], input[type="email"], input[type="tel"],
input[type="number"], input[type="date"], textarea, select {
  font-family: inherit; font-size: 13px;
  color: var(--text);
  background: var(--surface);
  border: 0;
  box-shadow: var(--ring-light);
  border-radius: var(--radius-control);
  padding: 7px 10px;
  outline: 0;
  line-height: 1.4;
  width: 100%;
  display: block;
}
.input-invalid {
  box-shadow: 0 0 0 1px var(--critical);
}
.date-input {
  font-variant-numeric: tabular-nums;
}
.field-error {
  color: var(--critical);
  font-size: 12px;
  line-height: 1.4;
}
.input:focus, .textarea:focus, .select:focus,
input[type="text"]:focus, input[type="search"]:focus, input[type="email"]:focus,
input[type="tel"]:focus, input[type="number"]:focus, input[type="date"]:focus,
textarea:focus, select:focus { box-shadow: 0 0 0 2px var(--focus); }
.textarea, textarea { height: auto; resize: vertical; min-height: 64px; line-height: 1.5; }

.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-family: var(--font-sans);
  font-size: 13px; text-transform: none; letter-spacing: 0;
  font-weight: 500; color: var(--text-3);
  line-height: 1.3;
}
.editable-field { transition: background 0.1s; position: relative; border-radius: var(--radius-control); padding: 2px 4px; margin: -2px -4px; }
.editable-field:hover { background: var(--hover-2); }

.form-grid { display: grid; gap: 12px; }
.new-claim-modal {
  min-width: min(860px, calc(100vw - 40px));
}
.new-claim-mode-switch {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}
.new-claim-mode {
  appearance: none;
  border: 1px solid var(--rule);
  background: var(--surface);
  color: var(--text-2);
  border-radius: var(--radius-lg);
  min-height: 42px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 650;
  cursor: pointer;
}
.new-claim-mode.active {
  background: var(--ink);
  color: var(--ink-fg);
  border-color: var(--ink);
}
.cac-bootstrap-wizard {
  display: grid;
  gap: 14px;
}
.cac-bootstrap-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 72px;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--surface), var(--bg));
}
.cac-bootstrap-input {
  margin: 6px 0 8px;
  min-height: 48px;
  font-size: 22px;
  font-weight: 750;
  letter-spacing: 0;
}
.cac-bootstrap-input::placeholder {
  color: var(--text-3);
  font-weight: 500;
}
.cac-bootstrap-sync-badge {
  width: 58px;
  height: 58px;
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  color: var(--ink);
  background: var(--hover-2);
  box-shadow: inset 0 0 0 1px var(--rule);
}
.cac-bootstrap-timeline {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.cac-bootstrap-step {
  min-height: 58px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 9px 10px;
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  color: var(--text-3);
  background: var(--surface);
}
.cac-bootstrap-step.done {
  color: var(--text);
  background: #F1FAF4;
  border-color: #CFEFDB;
}
.cac-bootstrap-step.active {
  color: var(--text);
  border-color: var(--ink);
}
.cac-bootstrap-step.failed {
  color: var(--critical);
  border-color: #F0C9C9;
  background: #FFF5F5;
}
.cac-bootstrap-step-icon {
  width: 22px;
  height: 22px;
  border-radius: var(--radius-pill);
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: 750;
  color: inherit;
  background: var(--hover-2);
}
.cac-bootstrap-step.done .cac-bootstrap-step-icon {
  color: #1A7D3A;
  background: #DFF5E7;
}
.cac-bootstrap-step.failed .cac-bootstrap-step-icon {
  color: var(--critical);
  background: #F8DEDE;
}
.cac-bootstrap-step.active .cac-bootstrap-step-icon svg,
.cac-bootstrap-sync-badge.is-active svg {
  animation: spin 1.1s linear infinite;
}
.cac-transfer-showcase {
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #F4F7FB, var(--surface));
  padding: 14px;
  display: grid;
  gap: 12px;
  overflow: hidden;
}
.cac-transfer-showcase.is-failed {
  border-color: rgba(185, 28, 28, 0.28);
  background: linear-gradient(180deg, #FFF7F7, var(--surface));
}
.cac-transfer-showcase.is-committing {
  border-color: rgba(36, 114, 79, 0.32);
  background: linear-gradient(180deg, #F1FAF4, var(--surface));
}
.cac-transfer-showcase-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}
.cac-transfer-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  font-weight: 750;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #2457A8;
}
.cac-transfer-eyebrow span {
  width: 7px;
  height: 7px;
  border-radius: var(--radius-pill);
  background: #1A7D3A;
  box-shadow: 0 0 0 4px rgba(26, 125, 58, 0.12);
}
.cac-transfer-showcase.is-active .cac-transfer-eyebrow span {
  animation: pulseDot 1.4s ease-in-out infinite;
}
.cac-transfer-showcase.is-committing .cac-transfer-eyebrow {
  color: #24724F;
}
.cac-transfer-showcase.is-failed .cac-transfer-eyebrow {
  color: var(--critical);
}
.cac-transfer-showcase.is-failed .cac-transfer-eyebrow span {
  background: var(--critical);
  box-shadow: 0 0 0 4px rgba(185, 28, 28, 0.10);
}
.cac-transfer-showcase h3 {
  margin: 5px 0 0;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.cac-transfer-claim-pill {
  padding: 6px 9px;
  border-radius: var(--radius-pill);
  background: var(--surface);
  border: 1px solid var(--rule);
  color: var(--text-2);
  font-size: 12px;
  white-space: nowrap;
}
.cac-transfer-canvas {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 160px minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
}
.cac-transfer-system {
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  overflow: hidden;
  min-width: 0;
}
.cac-transfer-system.source {
  border-color: #B9CBE9;
}
.cac-transfer-system.target {
  border-color: #B9DFC8;
}
.cac-transfer-showcase.is-committing .cac-transfer-system.target {
  box-shadow: inset 0 0 0 1px rgba(36, 114, 79, 0.16), 0 0 0 3px rgba(36, 114, 79, 0.07);
}
.cac-transfer-system-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  color: white;
}
.cac-transfer-system.source .cac-transfer-system-head {
  background: #2457A8;
}
.cac-transfer-system.target .cac-transfer-system-head {
  background: #24724F;
}
.cac-transfer-system-head > span {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.16);
  flex-shrink: 0;
}
.cac-transfer-system-head strong,
.cac-transfer-system-head small {
  display: block;
  line-height: 1.2;
}
.cac-transfer-system-head strong {
  font-size: 14px;
  font-weight: 750;
}
.cac-transfer-system-head small {
  margin-top: 2px;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.82;
}
.cac-transfer-system-body {
  display: grid;
  gap: 1px;
  padding: 8px;
  background: var(--bg);
}
.cac-transfer-category {
  min-height: 28px;
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) max-content;
  gap: 8px;
  align-items: center;
  padding: 6px 8px;
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text-2);
  font-size: 12px;
}
.cac-transfer-category-icon {
  width: 22px;
  height: 22px;
  border-radius: var(--radius);
  display: grid;
  place-items: center;
  background: var(--hover-2);
  color: var(--text-2);
}
.cac-transfer-category strong {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
}
.cac-transfer-system.source .cac-transfer-category-icon {
  color: #2457A8;
  background: #E7EFFB;
}
.cac-transfer-system.target .cac-transfer-category-icon {
  color: #24724F;
  background: #E5F4EA;
}
.cac-transfer-channel {
  min-height: 220px;
  position: relative;
  display: grid;
  place-items: center;
  color: #24724F;
}
.cac-transfer-line {
  position: absolute;
  left: -10px;
  right: -10px;
  top: 72px;
  height: 2px;
  background: linear-gradient(90deg, #2457A8 0%, #24724F 100%);
  opacity: 0.34;
}
.cac-transfer-flow-dot {
  position: absolute;
  top: -4px;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: var(--radius-pill);
  background: #2457A8;
  box-shadow: 0 0 0 4px rgba(36, 87, 168, 0.12);
  opacity: 0;
}
.cac-transfer-flow-dot:nth-child(2) {
  animation-delay: 0.45s;
}
.cac-transfer-flow-dot:nth-child(3) {
  animation-delay: 0.9s;
}
.cac-transfer-showcase.is-active .cac-transfer-flow-dot {
  animation: transferDot 1.8s linear infinite;
}
.cac-transfer-showcase.is-committing .cac-transfer-flow-dot {
  background: #24724F;
  box-shadow: 0 0 0 4px rgba(36, 114, 79, 0.12);
}
.cac-transfer-status {
  width: 138px;
  display: grid;
  gap: 7px;
  text-align: center;
  color: var(--text);
}
.cac-transfer-status span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.cac-transfer-progress {
  height: 7px;
  border-radius: var(--radius-pill);
  background: #DCE5F2;
  overflow: hidden;
}
.cac-transfer-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2457A8, #24724F);
  transition: width 0.28s ease;
}
.cac-transfer-status strong {
  font-family: var(--font-mono);
  font-size: 20px;
  letter-spacing: -0.02em;
}
.cac-transfer-log {
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  overflow: hidden;
}
.cac-transfer-log-head {
  min-height: 34px;
  padding: 8px 12px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.cac-transfer-log-head span:last-child {
  color: var(--text-3);
}
.cac-transfer-log-head span:last-child.is-live,
.cac-transfer-log-head span:last-child.is-complete {
  color: #24724F;
}
.cac-transfer-log-rows {
  max-height: 122px;
  overflow: hidden;
}
.cac-transfer-log-row {
  display: grid;
  grid-template-columns: 28px 22px 76px minmax(0, 1fr) 58px 50px;
  gap: 8px;
  align-items: center;
  min-height: 30px;
  padding: 5px 12px;
  border-bottom: 1px solid var(--rule-soft);
  font-size: 11px;
  color: var(--text-2);
}
.cac-transfer-log-time,
.cac-transfer-log-cat,
.cac-transfer-log-meta,
.cac-transfer-log-status {
  font-family: var(--font-mono);
}
.cac-transfer-log-time,
.cac-transfer-log-meta {
  color: var(--text-3);
}
.cac-transfer-log-icon {
  width: 20px;
  height: 20px;
  border-radius: var(--radius-control);
  display: grid;
  place-items: center;
  color: #2457A8;
  background: #E7EFFB;
}
.cac-transfer-log-cat {
  font-size: 9.5px;
  letter-spacing: 0.1em;
  font-weight: 750;
  color: #2457A8;
}
.cac-transfer-log-name {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 600;
}
.cac-transfer-log-status {
  justify-self: end;
  color: #24724F;
  font-size: 10px;
  font-weight: 750;
}
.cac-transfer-log-status.wait {
  color: var(--text-3);
}
.cac-transfer-log-status.live {
  color: #2457A8;
}
.cac-transfer-log-status.sync,
.cac-transfer-log-status.file,
.cac-transfer-log-status.task {
  color: #24724F;
}
.cac-transfer-log-status.miss {
  color: var(--critical);
}
.cac-transfer-log-row.cat-parties .cac-transfer-log-icon,
.cac-transfer-log-row.cat-parties .cac-transfer-log-cat {
  color: #7457B8;
}
.cac-transfer-log-row.cat-docs .cac-transfer-log-icon,
.cac-transfer-log-row.cat-docs .cac-transfer-log-cat {
  color: #A86525;
}
.cac-transfer-log-row.cat-medical .cac-transfer-log-icon,
.cac-transfer-log-row.cat-medical .cac-transfer-log-cat {
  color: #B84646;
}
.cac-transfer-log-row.cat-pay .cac-transfer-log-icon,
.cac-transfer-log-row.cat-pay .cac-transfer-log-cat,
.cac-transfer-log-row.cat-legal .cac-transfer-log-icon,
.cac-transfer-log-row.cat-legal .cac-transfer-log-cat {
  color: #24724F;
}
@keyframes transferDot {
  0% { transform: translateX(0); opacity: 0; }
  12% { opacity: 1; }
  84% { opacity: 1; }
  100% { transform: translateX(154px); opacity: 0; }
}
@keyframes pulseDot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.45; transform: scale(0.86); }
}
@media (prefers-reduced-motion: reduce) {
  .cac-transfer-showcase.is-active .cac-transfer-eyebrow span,
  .cac-transfer-showcase.is-active .cac-transfer-flow-dot {
    animation: none;
  }
  .cac-transfer-progress i {
    transition: none;
  }
}
.cac-bootstrap-step strong,
.cac-bootstrap-step small {
  display: block;
  line-height: 1.25;
}
.cac-bootstrap-step strong {
  font-size: 12px;
}
.cac-bootstrap-step small {
  margin-top: 3px;
  font-size: 11px;
  color: var(--text-3);
  overflow-wrap: anywhere;
}
.cac-bootstrap-review {
  display: grid;
  gap: 10px;
}
.cac-bootstrap-review-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 10px;
}
.cac-bootstrap-panel {
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 12px;
  background: var(--bg);
  min-width: 0;
}
.cac-bootstrap-panel h3 {
  margin: 6px 0 10px;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: 0;
}
.cac-bootstrap-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}
.cac-bootstrap-facts div {
  padding: 9px;
  border-radius: var(--radius);
  background: var(--surface);
  min-width: 0;
}
.cac-bootstrap-facts dt {
  font-size: 11px;
  color: var(--text-3);
}
.cac-bootstrap-facts dd {
  margin: 2px 0 0;
  font-weight: 650;
  overflow-wrap: anywhere;
}
.cac-bootstrap-group-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.cac-bootstrap-field-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.cac-bootstrap-policy-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 10px;
}
.cac-bootstrap-policy-grid > div {
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 10px;
  min-width: 0;
}
.cac-bootstrap-policy-grid strong {
  display: block;
  font-size: 12px;
  margin-bottom: 4px;
}
.cac-bootstrap-policy-grid p {
  margin: 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.cac-bootstrap-extracted-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.cac-bootstrap-extracted-section {
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 10px;
  min-width: 0;
}
.cac-bootstrap-extracted-section h4 {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 8px;
  font-size: 13px;
  letter-spacing: 0;
}
.cac-bootstrap-extracted-section dl {
  display: grid;
  gap: 6px;
  margin: 0;
}
.cac-bootstrap-extracted-section div {
  min-width: 0;
}
.cac-bootstrap-extracted-section dt {
  font-size: 10px;
  color: var(--text-3);
}
.cac-bootstrap-extracted-section dd {
  margin: 1px 0 0;
  font-size: 12px;
  font-weight: 650;
  overflow-wrap: anywhere;
}
.cac-bootstrap-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}
.cac-bootstrap-doc-list {
  display: grid;
  gap: 8px;
  max-height: 240px;
  overflow: auto;
}
.cac-bootstrap-doc-card {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr) max-content;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-lg);
  background: var(--surface);
}
.cac-bootstrap-doc-card input {
  width: 14px;
  height: 14px;
  box-shadow: none;
}
.cac-bootstrap-doc-card strong,
.cac-bootstrap-doc-card small {
  display: block;
  overflow-wrap: anywhere;
}
.cac-bootstrap-doc-card small {
  color: var(--text-3);
  margin-top: 2px;
}
.cac-bootstrap-warnings {
  display: grid;
  gap: 6px;
  color: var(--warn);
  font-size: 13px;
}
.cac-bootstrap-warnings > div {
  display: flex;
  align-items: center;
  gap: 6px;
}
.cac-bootstrap-not-found {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  border-color: #F0C9C9;
  background: #FFF8F8;
}
.cac-bootstrap-not-found-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  color: var(--critical);
  background: #F8DEDE;
}
.cac-bootstrap-not-found h3 {
  margin: 4px 0 6px;
}
.cac-bootstrap-not-found p {
  margin: 0;
  color: var(--text-2);
  line-height: 1.45;
}
.check-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
  color: var(--text-2);
  font-size: 13px;
}
.check-row input {
  width: auto;
  box-shadow: none;
}

/* ============================================================
 * 10. TABS
 * ============================================================ */
.tabs {
  --tabs-active-x: 3px;
  --tabs-active-width: 0px;
  position: relative;
  display: inline-flex;
  align-self: flex-start;
  width: fit-content;
  max-width: 100%;
  align-items: center;
  gap: 2px;
  padding: var(--tabs-track-padding);
  overflow-x: auto;
  border: 1px solid var(--rule);
  border-radius: var(--radius-tab-track);
  background: var(--surface);
  box-shadow: none;
}
.tabs.has-floating-labels {
  overflow: visible;
}
.tabs-indicator {
  position: absolute;
  z-index: 0;
  top: var(--tabs-track-padding);
  bottom: var(--tabs-track-padding);
  left: 0;
  width: var(--tabs-active-width);
  min-width: var(--tabs-active-width);
  inline-size: var(--tabs-active-width);
  border-radius: var(--radius-control);
  background: linear-gradient(180deg, var(--surface-2) 0%, var(--surface-3) 100%);
  transform: translateX(var(--tabs-active-x));
  transition:
    transform 360ms cubic-bezier(0.2, 0.82, 0.16, 1),
    width 300ms cubic-bezier(0.22, 0.75, 0.16, 1);
  will-change: transform, width;
}
.tabs-floating-label {
  position: absolute;
  z-index: 4;
  top: calc(var(--tabs-floating-label-gap) * -1);
  left: 0;
  max-width: 180px;
  padding: var(--tabs-floating-label-padding);
  border-radius: var(--tabs-floating-label-radius);
  background: var(--tabs-floating-label-bg);
  color: var(--tabs-floating-label-color);
  box-shadow: var(--tabs-floating-label-shadow);
  font-size: var(--tabs-item-font-size);
  font-weight: var(--tabs-active-font-weight);
  line-height: 1.1;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  transform: translate3d(var(--tabs-floating-label-x, 0px), -100%, 0) translateX(-50%) translateY(2px);
  transition:
    transform 220ms cubic-bezier(0.22, 0.75, 0.16, 1),
    opacity 150ms ease;
  will-change: transform, opacity;
}
.tabs-floating-label::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: calc(var(--tabs-floating-label-pointer-size) / -2);
  width: var(--tabs-floating-label-pointer-size);
  height: var(--tabs-floating-label-pointer-size);
  border-radius: 1px;
  background: inherit;
  transform: translateX(-50%) rotate(45deg);
}
.tabs-floating-label.is-visible {
  opacity: 1;
  transform: translate3d(var(--tabs-floating-label-x, 0px), -100%, 0) translateX(-50%) translateY(0);
}
.tab {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: var(--tabs-item-gap);
  min-height: var(--tabs-item-min-height);
  padding: var(--tabs-item-padding);
  border: 0;
  border-radius: var(--radius-control);
  color: var(--text-2);
  background: transparent;
  cursor: pointer;
  font: inherit;
  font-size: var(--tabs-item-font-size);
  font-weight: var(--tabs-item-font-weight);
  line-height: 1.15;
  white-space: nowrap;
  transition: color 150ms ease;
}
.tab:hover,
.tab:focus-visible,
.tab.active { color: var(--text); }
.tab:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}
.tab.active {
  font-weight: var(--tabs-active-font-weight);
  box-shadow: none;
}
.tabs-leading-label {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: var(--tabs-item-min-height);
  max-width: var(--tabs-leading-label-max-width);
  padding: 0 6px 0 7px;
  overflow: hidden;
  color: var(--text-3);
  font-size: var(--tabs-item-font-size);
  font-weight: var(--tabs-item-font-weight);
  line-height: 1;
  white-space: nowrap;
  transform: translateX(0);
  transition:
    max-width 360ms cubic-bezier(0.22, 0.75, 0.16, 1),
    opacity 260ms ease,
    padding 360ms cubic-bezier(0.22, 0.75, 0.16, 1),
    transform 320ms cubic-bezier(0.22, 0.75, 0.16, 1);
}
.tabs-leading-label.is-hidden {
  max-width: 0;
  padding-inline: 0;
  opacity: 0;
  transform: translateX(-4px);
}
.tab.is-icon-only {
  overflow: hidden;
  justify-content: center;
  width: var(--tabs-icon-only-size);
  padding: 5px;
  gap: 0;
}
.tabs:not(.has-floating-labels) .tab.is-icon-only:hover,
.tabs:not(.has-floating-labels) .tab.is-icon-only:focus-visible {
  width: auto;
  justify-content: flex-start;
  gap: var(--tabs-item-gap);
  padding: var(--tabs-item-padding);
}
.tab-collapsible-label,
.tab-collapsible-count {
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateX(-3px);
  white-space: nowrap;
  transition:
    max-width 360ms cubic-bezier(0.22, 0.75, 0.16, 1),
    opacity 240ms ease,
    transform 320ms cubic-bezier(0.22, 0.75, 0.16, 1);
}
.tab.is-icon-only .tab-collapsible-count {
  min-height: 0;
  padding-inline: 0;
}
.tabs:not(.has-floating-labels) .tab.is-icon-only:hover .tab-collapsible-label,
.tabs:not(.has-floating-labels) .tab.is-icon-only:focus-visible .tab-collapsible-label {
  max-width: 120px;
  opacity: 1;
  transform: translateX(0);
}
.tabs:not(.has-floating-labels) .tab.is-icon-only:hover .tab-collapsible-count,
.tabs:not(.has-floating-labels) .tab.is-icon-only:focus-visible .tab-collapsible-count {
  max-width: 48px;
  min-height: 17px;
  padding-inline: 6px;
  opacity: 1;
  transform: translateX(0);
}
.tabs:not(.has-moving-indicator) .tab.active {
  background: linear-gradient(180deg, var(--surface-2) 0%, var(--surface-3) 100%);
}
.inbox-tabs {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-wrap: wrap;
}
.inbox-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 24px;
  padding: 4px 10px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
}
.inbox-tab:hover {
  background: var(--hover);
  color: var(--text);
}
.inbox-tab.active {
  background: var(--surface);
  color: var(--text);
  border-color: var(--rule-firm);
  font-weight: 600;
  box-shadow: inset 0 -2px 0 var(--accent);
}
.tab-count {
  display: inline-flex;
  align-items: center;
  min-height: 17px;
  padding: 1px 6px;
  border-radius: var(--radius-control);
  color: var(--text-3);
  background: var(--surface-2);
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
}
.tab.active .tab-count { color: var(--text-3); background: var(--surface); }
.inbox-tab-count {
  font-family: var(--font-mono);
  font-size: 11px; color: var(--text-3);
  padding: 1px 6px;
  border-radius: var(--radius-pill);
  background: #F4F4F4;
  font-weight: 500;
}
.inbox-tab-count { border: 1px solid var(--rule); }
.inbox-tab.active .inbox-tab-count { color: var(--text); background: #EBEBEB; }
.inbox-tab.active .inbox-tab-count { border-color: var(--rule-firm); }

@media (prefers-reduced-motion: reduce) {
  .tabs-indicator {
    transition: none;
  }
}

/* Inbox tab variant — a bit lighter, used in toolbars */
.inbox-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 12px 24px;
  box-shadow: inset 0 -1px 0 var(--rule);
  flex-wrap: wrap;
}
.inbox-detail-view {
  display: grid;
  gap: 12px;
}
.inbox-detail-topbar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  padding: 0 0 10px;
  border-bottom: 1px solid var(--rule);
}
.inbox-detail-heading {
  min-width: 0;
}
.inbox-detail-title {
  color: var(--text);
  font-size: 16px;
  font-weight: 720;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.inbox-detail-shell {
  background: var(--surface);
}
.inbox-detail-shell .lx-q3hiop {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  height: auto;
  min-height: min(820px, calc(100vh - 210px));
  margin: 0;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
}
.inbox-detail-view-workspace {
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.inbox-detail-view-workspace .inbox-detail-shell {
  min-height: 0;
  flex: 1;
  display: flex;
}
.inbox-detail-view-workspace .lx-q3hiop {
  width: 100%;
  min-height: 0;
  height: 100%;
  border: 0;
  border-radius: 0;
}
.inbox-detail-view-workspace .lx-1en0zvr {
  padding: 0;
}
.inbox-workspace-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 0 0 10px;
  color: var(--text-3);
  font-size: 13px;
  border-bottom: 1px solid var(--rule);
}
.inbox-viewer-toggle {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 2px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
  margin-left: auto;
}
.inbox-viewer-toggle-button {
  min-height: 24px;
  padding: 3px 8px;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-3);
  font: inherit;
  font-size: 12px;
  font-weight: 650;
  cursor: pointer;
}
.inbox-viewer-toggle-button:hover {
  color: var(--text);
  background: var(--hover-2);
}
.inbox-viewer-toggle-button:disabled {
  color: var(--text-4);
  cursor: not-allowed;
  background: transparent;
  box-shadow: none;
}
.inbox-viewer-toggle-button.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--ring-light);
}
.inbox-markdown-viewer {
  min-height: 520px;
  max-height: calc(100vh - 310px);
  overflow: auto;
  padding: 18px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--ring-light);
}
.inbox-pdf-embed-shell {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 640px;
  height: calc(100vh - 280px);
  overflow: hidden;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--ring-light);
}
.inbox-pdf-embed-shell .inbox-anchor-viewer {
  flex: 1;
  min-height: 0;
  min-width: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
}
.inbox-pdf-embed-shell .pdf-anchor-pages {
  flex: 1;
  min-height: 0;
  max-height: none;
  width: 100%;
  overflow: auto;
}
.inbox-pdf-embed-shell .pdf-anchor-page {
  max-width: 100%;
}
.inbox-pdf-embed-shell .pdf-anchor-canvas {
  max-width: 100%;
  height: auto;
}
.inbox-pdf-embed {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: var(--surface);
}
.inbox-pdf-loading-state {
  display: grid;
  min-height: 100%;
  place-items: center;
  padding: 24px;
  color: var(--muted);
  text-align: center;
}
.inbox-pdf-loading-state.has-error {
  color: var(--text);
}
.inbox-pdf-error-card {
  display: grid;
  gap: 10px;
  max-width: 420px;
  text-align: left;
}
.inbox-pdf-error-card p {
  margin: 0;
  color: var(--text-3);
  font-size: 13px;
  line-height: 1.5;
}
.inbox-pdf-error-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.inbox-pdf-reader-actions {
  position: absolute;
  right: 12px;
  bottom: 12px;
  display: flex;
  gap: 8px;
  align-items: center;
}
.inbox-pdf-reader-actions > .btn {
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}
.inbox-markdown-content {
  max-width: 760px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.58;
}
.inbox-markdown-content h2,
.inbox-markdown-content h3,
.inbox-markdown-content h4 {
  margin: 0 0 10px;
  color: var(--text);
  font-weight: 720;
  line-height: 1.25;
}
.inbox-markdown-content h2 { font-size: 18px; }
.inbox-markdown-content h3 { font-size: 15px; }
.inbox-markdown-content h4 { font-size: 13px; }
.inbox-markdown-content p,
.inbox-markdown-content ul {
  margin: 0 0 10px;
}
.inbox-markdown-content ul {
  padding-left: 20px;
}
.inbox-markdown-content li {
  margin: 0 0 4px;
}
.inbox-markdown-content code {
  padding: 1px 4px;
  border-radius: var(--radius-sm);
  background: var(--surface-3);
  font-family: var(--font-mono);
  font-size: 12px;
}
.inbox-markdown-content a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.inbox-upload-ocr {
  min-height: 142px;
  font-family: var(--font-mono);
  font-size: 12px;
}
/* ============================================================
 * 11. FILTER BAR (legacy v3) → small pill buttons
 * ============================================================ */
.filter-bar {
  display: flex; align-items: center; gap: 6px;
  padding: var(--space-rhythm) var(--space-rhythm) 0;
  box-shadow: none;
  background: var(--canvas-bg);
  flex-wrap: wrap;
}
.filter-bar .filter-search {
  flex: 0 1 280px;
  width: auto;
  max-width: 320px;
  height: 28px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  box-shadow: none;
}
.filter-bar .filter-search:focus-within {
  background: var(--surface);
  box-shadow: 0 0 0 2px var(--focus);
}
.filter-bar .filter-search input {
  font-size: 12.5px;
}
.filter-bar-spacer {
  flex: 1 1 auto;
  min-width: 8px;
}
.filter-bar-actions {
  margin-left: auto;
  padding-left: var(--space-rhythm);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}
.toggle-switch {
  --toggle-w: 38px;
  --toggle-h: 22px;
  --toggle-pad: 2px;
  --toggle-knob: calc(var(--toggle-h) - var(--toggle-pad) * 2);
  position: relative;
  display: inline-flex;
  align-items: center;
  width: var(--toggle-w);
  height: var(--toggle-h);
  flex: 0 0 auto;
  padding: 0;
  border: 0;
  border-radius: var(--radius-pill);
  background: var(--surface-3);
  box-shadow: inset 0 0 0 1px var(--rule);
  cursor: pointer;
  transition: background 160ms ease, box-shadow 160ms ease;
}
.toggle-switch > span {
  position: absolute;
  top: var(--toggle-pad);
  left: var(--toggle-pad);
  width: var(--toggle-knob);
  height: var(--toggle-knob);
  border-radius: 50%;
  background: var(--surface);
  box-shadow: 0 1px 2px rgba(0,0,0,0.18), 0 0 0 1px rgba(0,0,0,0.04);
  transition: transform 180ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.toggle-switch:hover {
  background: color-mix(in srgb, var(--text-4) 30%, var(--surface-3));
}
.toggle-switch.is-on {
  background: #0f766e;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, #0f766e 80%, transparent);
}
.toggle-switch.is-on > span {
  transform: translateX(calc(var(--toggle-w) - var(--toggle-h)));
}
.toggle-switch:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}
.toggle-switch:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}
.filtered-table-toolbar {
  align-items: center;
  column-gap: var(--space-7);
  row-gap: var(--space-3);
  padding: var(--space-rhythm) 0 0;
  background: var(--canvas-bg);
  flex-direction: row;
  flex-wrap: wrap;
}
.filtered-table-toolbar .filtered-table-search {
  flex: 0 0 auto;
  width: min(320px, 100%);
  max-width: 320px;
  height: 28px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  box-shadow: none;
}
.filtered-table-summary {
  min-height: 28px;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 0 1 auto;
  max-width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--text-2);
  flex-wrap: wrap;
}
.filtered-table-summary.is-empty {
  display: none;
  min-width: 0;
  flex-basis: 0;
}
.filtered-table-summary-label {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
}
.filtered-table-chip {
  max-width: min(280px, 100%);
  white-space: nowrap;
  cursor: default;
}
.filtered-table-chip > span {
  overflow: hidden;
  text-overflow: ellipsis;
}
.filtered-table-chip button,
.filtered-table-clear {
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}
.filtered-table-chip button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.filtered-table-clear {
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 500;
  padding: 0 2px;
}
.filtered-table-clear:hover,
.filtered-table-clear:focus-visible {
  color: var(--text);
}
.filtered-table-th {
  position: relative;
  --filtered-table-filter-accent: var(--calendar-purple);
}
.filtered-table-th-anchor {
  position: relative;
}
.filtered-table-th-button {
  width: 100%;
  min-height: 100%;
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-align: left;
  white-space: nowrap;
  cursor: pointer;
}
.filtered-table-heading-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.filtered-table-th-button:hover,
.filtered-table-th-button:focus-visible,
.filtered-table-th.is-open .filtered-table-th-button {
  color: var(--text);
  outline: none;
}
.filtered-table-th.is-filtered {
  color: var(--filtered-table-filter-accent);
}
.filtered-table-th.is-filtered::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: var(--filtered-table-filter-accent);
}
.filtered-table-heading-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: var(--text-3);
  opacity: 0.72;
  transition: color 120ms ease, opacity 120ms ease, transform 120ms ease;
}
.filtered-table-th-button:hover .filtered-table-heading-chevron,
.filtered-table-th-button:focus-visible .filtered-table-heading-chevron,
.filtered-table-th.is-open .filtered-table-heading-chevron {
  color: var(--text-2);
  opacity: 1;
}
.filtered-table-th.is-open .filtered-table-heading-chevron {
  transform: rotate(180deg);
}
.filtered-table-th.is-filtered .filtered-table-heading-chevron {
  color: var(--filtered-table-filter-accent);
  opacity: 1;
}
.filtered-table-sort-mark {
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}
.filtered-table-popover {
  z-index: 1000;
  min-width: 240px;
  max-width: min(360px, calc(100vw - 36px));
  padding: 6px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-control);
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow-pop);
  text-transform: none;
  letter-spacing: 0;
}
.filtered-table-popover-section {
  padding: 8px;
}
.filtered-table-popover-section + .filtered-table-popover-section,
.filtered-table-popover-footer {
  border-top: 1px solid var(--rule-soft);
}
.filtered-table-popover-label {
  margin-bottom: 6px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
}
.filtered-table-option,
.filtered-table-sort-option {
  width: 100%;
  min-height: 28px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  border: 0;
  border-radius: var(--radius-control);
  background: transparent;
  color: var(--text-2);
  font: inherit;
  font-size: 12px;
  text-align: left;
  cursor: pointer;
}
.filtered-table-option:hover,
.filtered-table-sort-option:hover,
.filtered-table-sort-option.active {
  background: var(--surface-2);
  color: var(--text);
}
.filtered-table-option input {
  flex: 0 0 auto;
}
.filtered-table-option-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.filtered-table-option-count {
  margin-left: auto;
  color: var(--text-3);
  font-size: 11px;
}
.filtered-table-option-list {
  max-height: 180px;
  overflow: auto;
  padding-right: 2px;
}
.filtered-table-popover .input,
.filtered-table-popover .search-bar {
  width: 100%;
}
.filtered-table-date-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}
.filtered-table-presets + .filtered-table-date-grid {
  margin-top: var(--space-3);
}
.filtered-table-date-grid label {
  display: grid;
  gap: 4px;
  min-width: 0;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 500;
}
.filtered-table-date-grid input {
  box-sizing: border-box;
  min-width: 0;
  width: 100%;
}
.filtered-table-presets {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.filtered-table-preset {
  min-height: 26px;
  padding: 4px 8px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-2);
  font: inherit;
  font-size: 11.5px;
  cursor: pointer;
}
.filtered-table-preset:hover,
.filtered-table-preset.active {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}
.tab-filter-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 0 0 10px;
  box-shadow: inset 0 -1px 0 var(--rule);
  background: var(--bg);
  flex-wrap: wrap;
}
.tab-filter-tabs {
  display: flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
  overflow-x: auto;
}
.tab-filter-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 32px;
  padding: 7px 10px;
  color: var(--text-3);
  background: transparent;
  font-size: 12.5px;
  font-weight: 500;
  white-space: nowrap;
}
.tab-filter-tab:hover {
  color: var(--text-2);
}
.tab-filter-tab.active {
  color: var(--text);
  box-shadow: inset 0 -2px 0 var(--text);
}
.tab-filter-meta {
  color: var(--text-3);
  font-size: 12px;
  min-width: 0;
}
.tab-filter-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 6px;
}
.filter-pill {
  display: inline-flex; align-items: center; gap: var(--filter-control-gap);
  padding: 0 var(--filter-control-padding-x);
  height: var(--filter-control-height);
  font-size: var(--filter-control-font-size); font-weight: var(--filter-control-font-weight);
  color: var(--text-2);
  background: var(--surface);
  box-shadow: var(--ring-light);
  border-radius: var(--filter-control-radius);
  cursor: pointer;
}
.filter-pill:hover { background: var(--hover); }
.filter-pill.active { box-shadow: 0 0 0 1px var(--text); color: var(--text); }
.filter-pill-tone-accent {
  background: var(--filter-active-bg);
  color: var(--filter-active-text);
  box-shadow: none;
  font-weight: var(--filter-control-active-font-weight);
}
.filter-pill-tone-accent:hover {
  background: var(--filter-active-bg);
}
.filter-pill-tone-accent .filter-pill-val,
.filter-pill-tone-accent .filter-pill-x {
  color: inherit;
}
.filter-pill-key { color: var(--text-3); font-size: 11px; }
.filter-pill-val { font-weight: 500; color: var(--text); }
.filter-pill-x   { opacity: 0.55; cursor: pointer; padding-left: 2px; }
.filter-pill-x:hover { opacity: 1; }
.app-page-body > .lx-28v4rf.knowledge-page-root {
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding-top: 0;
}
.knowledge-filter-bar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) repeat(4, max-content);
  align-items: center;
  gap: 8px;
  padding-top: 8px;
  padding-bottom: 10px;
  padding-left: 24px;
  padding-right: 24px;
  margin-left: -24px;
  margin-right: -24px;
  box-shadow: inset 0 -1px 0 var(--rule);
}
.knowledge-filter-bar .search-bar {
  width: 100%;
  max-width: none;
}
.knowledge-filter-select {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 260px;
}
.knowledge-filter-summary {
  grid-column: 4;
  justify-self: end;
  white-space: nowrap;
  margin-bottom: 4px;
}
.knowledge-create-actions {
  grid-column: 5;
  display: inline-flex;
  align-items: center;
  justify-self: end;
  gap: 6px;
}
.knowledge-kind-switcher {
  grid-column: 1 / 4;
  display: inline-flex;
  align-items: center;
  justify-self: start;
  gap: 2px;
  max-width: 100%;
  padding: 3px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  overflow-x: auto;
}
.knowledge-kind-switcher button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 28px;
  padding: 0 10px;
  border: 0;
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--text-3);
  font: inherit;
  font-size: 12px;
  white-space: nowrap;
  cursor: pointer;
}
.knowledge-kind-switcher button:hover {
  background: var(--hover);
  color: var(--text);
}
.knowledge-kind-switcher button.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--ring-light);
}
.knowledge-kind-count {
  color: var(--text-3);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}

@media (max-width: 1180px) {
  .knowledge-filter-bar {
    grid-template-columns: minmax(260px, 1fr) repeat(2, max-content);
  }

  .knowledge-filter-summary {
    grid-column: 1 / -1;
    justify-self: start;
  }
  .knowledge-create-actions {
    grid-column: 1 / -1;
    justify-self: start;
  }
  .knowledge-kind-switcher {
    grid-column: 1 / -1;
  }
}

.menu-popover {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  padding: 4px;
  z-index: 50;
  background: var(--surface);
  border-radius: var(--radius-container);
  box-shadow: var(--shadow-pop);
}
.menu-popover.align-right { left: auto; right: 0; }
.menu-section {
  padding: 4px 0;
}
.menu-section + .menu-section {
  box-shadow: inset 0 1px 0 var(--rule-soft);
}
.menu-item {
  width: 100%;
  min-height: 28px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius-control);
  text-align: left;
  font-size: 12.5px;
  color: var(--text-2);
}
.menu-item:hover,
.menu-item:focus-visible,
.menu-item[aria-selected="true"] {
  background: var(--hover-2);
  color: var(--text);
  outline: 0;
}
.menu-item-check {
  margin-left: auto;
  color: var(--text);
  display: inline-flex;
}

/* ============================================================
 * 12. COMMAND MENU / SKELETONS
 * ============================================================ */
.command-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(0,0,0,0.28);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: min(14vh, 120px);
}
.command-menu {
  width: min(640px, calc(100vw - 32px));
  max-height: min(640px, calc(100vh - 80px));
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: var(--radius-container);
  background: var(--bg);
  box-shadow: var(--shadow-pop);
}
.command-search {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  box-shadow: inset 0 -1px 0 var(--rule);
  color: var(--text-3);
}
.command-search input {
  border: 0;
  outline: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  width: 100%;
  font-size: 14px;
}
.command-results {
  overflow: auto;
  padding: 8px;
}
.command-group-label {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-2);
  padding: 10px 8px 6px;
}
.command-item {
  display: grid;
  grid-template-columns: 24px 1fr auto;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 38px;
  padding: 7px 9px;
  border-radius: var(--radius-control);
  text-align: left;
}
.command-item:hover,
.command-item[aria-selected="true"] {
  background: var(--surface-3);
}
.command-item:disabled,
.command-item.is-disabled {
  cursor: not-allowed;
  opacity: 0.55;
}
.command-item-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-control);
  background: var(--surface-2);
  color: var(--text-3);
}
.command-item-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.command-item-label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  line-height: 18px;
  color: var(--text);
}
.command-item-sub {
  display: block;
  font-size: 12px;
  line-height: 16px;
  color: var(--text-3);
}
.command-item-source {
  display: block;
  font-size: 11px;
  line-height: 14px;
  color: var(--text-2);
}
.command-empty {
  padding: 32px 16px;
  text-align: center;
  color: var(--text-3);
  font-size: 13px;
}

.skeleton {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: var(--surface-3);
}
.skeleton::after {
  content: '';
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.75), transparent);
  animation: skeleton-shimmer 1.35s infinite;
}
.skeleton-line { height: 12px; width: 100%; }
.skeleton-pill { height: 20px; border-radius: var(--radius-pill); }
.skeleton-table {
  padding: 14px;
}
.skeleton-row {
  display: grid;
  grid-template-columns: 110px 1fr 160px 150px 120px;
  gap: 16px;
  padding: 14px 0;
  box-shadow: inset 0 -1px 0 var(--rule);
}
@keyframes skeleton-shimmer {
  100% { transform: translateX(100%); }
}

/* ============================================================
 * 12. STATUS DOTS
 * ============================================================ */
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; background: var(--text-4); }
.dot.critical { background: var(--critical); }
.dot.warn     { background: var(--warn); }
.dot.success  { background: var(--success); }
.dot.info     { background: var(--info); }

/* ============================================================
 * 13. HUB / DASHBOARD STAT BLOCKS
 * ============================================================ */
.hub { display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); gap: 24px; padding: 24px 24px; align-items: start; }
.hub-col { display: flex; flex-direction: column; gap: 24px; min-width: 0; }
.hub-summary { background: transparent; border: 0; padding: 12px 0; }
.hub-summary-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding: 14px 0; box-shadow: inset 0 -1px 0 var(--rule), inset 0 1px 0 var(--rule); }
.hub-stat-label { font-family: var(--font-sans); font-size: 13px; text-transform: none; letter-spacing: 0; color: var(--text-3); margin-bottom: 6px; font-weight: 500; line-height: 1; }
.hub-stat-value { font-family: var(--font-sans); font-size: 24px; font-weight: 600; letter-spacing: -0.04em; line-height: 1.1; color: var(--text); }

/* ============================================================
 * 14. DEADLINE / ACTIVITY ROWS — typographic, no panels
 * ============================================================ */
.deadline-row {
  display: grid; grid-template-columns: 104px 1fr auto;
  column-gap: 18px; row-gap: 12px; align-items: center;
  position: relative;
  padding: 10px 6px 10px 18px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
  cursor: pointer;
}
.deadline-row.critical { box-shadow: inset 0 -1px 0 var(--rule-soft); }
.deadline-row.overdue {
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.deadline-row.warn {
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.deadline-row.conflict {
  background: color-mix(in srgb, var(--warn-soft) 52%, transparent);
}
.deadline-row:is(.critical, .overdue, .warn)::before {
  content: "";
  position: absolute;
  left: 9px;
  top: 10px;
  bottom: 10px;
  width: 2px;
  border-radius: var(--radius-pill);
  background: var(--text-4);
}
.deadline-row:is(.critical, .overdue)::before { background: var(--critical); }
.deadline-row.warn::before { background: var(--warn); }
.warn-text {
  color: var(--warn);
}
.deadline-when { display: flex; flex-direction: column; }
.deadline-row > .deadline-when {
  align-self: stretch;
  justify-content: center;
  padding: 6px 8px 6px 10px;
}
.deadline-row.overdue > .deadline-when {
  background: color-mix(in srgb, var(--critical-soft) 58%, transparent);
}
.deadline-when-days { font-family: var(--font-sans); font-size: 18px; font-weight: 600; letter-spacing: -0.03em; line-height: 1; color: var(--text); }
.deadline-when-days.overdue,
.deadline-when-days.critical { color: var(--critical); }
.deadline-when-days.warn     { color: var(--warn); }
.deadline-when-date { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); margin-top: 4px; letter-spacing: 0; }
.deadline-urgency-chip {
  width: fit-content;
  margin-top: 5px;
}
.deadline-label  { font-size: 13px; color: var(--text); font-weight: 500; }
.deadline-source { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.deadline-audit-detail-grid,
.knowledge-provenance-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px 10px;
  margin-top: 8px;
}
.knowledge-provenance-grid span {
  min-width: 0;
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
}
.knowledge-provenance-grid strong {
  display: block;
  color: var(--text-2);
  font-weight: 650;
}
.deadline-audit-detail-grid > div {
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-control);
  background: var(--surface-2);
}
.deadline-audit-detail-grid span {
  display: block;
  color: var(--text-3);
  font-size: 11px;
}
.deadline-audit-detail-grid strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
  font-size: 12px;
  line-height: 1.35;
}
.deadline-conflict-banner,
.claim-update-legal-conflict-banner {
  align-items: start;
}
.deadline-key-date-panel {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}
.deadline-key-date-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.deadline-key-date-table {
  display: grid;
  max-height: 340px;
  min-width: 0;
  overflow: auto;
  border: 1px solid var(--rule);
  border-radius: var(--radius-control);
}

/* CAC complete-data workspace */
.cac-workspace {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.cac-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.cac-subtabs {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
}
.cac-subtab {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 5px 9px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-3);
  background: transparent;
  border-radius: var(--radius);
}
.cac-subtab:hover,
.cac-subtab.active {
  background: var(--surface-3);
  color: var(--text);
}
.cac-table-wrap {
  overflow: auto;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
}
.cac-data-table {
  min-width: 740px;
}
.cac-mini-grid,
.cac-recommendation-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.cac-recommendation-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.cac-mini-panel,
.cac-recommendation-grid > div {
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 10px;
  background: var(--surface);
}
.cac-bar-list {
  display: grid;
  gap: 10px;
}
.cac-bar-row {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr) 82px 18px;
  gap: 10px;
  align-items: center;
  font-size: 13px;
}
.cac-bar-button {
  width: 100%;
  border: 1px solid transparent;
  border-radius: var(--radius);
  padding: 8px;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}
.cac-bar-button:hover,
.cac-bar-button:focus-visible {
  border-color: var(--rule);
  background: var(--surface-2);
  outline: none;
}
.cac-bar {
  height: 8px;
  border-radius: var(--radius-pill);
  overflow: hidden;
  background: var(--surface-3);
}
.cac-bar-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--ink);
}
.cac-bar-fill.info { background: var(--info); }
.cac-bar-fill.success { background: var(--success); }
.cac-bar-fill.warn { background: var(--warn); }
.cac-cost-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.cac-cost-summary > div {
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 12px;
  background: var(--surface);
}
.cac-source-field-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cac-source-field-list code {
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 4px 6px;
  background: var(--surface-2);
  font-size: 11px;
}
.official-lni-workspace {
  display: grid;
  gap: 18px;
}
.official-lni-layout {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}
.official-lni-nav {
  position: sticky;
  top: 0;
  min-width: 0;
}
.navigator-row.cac-subtab {
  min-height: 44px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  padding: 10px 12px;
  border-radius: 0;
  border-bottom: 1px solid var(--rule);
  font-size: inherit;
}
.official-lni-main {
  min-width: 0;
}
.official-lni-panel-stack,
.official-lni-row-list {
  display: grid;
}
.official-lni-panel-stack {
  gap: 18px;
}
.official-lni-fact-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px 18px;
}
.cac-table-shell .table-wrap {
  overflow-x: auto;
}
.notice.success {
  border-color: #c7ebd2;
  background: var(--success-soft);
  color: var(--success);
}
@media (max-width: 900px) {
  .cac-mini-grid,
  .cac-recommendation-grid {
    grid-template-columns: 1fr;
  }
  .cac-bar-row,
  .cac-cost-summary {
    grid-template-columns: 1fr;
  }
  .official-lni-layout,
  .official-lni-fact-strip {
    grid-template-columns: 1fr;
  }
  .official-lni-nav {
    position: static;
  }
}
.deadline-key-date-table-head,
.deadline-key-date-row {
  display: grid;
  grid-template-columns: minmax(190px, 1.25fr) 78px minmax(220px, 1.3fr) 90px 112px;
  gap: 12px;
  align-items: center;
  min-width: 760px;
}
.deadline-key-date-table-head {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 0 8px 7px;
  background: var(--surface);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  border-bottom: 1px solid var(--rule);
}
.deadline-key-date-row {
  padding: 6px 8px;
  border-bottom: 1px solid var(--rule-soft);
}
.deadline-key-date-row:last-child {
  border-bottom: 0;
}
.deadline-key-date-row.missing {
  color: var(--text-3);
  background: var(--surface-2);
}
.deadline-key-date-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
}
.deadline-key-date-label {
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.deadline-key-date-source {
  overflow: hidden;
  color: var(--text-2);
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.deadline-authority-panel {
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.deadline-authority-head {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.deadline-authority-text {
  color: var(--text-2);
  line-height: 1.5;
}
.deadline-authority-list {
  display: grid;
  gap: 6px;
}
.deadline-authority-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}
.deadline-authority-row > div {
  min-width: 0;
}
.deadline-authority-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  margin-top: 8px;
}
.deadline-workspace-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 0;
}
.deadline-filter-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.deadline-group {
  margin: 12px 0;
}
.deadline-group + .deadline-group {
  border-top: 1px solid var(--rule-soft);
  padding-top: 12px;
}
.deadline-group-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 4px;
  font-weight: 600;
  color: var(--text);
}
.deadline-group-label {
  flex-shrink: 0;
}
.deadline-scope-filter {
  display: flex;
  gap: 10px;
  align-items: center;
  max-width: 470px;
}
.deadline-scope-filter > span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}
.authority-register,
.deadline-gap-list {
  display: grid;
  gap: 10px;
}
.deadline-gap-row {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}
.authority-register-row {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(280px, 1.1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}
.authority-register-row.inactive {
  color: var(--text-3);
  background: var(--surface-2);
}
.authority-register-toggle {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  min-width: 0;
  cursor: pointer;
}
.authority-register-toggle input {
  margin-top: 3px;
}
.authority-register-toggle span {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.authority-register-toggle small {
  overflow: hidden;
  color: var(--text-2);
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.authority-register-actions {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
}
.deadline-gap-row {
  grid-template-columns: minmax(260px, 0.9fr) minmax(280px, 1.2fr) auto;
  align-items: center;
}
.deadline-gap-title {
  color: var(--text);
  font-weight: 600;
}
.deadline-gap-items {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.legal-clock-gap {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-control);
  background: var(--surface-2);
  color: var(--text);
  text-align: left;
}
.legal-clock-gap {
  display: flex;
  align-items: center;
  gap: 6px;
  border-color: var(--critical-border);
  color: var(--critical);
}
.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background: var(--bg);
}

.auth-panel {
  width: min(100%, 360px);
  display: grid;
  gap: 18px;
  padding: 26px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-lg);
}

.auth-panel h1 {
  margin: 0;
  font-size: 26px;
  line-height: 1.1;
  letter-spacing: 0;
}

.auth-form {
  display: grid;
  gap: 12px;
}

.auth-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
}

.auth-form input {
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  font: inherit;
}

.auth-form input:focus {
  outline: 2px solid color-mix(in srgb, var(--accent) 28%, transparent);
  border-color: var(--accent);
}

.auth-error {
  padding: 8px 10px;
  border: 1px solid var(--danger-border, #f0b8b8);
  border-radius: var(--radius);
  background: var(--danger-bg, #fff4f4);
  color: var(--danger, #a12b2b);
  font-size: 13px;
}
.auth-notice {
  padding: 8px 10px;
  border: 1px solid var(--rule-firm);
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 13px;
  overflow-wrap: anywhere;
}
@media (max-width: 560px) {
  .deadline-authority-add {
    grid-template-columns: 1fr;
  }
  .deadline-workspace-head {
    align-items: stretch;
    flex-direction: column;
  }
  .deadline-scope-filter,
  .authority-register-row,
  .deadline-gap-row {
    grid-template-columns: 1fr;
  }
}
.knowledge-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
  flex: 1;
  min-height: 0;
  margin-top: 0;
  overflow: hidden;
}
.knowledge-table-panel {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}
.app-page-body .knowledge-table-wrap {
  overflow: auto;
  flex: 1;
  min-height: 0;
}
.knowledge-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}
.knowledge-table th,
.knowledge-table td {
  padding: 8px 12px;
  font-size: 12.5px;
  vertical-align: middle;
}
.knowledge-table th:nth-child(1),
.knowledge-table td:nth-child(1) {
  width: 30%;
}
.knowledge-table th:nth-child(2),
.knowledge-table td:nth-child(2) {
  width: 11%;
  overflow-wrap: anywhere;
}
.knowledge-table th:nth-child(3),
.knowledge-table td:nth-child(3) {
  width: 17%;
}
.knowledge-table th:nth-child(4),
.knowledge-table td:nth-child(4) {
  width: 16%;
}
.knowledge-table th:nth-child(5),
.knowledge-table td:nth-child(5) {
  width: 16%;
}
.knowledge-table th:nth-child(6),
.knowledge-table td:nth-child(6) {
  width: 10%;
}
.knowledge-table tbody tr.active td {
  background: var(--surface-2);
}
.knowledge-table tbody tr:focus-visible td {
  outline: 2px solid var(--focus);
  outline-offset: -2px;
}
.knowledge-table-title {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  overflow-wrap: anywhere;
  color: var(--text);
  font-weight: 550;
  line-height: 1.25;
}
.knowledge-table-seed-chip {
  flex: 0 0 auto;
}
.knowledge-table-sub {
  margin-top: 3px;
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
}
.knowledge-table td:nth-child(2) .knowledge-table-sub {
  overflow-wrap: anywhere;
}
.knowledge-table-date {
  white-space: nowrap;
}
.knowledge-preview {
  min-width: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: none;
  background: transparent;
  box-shadow: inset 1px 0 0 var(--rule);
}
.knowledge-preview.empty {
  min-height: 360px;
  justify-content: center;
}
.knowledge-preview-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px 4px;
}
.knowledge-preview-head h3 {
  margin: 3px 0 0;
  font-size: 16px;
  line-height: 1.25;
  color: var(--text);
}
.knowledge-preview-eyebrow {
  color: var(--text-3);
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
}
.knowledge-source-disabled,
.knowledge-source-disabled:hover {
  color: #A3A3A3;
  background: transparent;
  opacity: 1;
  box-shadow: none;
  text-decoration: none;
}
.knowledge-preview-actions {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 6px;
  flex-shrink: 0;
}
.knowledge-preview-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  padding: 4px 18px 10px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.knowledge-preview-scroll {
  flex: 1;
  min-height: 0;
  overflow: auto;
}
.knowledge-preview-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  padding: 16px 18px 18px;
}
.knowledge-preview-document {
  display: grid;
  gap: 18px;
  min-width: 0;
}
.knowledge-preview-section {
  scroll-margin-top: 18px;
  display: grid;
  gap: 8px;
}
.knowledge-preview-section h4 {
  margin: 0;
  font-size: 12px;
  line-height: 1.3;
  color: var(--text);
}
.knowledge-preview-section p,
.knowledge-preview-section ul {
  margin: 0;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.knowledge-preview-section ul {
  padding-left: 18px;
}
.knowledge-preview-prose {
  white-space: pre-wrap;
}
.knowledge-preview-outline {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 20;
  min-width: 156px;
  display: grid;
  gap: 2px;
  padding: 4px;
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-pop), var(--ring-light);
}
.knowledge-preview-outline a {
  display: block;
  padding: 5px 7px;
  border-radius: var(--radius-control);
  color: var(--text-3);
  font-size: 12px;
  text-decoration: none;
}
.knowledge-preview-outline a:hover,
.knowledge-preview-outline a:focus-visible {
  background: var(--hover-2);
  color: var(--text);
  outline: none;
}
.knowledge-preview-review-actions {
  justify-content: flex-start;
}
.knowledge-large-modal-body {
  padding: 0;
  min-height: 0;
}
.knowledge-preview-large {
  position: static;
  flex: 1;
  width: 100%;
  height: 100%;
  max-height: none;
  min-height: 0;
  box-shadow: none;
  background: var(--bg);
}
.knowledge-preview-large .knowledge-preview-head,
.knowledge-preview-large .knowledge-preview-meta {
  padding-left: 28px;
  padding-right: 28px;
}
.knowledge-preview-large .knowledge-preview-scroll {
  flex: 1;
}
.knowledge-preview-large .knowledge-preview-layout {
  width: 100%;
  margin: 0 auto;
  padding: 24px 28px 32px;
}
.knowledge-detail-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  box-shadow: inset 0 1px 0 var(--rule);
}
.knowledge-detail-table th,
.knowledge-detail-table td {
  padding: 5px 8px;
  text-align: left;
  vertical-align: top;
  line-height: 1.35;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.knowledge-detail-table th {
  width: 24%;
  color: var(--text-3);
  font-weight: 500;
}
.knowledge-detail-table td {
  color: var(--text);
  font-weight: 550;
}
.knowledge-date-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-left: calc(24% + 8px);
  padding-top: 2px;
}
.knowledge-date-strip div {
  min-width: 0;
}
.knowledge-date-strip span,
.knowledge-date-strip strong {
  display: block;
  overflow-wrap: anywhere;
}
.knowledge-date-strip span {
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
}
.knowledge-date-strip strong {
  margin-top: 2px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 550;
  line-height: 1.35;
}
@media (max-width: 1180px) {
  .knowledge-workspace {
    grid-template-columns: 1fr;
  }
  .knowledge-preview {
    position: static;
    max-height: none;
    box-shadow: inset 0 1px 0 var(--rule);
  }
}
@media (max-width: 760px) {
  .knowledge-preview-head {
    flex-direction: column;
  }
  .knowledge-date-strip {
    grid-template-columns: 1fr;
    margin-left: 0;
  }
}
.knowledge-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0 54px;
  border-top: 1px solid var(--rule);
}
.knowledge-pagination-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 6px;
  padding-right: 130px;
}
@media (max-width: 760px) {
  .knowledge-pagination {
    align-items: flex-start;
    flex-direction: column;
  }
  .knowledge-pagination-actions {
    justify-content: flex-start;
    padding-right: 0;
  }
}
.knowledge-viewer {
  display: grid;
  gap: 18px;
}
.table-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0 54px;
  border-top: 1px solid var(--rule);
}
.table-wrap + .table-pagination,
.card-body.tight > .table-pagination {
  margin-top: 0;
}
.table-pagination-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 6px;
  padding-right: 130px;
}
.table-pagination-gap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  color: var(--text-3);
  font-weight: 700;
}
@media (max-width: 760px) {
  .table-pagination {
    align-items: flex-start;
    flex-direction: column;
  }
  .table-pagination-actions {
    justify-content: flex-start;
    padding-right: 0;
  }
}
.knowledge-viewer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.knowledge-viewer-section {
  display: grid;
  gap: 8px;
}
.knowledge-viewer-section h3 {
  margin: 0;
  font-size: 13px;
  line-height: 1.3;
  font-weight: 600;
  color: var(--text);
}
.knowledge-viewer-section p,
.knowledge-viewer-section ul {
  margin: 0;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.knowledge-viewer-section ul {
  padding-left: 18px;
}
.report-export-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.report-freshness-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 26px;
  margin-bottom: 10px;
  padding: 3px 8px;
  border-radius: var(--radius-pill);
  box-shadow: var(--ring-light);
  color: var(--text-2);
  font-size: 12px;
}
.report-freshness-pill button {
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-weight: 600;
}
.report-freshness-pill button:not(:disabled) {
  cursor: pointer;
}
.report-freshness-pill button:disabled {
  color: var(--text-3);
}
.report-export-option {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 10px 12px;
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
  background: var(--surface);
  text-align: left;
}
.report-export-option:hover,
.report-export-option:focus-visible {
  background: var(--hover);
}
.report-export-option.selected {
  box-shadow: inset 0 0 0 1px var(--text);
}
.report-export-option-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.report-export-option-count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
}
.reports-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.reports-column {
  display: grid;
  align-content: start;
  gap: 24px;
  min-width: 0;
}
.knowledge-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.knowledge-detail-grid > div {
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-control);
  background: var(--surface-2);
}
.knowledge-detail-grid span {
  display: block;
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.3;
}
.knowledge-detail-grid strong {
  display: block;
  margin-top: 3px;
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.drawer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
}
.claim-tab-scaffold {
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--canvas-bg);
}
.claim-tab-header {
  position: relative;
  z-index: 30;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  padding: var(--claim-tab-header-padding);
  background: var(--canvas-bg);
}
.claim-tab-heading {
  min-width: 0;
}
.claim-tab-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.claim-tab-title {
  margin: 0;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0;
}
.claim-tab-subtitle {
  margin-top: 5px;
  color: var(--text-3);
  font-size: 13px;
  line-height: 1.4;
}
.claim-tab-actions {
  position: relative;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
}
.claim-header-actions-cluster {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
  min-width: 0;
}
.claim-actions-dropdown {
  position: relative;
}
.btn.claim-actions-trigger,
.btn.claim-actions-trigger[aria-expanded="true"] {
  color: var(--text-2);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}
.btn.claim-actions-trigger:hover,
.btn.claim-actions-trigger[aria-expanded="true"]:hover {
  color: var(--text);
  background: var(--surface-3);
  box-shadow: var(--ring);
}
.claim-actions-trigger .claim-actions-trigger-chevron {
  transition: transform 150ms ease;
  transform-origin: 50% 50%;
}
.claim-actions-trigger.is-open .claim-actions-trigger-chevron {
  transform: rotate(-180deg);
}
.claim-actions-menu {
  position: fixed;
  top: var(--claim-actions-menu-top, auto);
  width: 252px;
  max-height: var(--claim-actions-menu-max-height, calc(100vh - 96px));
  overflow: auto;
  transform-origin: top right;
  backface-visibility: hidden;
  will-change: transform, opacity;
  z-index: 240;
  animation: claim-actions-menu-unfurl 210ms cubic-bezier(0.32, 0, 0.15, 1);
}
.menu-popover.align-right.claim-actions-menu {
  right: var(--claim-actions-menu-right, 8px);
}
.claim-actions-menu-label {
  padding: 5px 8px 3px;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.claim-actions-menu-item:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}
.claim-actions-menu-copy {
  display: grid;
  gap: 1px;
  min-width: 0;
}
.claim-actions-menu-sub {
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.3;
}
@keyframes claim-actions-menu-unfurl {
  0% {
    opacity: 0;
    transform: translateY(-7px) rotateX(-22deg) scaleY(0.82);
  }
  100% {
    opacity: 1;
    transform: translateY(0) rotateX(0) scaleY(1);
  }
}
@keyframes claim-facts-panel-unfurl {
  0% {
    opacity: 0;
    transform: rotateX(-18deg) scaleY(0.86);
  }
  100% {
    opacity: 1;
    transform: rotateX(0) scaleY(1);
  }
}
@keyframes claim-issue-scope-menu-unfurl {
  0% {
    opacity: 0;
    transform: translateX(-50%) rotateX(-18deg) scaleY(0.86);
  }
  100% {
    opacity: 1;
    transform: translateX(-50%) rotateX(0) scaleY(1);
  }
}
@media (prefers-reduced-motion: reduce) {
  .claim-actions-trigger svg,
  .claim-actions-menu,
  .claim-issue-scope-menu {
    animation: none;
    transition: none;
  }
}
.claim-tab-body {
  padding: var(--space-widget);
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: auto;
}
.claim-tab-body:has(.table-shell-with-rail),
.claim-tab-body:has(.data-list-card),
.claim-tab-body:has(.notes-thread-surface),
.claim-tab-body:has(.claim-update-list) {
  overflow: hidden;
}
.claim-tab-body > .hub,
.claim-tab-body > .lx-28v4rf,
.claim-tab-body > .lx-v3wu3v,
.claim-tab-body > .lx-10gs2lv {
  padding: 0;
}
.claim-tab-body > .hub {
  gap: var(--widget-gap);
}
.claim-tab-body > .lx-28v4rf,
.claim-tab-body > .lx-v3wu3v {
  display: flex;
  flex-direction: column;
  gap: 18px;
  flex: 1;
  min-height: 0;
}
.claim-tab-body > .notes-tab-wrap {
  max-width: none;
  width: 100%;
}
.claim-tab-body .table-wrap {
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}
.claim-activity-filter-toolbar {
  padding: 0 0 12px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.claim-tab-body .table-wrap .empty-state {
  border-top: 1px solid var(--rule-soft);
}
.claim-tab-body .card {
  border-radius: 0;
}
.claim-tab-scaffold-list .claim-tab-body > .lx-28v4rf > .card,
.claim-tab-scaffold-timeline .claim-tab-body > .lx-28v4rf > .card {
  border-radius: var(--radius);
}
.claim-tab-scaffold-worksheet .claim-tab-body {
  padding-top: 18px;
}
.claim-info-link-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 10px 0;
  border: 0;
  border-bottom: 1px solid var(--rule-soft);
  background: transparent;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}
.claim-info-link-row:last-child { border-bottom: 0; }
.claim-info-link-row.disabled {
  cursor: not-allowed;
  opacity: 0.65;
}
.manual-entry-summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.document-context-action-row,
.apf-action-row {
  position: relative;
  z-index: 3;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  pointer-events: auto;
}
.document-context-action-row > .btn,
.apf-action-row > .btn {
  position: relative;
  z-index: 4;
  pointer-events: auto;
}
.document-file-action-panel,
.document-version-panel {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
  padding: 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.document-version-list {
  display: grid;
  gap: 6px;
}
.document-version-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  background: var(--surface);
  font-size: 12px;
}
.document-version-row.active {
  border-color: var(--rule-firm);
  box-shadow: inset 2px 0 0 var(--accent);
}
.document-version-row span {
  color: var(--text-2);
  font-weight: 700;
}
.document-version-row strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}
.document-version-row em {
  color: var(--text-2);
  font-style: normal;
  white-space: nowrap;
}
.document-ai-card {
  margin-bottom: 14px;
}
.document-ai-card .card-head {
  align-items: center;
}
.document-ai-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.document-ai-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.document-ai-summary {
  margin: 0;
  color: var(--text);
  line-height: 1.45;
}

.documents-filtered-table {
  table-layout: fixed;
  min-width: 1380px;
}
.documents-filtered-table tbody tr {
  position: relative;
}
.documents-filtered-table tbody tr:has(.document-list-title-cell:hover),
.documents-filtered-table tbody tr:has(.document-title-hover:hover),
.documents-filtered-table tbody tr:has(.document-title-hover:focus-within) {
  z-index: 360;
}
.documents-filtered-table col.document-col-title { width: 17%; }
.documents-filtered-table col.document-col-summary { width: 16.25%; }
.documents-filtered-table col.document-col-type { width: 9.25%; }
.documents-filtered-table col.document-col-category { width: 6.25%; }
.documents-filtered-table col.document-col-date { width: 6.5%; }
.documents-filtered-table col.document-col-visit { width: 6.5%; }
.documents-filtered-table col.document-col-issues { width: 10.5%; }
.documents-filtered-table col.document-col-last-edit { width: 6.5%; }
.documents-filtered-table col.document-col-tags { width: 8%; }
.documents-filtered-table col.document-col-action { width: 2.5%; }
.documents-filtered-table col.document-col-status { width: 5%; }
.documents-filtered-table col.document-col-edit { width: 5%; }
.document-list-title-cell {
  min-width: 0;
  position: relative;
}
.document-list-title-cell:hover,
.document-list-title-cell:has(.document-title-hover:hover),
.document-list-title-cell:has(.document-title-hover:focus-within) {
  z-index: 370;
}
.document-list-title-text {
  display: inline;
  overflow: hidden;
}
.document-title-hover {
  position: relative;
  display: inline;
  max-width: 100%;
  min-width: 0;
}
.document-hidden-facts-trigger {
  display: none;
  vertical-align: -1px;
  margin-left: 4px;
  color: var(--text-3);
  line-height: 1;
}
.document-hidden-facts-popover {
  pointer-events: none;
  position: absolute;
  z-index: 380;
  left: 0;
  top: calc(100% + 8px);
  display: flex;
  flex-direction: column;
  width: min(420px, calc(100vw - 32px));
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 0;
  background: var(--bg);
  color: var(--text);
  box-shadow: var(--shadow-pop);
  opacity: 0;
  transform: translateY(-3px);
  transition: opacity 160ms ease, transform 160ms ease, visibility 160ms linear;
  visibility: hidden;
}
.documents-filtered-table tbody tr:nth-last-child(-n + 2) .document-hidden-facts-popover {
  top: auto;
  bottom: calc(100% + 8px);
  transform: translateY(3px);
}
.document-list-title-cell:hover .document-hidden-facts-popover,
.document-list-title-cell:focus-within .document-hidden-facts-popover,
.document-title-hover:hover .document-hidden-facts-popover,
.document-title-hover:focus-within .document-hidden-facts-popover {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}
.document-hidden-facts-title {
  display: block;
  min-height: 38px;
  padding: 8px 10px 7px 12px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.25;
}
.document-hidden-facts-row {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 10px;
  min-height: 32px;
  padding: 7px 12px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.document-hidden-facts-row + .document-hidden-facts-row {
  border-top: 1px solid var(--border);
}
.document-hidden-facts-row > span:first-child {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
}
.document-list-summary-cell {
  min-width: 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.document-list-summary-text {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}
.document-list-chip-cell {
  min-width: 0;
}
.document-table-meta-label {
  display: inline;
  color: var(--text);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.25;
}
.document-issue-label {
  color: var(--text-2);
}
.document-list-date-cell {
  min-width: 0;
  white-space: nowrap;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.25;
}
.documents-filtered-table td.document-list-date-cell {
  font-size: 12px;
  line-height: 1.25;
}
.document-list-visit-cell {
  min-width: 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.document-list-visit-cell > div,
.document-list-visit-cell > span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.document-list-issues-cell {
  min-width: 0;
}
.document-issue-chip-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
  min-width: 0;
  line-height: 1.25;
}
.document-unlinked-issue {
  display: inline-block;
  font-size: 12px;
  line-height: 1.3;
}
.documents-filtered-table .document-unlinked-issue {
  font-size: 12px;
}
.document-tags-cell {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  align-items: center;
  min-width: 0;
  overflow: hidden;
}
.document-tags-cell .chip {
  max-width: 100%;
  flex: 0 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}
.document-alert-heading,
.document-alert-cell {
  text-align: center;
}
.document-edit-heading,
.document-status-cell {
  text-align: left;
}
.document-edit-cell {
  text-align: left;
}
.documents-filtered-table td.document-alert-cell {
  padding-left: 8px;
  padding-right: 8px;
}
.document-tags-table-cell,
.documents-filtered-table td.lx-su2aud,
.documents-filtered-table td:last-child {
  min-width: 0;
}
.document-alert-button {
  width: 28px;
  height: 28px;
  min-width: 0;
  padding: 0;
  justify-content: center;
}
.document-edit-action-wrap {
  display: inline-flex;
}
.document-edit-button {
  width: 28px;
  height: 28px;
  min-width: 0;
  padding: 0;
  justify-content: center;
}
.document-edit-button:disabled {
  color: var(--text-3);
  cursor: not-allowed;
  opacity: 0.55;
}
.document-status-chip {
  max-width: 100%;
  padding-left: 8px;
  padding-right: 8px;
  white-space: nowrap;
}
.document-date-filter {
  width: 150px;
}
.document-date-filter-field {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text-2);
  font-size: 12px;
  white-space: nowrap;
}
@media (max-width: 2047px) {
  .documents-filtered-table {
    min-width: 0;
  }
  .documents-filtered-table col.document-col-title { width: 18.5%; }
  .documents-filtered-table col.document-col-summary { width: 18.5%; }
  .documents-filtered-table col.document-col-type { width: 10%; }
  .documents-filtered-table col.document-col-category { width: 7%; }
  .documents-filtered-table col.document-col-date { width: 7%; }
  .documents-filtered-table col.document-col-visit { width: 7%; }
  .documents-filtered-table col.document-col-issues { width: 12.5%; }
  .documents-filtered-table col.document-col-last-edit { width: 0; }
  .documents-filtered-table col.document-col-tags { width: 9.5%; }
  .documents-filtered-table col.document-col-action { width: 3%; }
  .documents-filtered-table col.document-col-status { width: 5.5%; }
  .documents-filtered-table col.document-col-edit { width: 4%; }
  .documents-filtered-table col.document-col-last-edit,
  .documents-filtered-table .document-edited-column {
    visibility: collapse;
  }
  .documents-filtered-table .document-edited-column {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0;
    line-height: 0;
  }
  .documents-filtered-table .document-edited-column > * {
    display: none;
  }
  .document-hidden-facts-trigger {
    display: inline-flex;
  }
}

@media (max-width: 1999px) {
  .documents-filtered-table col.document-col-title { width: 19%; }
  .documents-filtered-table col.document-col-summary { width: 20.5%; }
  .documents-filtered-table col.document-col-type { width: 11%; }
  .documents-filtered-table col.document-col-category { width: 8%; }
  .documents-filtered-table col.document-col-date { width: 0; }
  .documents-filtered-table col.document-col-visit { width: 7%; }
  .documents-filtered-table col.document-col-issues { width: 13.5%; }
  .documents-filtered-table col.document-col-tags { width: 10%; }
  .documents-filtered-table col.document-col-action { width: 0; }
  .documents-filtered-table col.document-col-status { width: 6.5%; }
  .documents-filtered-table col.document-col-edit { width: 5%; }
  .documents-filtered-table col.document-col-date,
  .documents-filtered-table .document-date-column {
    visibility: collapse;
  }
  .documents-filtered-table .document-date-column {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0;
    line-height: 0;
  }
  .documents-filtered-table .document-date-column > * {
    display: none;
  }
  .documents-filtered-table col.document-col-action,
  .documents-filtered-table .document-alert-heading,
  .documents-filtered-table .document-alert-cell {
    visibility: collapse;
  }
  .documents-filtered-table .document-alert-heading,
  .documents-filtered-table .document-alert-cell {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0;
    line-height: 0;
  }
  .documents-filtered-table .document-alert-heading > *,
  .documents-filtered-table .document-alert-cell > * {
    display: none;
  }
}

@media (max-width: 1679px) {
  .documents-filtered-table col.document-col-title { width: 25%; }
  .documents-filtered-table col.document-col-summary { width: 0; }
  .documents-filtered-table col.document-col-type { width: 12.5%; }
  .documents-filtered-table col.document-col-category { width: 9%; }
  .documents-filtered-table col.document-col-visit { width: 8.5%; }
  .documents-filtered-table col.document-col-issues { width: 17%; }
  .documents-filtered-table col.document-col-tags { width: 12%; }
  .documents-filtered-table col.document-col-action { width: 0; }
  .documents-filtered-table col.document-col-status { width: 9.5%; }
  .documents-filtered-table col.document-col-edit { width: 6.5%; }
  .documents-filtered-table col.document-col-summary,
  .documents-filtered-table .document-summary-column {
    visibility: collapse;
  }
  .documents-filtered-table .document-summary-column {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0;
    line-height: 0;
  }
  .documents-filtered-table .document-summary-column > * {
    display: none;
  }
}

@media (max-width: 1500px) {
  .documents-filtered-table col.document-col-title { width: 25%; }
  .documents-filtered-table col.document-col-type { width: 12.5%; }
  .documents-filtered-table col.document-col-category { width: 9.5%; }
  .documents-filtered-table col.document-col-visit { width: 8%; }
  .documents-filtered-table col.document-col-issues { width: 18%; }
  .documents-filtered-table col.document-col-tags { width: 12%; }
  .documents-filtered-table col.document-col-action { width: 0; }
  .documents-filtered-table col.document-col-status { width: 8%; }
  .documents-filtered-table col.document-col-edit { width: 7%; }
  .documents-filtered-table col.document-col-action,
  .documents-filtered-table .document-alert-heading,
  .documents-filtered-table .document-alert-cell {
    visibility: collapse;
  }
  .documents-filtered-table .document-alert-heading,
  .documents-filtered-table .document-alert-cell {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0;
    line-height: 0;
  }
  .documents-filtered-table .document-alert-heading > *,
  .documents-filtered-table .document-alert-cell > * {
    display: none;
  }
}

@media (max-width: 1400px) {
  .documents-filtered-table col.document-col-title { width: 34%; }
  .documents-filtered-table col.document-col-type { width: 18%; }
  .documents-filtered-table col.document-col-category { width: 0; }
  .documents-filtered-table col.document-col-visit { width: 0; }
  .documents-filtered-table col.document-col-issues { width: 25%; }
  .documents-filtered-table col.document-col-tags { width: 0; }
  .documents-filtered-table col.document-col-status { width: 13%; }
  .documents-filtered-table col.document-col-edit { width: 10%; }
  .documents-filtered-table col.document-col-category,
  .documents-filtered-table col.document-col-visit,
  .documents-filtered-table col.document-col-tags,
  .documents-filtered-table .document-category-column,
  .documents-filtered-table .document-visit-column,
  .documents-filtered-table .document-tags-column {
    visibility: collapse;
  }
  .documents-filtered-table .document-category-column,
  .documents-filtered-table .document-visit-column,
  .documents-filtered-table .document-tags-column {
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0;
    line-height: 0;
  }
  .documents-filtered-table .document-category-column > *,
  .documents-filtered-table .document-visit-column > *,
  .documents-filtered-table .document-tags-column > * {
    display: none;
  }
}
.document-ai-keyterms {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.document-ai-term {
  gap: 6px;
}
.document-ai-term strong {
  color: var(--text);
}
.document-ai-structured {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  overflow: hidden;
}
.document-ai-structured-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  padding: 10px 12px;
  border-right: 1px solid var(--rule-soft);
  border-bottom: 1px solid var(--rule-soft);
}
.document-ai-structured-row:nth-child(2n) {
  border-right: 0;
}
.document-ai-structured-row span {
  color: var(--text-3);
  font-size: 11px;
  text-transform: uppercase;
}
.document-ai-structured-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  overflow-wrap: anywhere;
}
.document-ai-markdown {
  min-height: 180px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
  line-height: 1.45;
}
.document-review-modal {
  min-width: min(980px, calc(100vw - 32px));
}
.document-review-modal-body {
  padding: 0;
  overflow: hidden;
}
.document-review-workspace {
  display: grid;
  grid-template-columns: minmax(460px, 1.08fr) minmax(420px, 0.92fr);
  min-height: 0;
  height: 100%;
}
.document-review-preview-pane {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  border-right: 1px solid var(--rule);
  background: var(--surface-2);
}
.document-review-preview-body {
  min-height: 0;
  flex: 1;
  overflow: auto;
  padding: 12px;
}
.document-review-preview-body .hub-pdf-viewer {
  min-height: 100%;
  max-height: none;
}
.document-review-preview-body .document-review-page {
  min-height: 100%;
}
.document-review-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.document-summary-tags-card {
  align-content: start;
  gap: 8px;
  padding-block: 10px;
}
.document-review-tags .tag-bubble {
  min-height: 22px;
  padding: 3px 8px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-2);
  font-size: 11px;
  line-height: 1.2;
}
.document-review-ai-message,
.document-ai-empty-state {
  display: grid;
  gap: 8px;
}
.document-review-ai-message {
  padding: 10px 12px;
  border: 1px solid var(--warn);
  border-radius: var(--radius-lg);
  background: var(--warn-soft);
  color: var(--warn);
  font-size: 12px;
  line-height: 1.45;
}
.document-review-detail-card,
.document-review-deadline-card {
  display: grid;
  gap: 8px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 12px;
}
.document-review-detail-row {
  display: grid;
  grid-template-columns: minmax(82px, 0.45fr) minmax(0, 1fr);
  gap: 10px;
  align-items: baseline;
}
.document-review-detail-row span,
.document-review-deadline-card span {
  color: var(--text-3);
  font-size: 12px;
}
.document-review-detail-row strong,
.document-review-deadline-card strong {
  min-width: 0;
  color: var(--text);
  font-size: 13px;
  font-weight: 650;
  overflow-wrap: anywhere;
}
.document-review-deadline-card {
  border-color: rgba(156, 110, 31, 0.24);
  background: var(--warn-soft);
}
.document-review-update-card,
.claim-update-entry-card {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(29, 113, 184, 0.24);
  border-radius: var(--radius-lg);
  background: var(--info-soft);
  padding: 12px;
}
.claim-update-entry-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px 16px;
  border-color: var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.document-review-update-card strong,
.claim-update-entry-card strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}
.document-review-update-card span {
  display: block;
  color: var(--text-2);
  font-size: 12px;
  margin-top: 2px;
}
.claim-update-entry-card p {
  margin: 4px 0 0;
}
.document-review-update-card .btn {
  justify-content: center;
}
.claim-update-entry-card .btn {
  justify-self: end;
  width: auto;
  min-width: max-content;
}
.document-review-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.document-review-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: var(--surface);
  overflow: hidden;
}
.document-review-tabs {
  padding: 0 12px;
  border-bottom: 1px solid var(--rule-soft);
}
.document-review-section {
  display: grid;
  gap: 16px;
  padding: 16px;
  overflow: auto;
}
.document-review-main > .document-review-section {
  min-height: 0;
  flex: 1;
}
.document-review-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.document-summary-stack {
  display: grid;
  align-content: start;
  gap: 12px;
}
.document-summary-details-card {
  gap: 10px;
}
.document-summary-detail-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 18px;
}
.document-summary-primary,
.document-summary-extract-section {
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  padding: 12px;
}
.document-extract-preview {
  max-height: 320px;
  overflow: auto;
}
.document-summary-empty {
  color: var(--text-3);
  font-size: 12px;
}
.document-extract-preview p {
  margin: 0 0 10px;
  color: var(--text-2);
  line-height: 1.45;
}
.document-extract-preview p:last-child {
  margin-bottom: 0;
}
.evidence-summary-textarea {
  min-height: 180px;
}
.document-review-page {
  margin: 0;
}
.claim-update-review-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}
.claim-update-review-head p {
  margin: 4px 0 0;
}
.claim-update-list {
  display: grid;
  gap: 10px;
}
.claim-updates-workspace {
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
  min-height: 0;
}
.cac-update-source-body {
  display: grid;
  gap: 14px;
}
.cac-status-field {
  max-width: 520px;
}
.cac-status-field .cac-status-control {
  margin-top: 6px;
}
.cac-update-message-stack,
.cac-imported-facts-block {
  display: grid;
  gap: 8px;
}
.cac-imported-facts-block .table {
  margin: 0;
}
.claim-update-queue-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.claim-update-queue-summary > div {
  display: grid;
  gap: 4px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 10px 12px;
}
.claim-update-queue-summary span {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
  overflow-wrap: anywhere;
}
.claim-update-queue-summary strong {
  color: var(--text);
  font-size: 20px;
  line-height: 1;
}
.document-view-tabs {
  padding-inline: 3px;
}
.claim-alert-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
}
.claim-alert-summary-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.claim-alert-summary-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-weight: 700;
  color: var(--text);
}
.claim-alert-summary-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
}
.claim-alert-rule-chip {
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 760px) {
  .claim-alert-summary {
    align-items: stretch;
    flex-direction: column;
  }
  .claim-alert-summary-actions {
    justify-content: flex-start;
  }
}
.dynamic-fact-workspace {
  display: grid;
  gap: 8px;
  padding: 16px 24px 24px;
  min-width: 0;
}
.dynamic-fact-main {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.dynamic-fact-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.dynamic-fact-toolbar-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.dynamic-fact-template-tabs {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 4px 0 6px;
}
.dynamic-fact-template-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--bg);
  color: var(--text);
  padding: 6px 9px;
  font: inherit;
  font-size: 12px;
  white-space: nowrap;
  cursor: pointer;
}
.dynamic-fact-template-tab.active {
  border-color: var(--text);
  background: var(--text);
  color: var(--bg);
}
.dynamic-fact-template-tab em {
  min-width: 18px;
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-2);
  font-style: normal;
  text-align: center;
  padding: 1px 5px;
}
.dynamic-fact-template-tab.active em {
  background: rgba(255, 255, 255, 0.18);
  color: inherit;
}
.dynamic-fact-quality-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(104px, 1fr));
  gap: 6px;
}
.dynamic-fact-quality-strip button {
  min-width: 0;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  padding: 8px 10px;
  font: inherit;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 3px;
}
.dynamic-fact-quality-strip button:hover,
.dynamic-fact-quality-strip button.active {
  border-color: var(--focus);
  box-shadow: 0 0 0 2px var(--focus);
}
.dynamic-fact-quality-strip span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.15;
  text-transform: uppercase;
}
.dynamic-fact-quality-strip strong {
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.dynamic-fact-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--rule);
  background: var(--surface);
  padding: 8px;
}
.dynamic-fact-control,
.dynamic-fact-column-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  color: var(--text-2);
  font-size: 12px;
}
.dynamic-fact-control > span:first-child {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}
.dynamic-fact-control .select {
  min-height: 30px;
  width: auto;
  min-width: 128px;
}
.dynamic-fact-check {
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  padding: 0 8px;
}
.dynamic-fact-column-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 8px;
  min-width: min(100%, 360px);
  margin-left: auto;
}
.dynamic-fact-column-toggle {
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-pill);
  padding: 0 8px;
  background: var(--surface-2);
}
.dynamic-fact-formula-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  border: 1px solid var(--rule);
  background: var(--surface);
  padding: 5px 8px;
  font-size: 12.5px;
  overflow-x: auto;
  white-space: nowrap;
}
.dynamic-fact-formula-bar > span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
}
.dynamic-fact-formula-bar b {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
}
.claim-tab-body .dynamic-fact-table-shell > .dynamic-fact-table-wrap,
.dynamic-fact-table-shell > .dynamic-fact-table-wrap {
  flex: 1;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow: auto;
  scrollbar-gutter: stable;
}
.claim-tab-body > .lx-28v4rf:has(.dynamic-fact-table-shell),
.dynamic-fact-table-shell {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}
.dynamic-fact-opened {
  border: 1px solid color-mix(in srgb, var(--success) 34%, var(--rule));
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--success) 8%, var(--surface));
  color: var(--success);
  padding: 2px 7px;
  font-weight: 700;
}
.dynamic-fact-name {
  min-width: 140px;
  font-weight: 700;
}
.dynamic-fact-value {
  min-width: 140px;
  border-left: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  padding-inline: 10px;
  font-weight: 650;
}
.dynamic-fact-source {
  max-width: 420px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dynamic-fact-table th,
.dynamic-fact-table td {
  vertical-align: top;
}
.dynamic-fact-table {
  table-layout: fixed;
  width: max-content;
  min-width: 100%;
}
.dynamic-fact-table .dynamic-fact-doc-col {
  width: 300px;
}
.dynamic-fact-table .dynamic-fact-value-col {
  width: 168px;
}
.dynamic-fact-table .dynamic-fact-review-col {
  width: 118px;
}
.dynamic-fact-table th {
  white-space: normal;
}
.dynamic-fact-table .dynamic-fact-group-row th {
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  line-height: 1.15;
  text-transform: uppercase;
}
.dynamic-fact-table tbody tr.is-selected > td {
  background: color-mix(in srgb, var(--focus) 5%, var(--surface));
}
.dynamic-fact-table tbody tr.has-open-source > td:first-child {
  box-shadow: inset 3px 0 0 var(--success);
}
.dynamic-fact-th-label,
.dynamic-fact-th-meta {
  display: block;
  min-width: 0;
}
.dynamic-fact-th-label {
  color: var(--text);
  font-weight: 700;
  line-height: 1.2;
  overflow-wrap: anywhere;
}
.dynamic-fact-th-meta {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 650;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: 0;
}
.dynamic-fact-table-compact th,
.dynamic-fact-table-compact td {
  padding-inline: 7px;
}
.dynamic-fact-table-compact .dynamic-fact-value-col {
  width: 146px;
}
.dynamic-fact-cell {
  width: 100%;
  min-height: 28px;
  display: flex;
  align-items: flex-start;
  gap: 6px;
  justify-content: flex-start;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  padding: 5px 8px;
  font: inherit;
  font-size: 12.5px;
  text-align: left;
  overflow-wrap: anywhere;
}
.dynamic-fact-cell-value {
  min-width: 0;
  flex: 1;
}
.dynamic-fact-cell-meta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  max-width: 100%;
}
.dynamic-fact-cell em {
  flex: 0 0 auto;
  color: var(--text-3);
  font-size: 10.5px;
  font-style: normal;
  line-height: 1.4;
}
.dynamic-fact-cell:hover:not(:disabled),
.dynamic-fact-cell.active {
  border-color: var(--focus);
  box-shadow: 0 0 0 2px var(--focus);
}
.dynamic-fact-cell:disabled {
  color: var(--text-3);
  background: var(--surface-2);
}
.dynamic-fact-cell.missing {
  border-style: dashed;
  color: var(--text-3);
}
.dynamic-fact-cell.not-applicable {
  border-style: dashed;
  color: var(--text-3);
  background: color-mix(in srgb, var(--surface-2) 72%, var(--surface));
}
.dynamic-fact-cell.has-source-gap:not(.missing) {
  background: color-mix(in srgb, var(--warn) 6%, var(--surface));
}
.dynamic-fact-cell[data-status="confirmed"],
.dynamic-fact-cell[data-status="accepted"] {
  border-color: color-mix(in srgb, var(--success) 32%, var(--rule));
}
.dynamic-fact-cell[data-status="rejected"],
.dynamic-fact-cell[data-status="error"],
.dynamic-fact-cell[data-status="failed"] {
  border-color: color-mix(in srgb, var(--critical) 34%, var(--rule));
}
.dynamic-fact-cell[data-status="suggested"],
.dynamic-fact-cell[data-status="needs_review"],
.dynamic-fact-cell[data-status="needs-review"] {
  border-color: color-mix(in srgb, var(--warn) 42%, var(--rule));
}
.dynamic-fact-source-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  max-width: 92px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-2);
  padding: 1px 6px;
  font-size: 10.5px;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dynamic-fact-source-chip.is-exact {
  border-color: color-mix(in srgb, var(--success) 36%, var(--rule));
  background: color-mix(in srgb, var(--success) 9%, var(--surface));
  color: var(--success);
}
.dynamic-fact-source-chip.is-line {
  border-color: color-mix(in srgb, var(--info) 30%, var(--rule));
  background: color-mix(in srgb, var(--info) 8%, var(--surface));
  color: var(--info);
}
.dynamic-fact-source-chip.is-page {
  border-color: color-mix(in srgb, var(--warn) 38%, var(--rule));
  background: color-mix(in srgb, var(--warn) 8%, var(--surface));
  color: var(--warn);
}
.dynamic-fact-source-chip.is-missing-anchor,
.dynamic-fact-source-chip.is-missing-value {
  border-color: color-mix(in srgb, var(--critical) 30%, var(--rule));
  background: color-mix(in srgb, var(--critical) 7%, var(--surface));
  color: var(--critical);
}
.dynamic-fact-source-chip.is-not-applicable {
  border-color: var(--rule);
  background: var(--surface-2);
  color: var(--text-3);
}
@media (max-width: 960px) {
  .dynamic-fact-quality-strip {
    grid-template-columns: repeat(3, minmax(104px, 1fr));
  }
}
@media (max-width: 620px) {
  .dynamic-fact-quality-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.document-fact-review-workspace {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  min-height: 0;
}
.document-fact-source-pane,
.document-fact-list-pane {
  min-width: 0;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  overflow: hidden;
}
.document-fact-pane-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
  border-bottom: 1px solid var(--rule-soft);
  background: var(--surface-2);
}
.document-fact-pane-head strong {
  display: block;
  margin-top: 2px;
  font-size: 13px;
  overflow-wrap: anywhere;
}
.document-fact-bulk-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}
.document-fact-source-body {
  display: grid;
  gap: 12px;
  max-height: 650px;
  overflow: auto;
  padding: 12px;
}
.document-fact-text-preview {
  min-height: 340px;
  margin: 0;
}
.document-fact-review-list {
  display: grid;
}
.document-fact-review-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.65fr) minmax(140px, 1fr) minmax(118px, 0.4fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  border: 0;
  border-bottom: 1px solid var(--rule-soft);
  background: transparent;
  color: inherit;
  padding: 9px 12px;
  font: inherit;
  text-align: left;
}
.document-fact-review-row-editable {
  cursor: default;
}
.document-fact-review-row:hover,
.document-fact-review-row.active {
  background: var(--surface-2);
}
.document-fact-review-row.active {
  box-shadow: inset 3px 0 0 var(--focus);
}
.document-fact-review-row.dirty {
  background: color-mix(in srgb, var(--warn) 6%, transparent);
}
.document-fact-review-row:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: -2px;
}
.document-fact-review-row span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}
.document-fact-review-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 650;
  overflow-wrap: anywhere;
}
.document-fact-review-row em {
  font-style: normal;
  justify-self: end;
}
.document-fact-edit-control {
  min-width: 0;
}
.document-fact-value-input {
  width: 100%;
  min-height: 30px;
  font-size: 12.5px;
}
.document-fact-status-select {
  width: 100%;
  min-height: 30px;
  font-size: 12.5px;
}
.document-fact-status-select.chip-success {
  background: var(--success-soft);
}
.document-fact-status-select.chip-critical {
  background: var(--critical-soft);
}
.document-fact-status-select.chip-warn {
  background: var(--warn-soft);
}
.document-fact-edit-status {
  padding: 8px 12px;
  border-top: 1px solid var(--rule-soft);
}
.claim-update-source-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.claim-update-source-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  border: 0;
  border-radius: var(--radius-pill);
  font: inherit;
  font-size: 12px;
  font-weight: 500;
  padding: 2px 10px;
  cursor: pointer;
}
.claim-update-source-chip:hover {
  background: var(--hover);
}
.claim-update-source-chip.active {
  background: var(--text);
  color: var(--surface);
}
.updates-filter-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--radius-pill);
  background: var(--surface-3);
  color: currentColor;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}
.claim-update-status {
  border-top: 1px solid var(--rule);
  padding-top: 10px;
}
.updates-workbench {
  display: grid;
  gap: 16px;
}
.updates-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.updates-metric {
  display: grid;
  gap: 6px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 12px;
}
.updates-metric span {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.updates-metric strong {
  color: var(--text);
  font-size: 24px;
  line-height: 1;
}
.updates-mode-tabs {
  margin: 0;
  padding-inline: 0;
}
.updates-chip-row,
.updates-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.updates-filter-row {
  row-gap: 10px;
}
.updates-filter-chip {
  min-height: 28px;
  cursor: pointer;
}
.updates-filter-chip:hover {
  background: var(--hover);
}
.updates-filter-select {
  max-width: min(360px, 100%);
}
.updates-filter-search {
  flex: 1 1 260px;
  min-width: 220px;
  max-width: 420px;
}
.updates-batch-list {
  display: grid;
  gap: 10px;
}
.updates-batch-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 12px;
}
.updates-batch-title {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 5px;
}
.updates-batch-title strong {
  color: var(--text);
  font-size: 15px;
}
.updates-batch-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.claim-update-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 12px;
}
.claim-update-row.approved,
.claim-update-row.applied {
  border-color: rgba(31, 130, 74, 0.38);
  background: var(--success-soft);
}
.claim-update-row.declined {
  border-color: rgba(193, 58, 43, 0.32);
  background: var(--critical-soft);
}
.claim-update-row.focused {
  border-color: var(--focus, #2563eb);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--focus, #2563eb) 18%, transparent);
}
.claim-update-title-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}
.claim-update-title-row strong {
  font-size: 15px;
}
.claim-update-values {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.claim-update-values > div {
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 10px;
}
.claim-update-values span {
  display: block;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}
.claim-update-values strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.claim-update-reason {
  margin-top: 10px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.4;
}
.claim-update-follow-up {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  max-width: 420px;
}
.checkbox-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
  font-weight: 650;
}
.checkbox-line input {
  margin: 0;
}
.input-sm {
  min-height: 32px;
  padding-block: 6px;
  font-size: 12px;
}
.claim-field-provenance {
  margin-top: 4px;
}
.claim-update-controls {
  display: grid;
  gap: 6px;
  min-width: 158px;
  justify-items: stretch;
}
.claim-update-controls .btn {
  width: 100%;
  justify-content: flex-start;
  padding-inline: 10px;
}
.claim-update-approve.active {
  border-color: rgba(31, 130, 74, 0.42);
  background: var(--success-soft);
  color: var(--success);
}
.claim-update-decline.active {
  border-color: rgba(193, 58, 43, 0.38);
  background: var(--critical-soft);
  color: var(--critical);
}
.claim-update-table-shell {
  flex: 1 1 auto;
  min-height: 0;
  max-height: min(62vh, 680px);
  overflow: auto;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
}
.claim-update-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.claim-update-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 10px 12px;
  border-bottom: 1px solid var(--rule);
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: left;
  text-transform: uppercase;
  white-space: nowrap;
  pointer-events: none;
}
.claim-update-table thead th .playbook-help-trigger {
  pointer-events: auto;
}
.claim-update-table-head {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.claim-update-table-help {
  text-transform: none;
}
.claim-update-table thead th .claim-update-table-help-popover {
  bottom: auto;
  top: calc(100% + 8px);
  width: min(320px, calc(100vw - 48px));
  white-space: pre-line;
  transform: translateX(-16px) translateY(-4px);
  z-index: 5;
}
.claim-update-table thead th .playbook-help-trigger:hover .claim-update-table-help-popover,
.claim-update-table thead th .playbook-help-trigger:focus-visible .claim-update-table-help-popover {
  transform: translateX(-16px) translateY(0);
}
.claim-update-table-provenance[title] {
  cursor: help;
}
.claim-update-table tbody td,
.claim-update-table tbody th {
  padding: 10px 12px;
  border-bottom: 1px solid var(--rule-soft);
  vertical-align: middle;
}
.claim-update-table-row:last-child td,
.claim-update-table-row:last-child th {
  border-bottom: none;
}
.claim-update-table-row.approved,
.claim-update-table-row.applied {
  background: color-mix(in srgb, var(--success-soft) 72%, var(--surface));
}
.claim-update-table-row.declined {
  background: color-mix(in srgb, var(--critical-soft) 68%, var(--surface));
}
.claim-update-table-field {
  min-width: 140px;
  font-weight: 600;
}
.claim-update-table-field .chip-xs {
  display: inline-block;
  margin-left: 6px;
  vertical-align: middle;
}
.claim-update-table-section {
  min-width: 96px;
  white-space: nowrap;
}
.claim-update-table-value {
  min-width: 160px;
  max-width: 280px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.claim-update-table-proposed {
  font-weight: 650;
  color: var(--text);
}
.claim-update-table-provenance {
  min-width: 132px;
  max-width: 180px;
  line-height: 1.35;
}
.claim-update-origin-label {
  display: block;
  font-size: 12px;
  font-weight: 650;
}
.claim-update-origin-detail {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  line-height: 1.3;
}
.claim-update-origin-manual {
  color: var(--text);
}
.claim-update-origin-cac {
  color: var(--accent, #2563eb);
}
.claim-update-origin-document {
  color: var(--text-2);
}
.claim-update-table-decision-cell {
  min-width: 148px;
}
.claim-update-table-decisions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
}
.claim-update-table-decisions .btn-xs {
  min-height: 28px;
  padding: 4px 8px;
  font-size: 11px;
}
.claim-update-table-task-head,
.claim-update-table-task-cell {
  width: min(168px, 22vw);
  min-width: 88px;
  text-align: left;
}
.claim-update-table-task-stack {
  display: grid;
  gap: 6px;
  justify-items: start;
}
.claim-update-table-task {
  justify-content: flex-start;
  margin: 0;
}
.claim-update-table-task-title {
  width: min(156px, 100%);
}
@media (max-width: 960px) {
  .document-review-workspace,
  .document-fact-review-workspace,
  .document-review-detail-grid,
  .document-summary-detail-list,
  .claim-update-queue-summary,
  .updates-summary-grid {
    grid-template-columns: 1fr;
  }
  .document-review-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .claim-update-review-head,
  .claim-update-row,
  .claim-update-values {
    grid-template-columns: 1fr;
  }
  .claim-update-entry-card {
    grid-template-columns: 1fr;
  }
  .claim-update-entry-card .btn {
    justify-self: stretch;
    justify-content: center;
  }
  .claim-update-controls {
    min-width: 0;
  }
  .claim-update-review-head {
    display: grid;
  }
  .document-review-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .document-ai-structured {
    grid-template-columns: 1fr;
  }
  .document-ai-structured-row,
  .document-ai-structured-row:nth-child(2n) {
    border-right: 0;
  }
  .document-fact-review-row {
    grid-template-columns: 1fr;
  }
  .document-fact-review-row em {
    justify-self: start;
  }
}
.evidence-helper-text {
  margin-bottom: 12px;
  max-width: 68ch;
}
.task-assignee-stack {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.task-assignee-stack-compact {
  gap: 0;
}
.task-assignee-avatars {
  display: inline-flex;
  align-items: center;
}
.task-assignee-avatar {
  box-shadow: 0 0 0 2px var(--surface);
}
.task-assignee-avatar + .task-assignee-avatar {
  margin-left: -7px;
}
.task-people-picker {
  position: relative;
  width: 100%;
  min-width: 0;
}
.task-people-selected {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 6px;
  border: 1px solid var(--border);
  border-radius: var(--radius-connected-top);
  background: var(--surface-2);
}
.task-person-chip {
  display: flex;
  align-items: center;
  gap: 7px;
  max-width: 100%;
  padding: 3px 6px 3px 4px;
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text);
  font-size: 13px;
}
.task-person-chip button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  color: var(--text-3);
}
.task-person-chip button:hover {
  background: var(--surface-3);
  color: var(--text);
}
.task-people-search {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-top: 0;
  border-radius: var(--radius-connected-bottom);
  background: var(--surface);
  color: var(--text-3);
}
.task-people-input {
  width: 100%;
  height: 34px;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
}
.task-people-menu {
  position: absolute;
  z-index: 30;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  max-height: 236px;
  overflow: auto;
  border: 1px solid var(--border-firm);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-pop);
  padding: 4px;
}
.task-people-option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  width: 100%;
  min-height: 40px;
  padding: 6px 8px;
  border-radius: var(--radius-control);
  text-align: left;
}
.task-people-option:hover,
.task-people-option:focus-visible {
  background: var(--surface-2);
}
.task-people-name {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}
.task-people-role,
.task-people-empty {
  display: block;
  font-size: 12px;
  color: var(--text-3);
}
.task-people-empty {
  padding: 10px;
}
.task-assignees-field .editable-field {
  min-width: 0;
}
.task-waiting-line {
  margin-top: 5px;
  max-width: 46ch;
}
.fax-wizard {
  display: grid;
  gap: 16px;
}
.fax-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.fax-step {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  padding: 8px 10px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.fax-step span {
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-3);
  font-size: 11px;
}
.fax-step.active {
  border-color: var(--text);
  background: var(--surface);
  color: var(--text);
}
.fax-step.complete {
  border-color: rgba(43, 122, 75, 0.28);
  background: var(--success-soft);
  color: var(--success);
}
.fax-panel {
  display: grid;
  gap: 16px;
}
.fax-cover-builder,
.fax-attachment-builder {
  display: grid;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  padding: 12px;
  margin-bottom: 12px;
}
.fax-cover-builder textarea {
  min-height: 92px;
}
.fax-attachment-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(160px, 0.8fr) 78px auto;
  gap: 8px;
  align-items: start;
}
.fax-attachment-name {
  display: grid;
  gap: 4px;
}
.fax-existing-docs-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.45fr);
  gap: 12px;
  align-items: end;
  margin: 2px 0 8px;
}
.fax-doc-filters {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.fax-section-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 720;
}
.fax-packet-order {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}
.fax-packet-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 9px 10px;
}
.fax-packet-number {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 12px;
  font-weight: 720;
}
.fax-packet-actions {
  display: flex;
  align-items: center;
  gap: 4px;
}
.fax-review-order {
  display: grid;
  gap: 3px;
  margin-top: 8px;
}
.fax-readonly-stat {
  display: flex;
  align-items: center;
  min-height: 38px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 0 12px;
  font-weight: 720;
}
.fax-doc-list,
.fax-recipient-list {
  display: grid;
  gap: 8px;
}
.fax-doc-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 10px 12px;
  text-align: left;
}
.fax-doc-row:hover,
.fax-doc-row.selected {
  border-color: var(--accent);
  background: var(--surface-2);
}
.fax-doc-check {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-3);
}
.fax-doc-row.selected .fax-doc-check {
  background: var(--text);
  color: var(--surface);
}
.fax-doc-title,
.fax-recipient-name,
.fax-result-title {
  display: block;
  color: var(--text);
  font-weight: 720;
}
.fax-doc-meta {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 12px;
}
.fax-recipient-layout,
.fax-review-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.fax-add-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}
.fax-custom-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, 0.75fr) auto;
  gap: 8px;
}
.fax-recipient-card,
.fax-review-card,
.fax-result-banner,
.fax-receipt-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 12px;
}
.fax-result-banner {
  justify-content: flex-start;
}
.fax-result-banner.sent {
  border-color: rgba(43, 122, 75, 0.26);
  background: var(--success-soft);
}
.fax-result-banner.failed {
  border-color: rgba(156, 42, 24, 0.26);
  background: var(--critical-soft);
}
.fax-receipt-note {
  justify-content: flex-start;
  color: var(--text-2);
  font-size: 13px;
}
.fax-empty {
  padding: 18px;
}
@media (max-width: 760px) {
  .fax-steps,
  .fax-recipient-layout,
  .fax-review-grid {
    grid-template-columns: 1fr;
  }
  .fax-custom-grid {
    grid-template-columns: 1fr;
  }
  .fax-attachment-grid,
  .fax-existing-docs-head {
    grid-template-columns: 1fr;
  }
  .fax-packet-item {
    grid-template-columns: auto minmax(0, 1fr);
  }
  .fax-packet-actions {
    grid-column: 2;
  }
}
.workstream-status-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid #EBD3A8;
  border-radius: var(--radius);
  background: #FCEEDA;
}
.workstream-status-banner > div { flex: 1; min-width: 0; }

.activity-row {
  display: grid; grid-template-columns: 64px 22px 1fr;
  gap: 10px; align-items: start;
  padding: 8px 0;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.activity-row.selected {
  margin-inline: -8px;
  padding-inline: 8px;
  border-radius: var(--radius);
  background: var(--surface-2);
}
.activity-time { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); padding-top: 2px; }
.activity-text { font-size: 13px; color: var(--text-2); line-height: 1.5; }
.activity-filter-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}
.activity-text-cac {
  display: grid;
  gap: 6px;
}
.activity-cac-detail,
.activity-cac-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  color: var(--text-3);
  font-size: 12px;
}
.activity-cac-detail span {
  min-width: 0;
  overflow-wrap: anywhere;
}
.activity-cac-meta {
  align-items: center;
}

/* ============================================================
 * 15. INBOX — list rows + drawer
 * ============================================================ */
.inbox-table-shell .table-wrap {
  border-radius: 0;
  overflow-x: auto;
  overflow-y: visible;
}
.inbox-table {
  table-layout: fixed;
  min-width: 0;
  background: var(--surface);
}
.inbox-table th,
.inbox-table td {
  padding: 14px 9px;
}
.inbox-table th {
  background: var(--widget-header-bg);
  font-size: 13px;
}
.inbox-table td {
  font-size: 14px;
}
.inbox-table col[data-col="select"],
.inbox-table col[data-col="actions"] { width: 40px; }
.inbox-table col[data-col="received"] { width: 94px; }
.inbox-table col[data-col="source"] { width: 30px; }
.inbox-table col[data-col="from"] { width: 230px; }
.inbox-table col[data-col="subject"] { width: 260px; }
.inbox-table col[data-col="claim"] { width: 235px; }
.inbox-table col[data-col="ingestion"] { width: 245px; }
.inbox-table col[data-col="status"] { width: 118px; }
.inbox-table th[data-col="actions"],
.inbox-table td.inbox-row-actions {
  padding-left: 0;
  padding-right: 0;
  text-align: center;
  vertical-align: middle;
}
.inbox-table td.inbox-row-actions {
  width: 40px;
}
.inbox-table td.inbox-row-actions .inbox-row-action-btn {
  color: var(--muted);
  transition: color 120ms ease, background 120ms ease;
}
.inbox-table td.inbox-row-actions .inbox-row-action-btn svg {
  stroke: currentColor;
}
.inbox-table tbody tr:hover td.inbox-row-actions .inbox-row-action-btn,
.inbox-table tbody tr:focus-within td.inbox-row-actions .inbox-row-action-btn,
.inbox-table.inbox-table-show-actions td.inbox-row-actions .inbox-row-action-btn {
  color: var(--text);
  background: var(--hover-2);
}
.inbox-table td.card-control input {
  width: 14px;
  height: 14px;
  margin: 0 auto;
}
.inbox-table th:first-child,
.inbox-table td:first-child {
  padding-left: 14px;
}
.inbox-table tbody tr {
  cursor: pointer;
}
.inbox-table tbody tr.selected td {
  background: var(--hover-2);
  box-shadow: inset 0 -1px 0 var(--rule);
}
.inbox-table tbody tr.selected td:first-child,
.inbox-table tbody tr.selected td[data-card="received"] {
  box-shadow: inset 0 -1px 0 var(--rule), inset 3px 0 0 var(--text);
}
.inbox-file-success {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 10px;
  padding: 9px 10px;
  border: 1px solid color-mix(in srgb, var(--success) 28%, var(--rule));
  border-radius: var(--radius-lg);
  background: var(--success-soft);
  color: var(--text);
  font-size: 12px;
}
.inbox-file-success-main {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.inbox-file-success-main svg {
  flex: 0 0 auto;
  color: var(--success);
}
.inbox-file-success-main span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.inbox-ingestion-items-panel {
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 12px;
  margin-bottom: 12px;
  background: var(--surface);
}
.inbox-ingestion-items-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.inbox-ingestion-item-list {
  display: grid;
  gap: 8px;
}
.inbox-ingestion-item-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--panel);
}
.inbox-ingestion-item-row.active {
  border-color: var(--accent);
  box-shadow: inset 3px 0 0 var(--accent);
}
.inbox-ingestion-item-main {
  min-width: 0;
}
.inbox-ingestion-item-title {
  font-weight: 650;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.inbox-ingestion-item-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
@media (max-width: 760px) {
  .inbox-ingestion-item-row {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }
  .inbox-ingestion-item-actions {
    flex-wrap: wrap;
  }
}
.inbox-table tbody tr.unread .inbox-sender,
.inbox-table tbody tr.unread .inbox-subject {
  font-weight: 600;
}
.inbox-source-cell {
  padding-left: 4px !important;
  padding-right: 2px !important;
}
.inbox-table th[data-col="from"],
.inbox-table td[data-card="from"] {
  padding-left: 2px;
}
.inbox-source-cell .source-chip {
  justify-content: center;
  width: 18px;
}
.inbox-source-cell,
.inbox-received-cell,
.inbox-pages-cell {
  white-space: nowrap;
}
.inbox-received-cell {
  line-height: 1.2;
}
.inbox-received-date,
.inbox-received-time {
  display: block;
}
.inbox-received-time {
  margin-top: 2px;
  font-size: 12px;
  color: var(--text-3);
}
.inbox-source-attachment {
  display: block;
  margin: 3px 0 0 19px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.1;
}
.inbox-claim-match-line {
  font-size: 13px;
}
.inbox-claim-match-line > span + span {
  margin-left: 4px;
}
.inbox-claim-match-line .mono {
  font-size: 13px;
}
.inbox-claim-separator {
  margin-inline: 3px 0;
}
.inbox-sender,
.inbox-subject,
.inbox-claim-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.inbox-split-flag {
  display: inline-flex;
  align-items: center;
  margin-left: 6px;
  color: var(--warn);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}
.inbox-ingestion-cell {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.inbox-ingestion-topline,
.inbox-ingestion-meta,
.inbox-ingestion-compact-top,
.inbox-ingestion-compact-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}
.inbox-ingestion-meta {
  color: var(--text-3);
  font-size: 12px;
}
.inbox-ingestion-meta span,
.inbox-ingestion-compact-bottom span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.inbox-ingestion-segments {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 2px;
  height: 6px;
}
.inbox-ingestion-segments span {
  min-width: 0;
  background: var(--surface-3);
}
.inbox-ingestion-segments span:first-child {
  border-radius: var(--radius-segment-start);
}
.inbox-ingestion-segments span:last-child {
  border-radius: var(--radius-segment-end);
}
.inbox-ingestion-segments span.complete {
  background: var(--accent);
}
.inbox-ingestion-cell.compact {
  gap: 3px;
}
.inbox-ingestion-compact-top {
  display: block;
  font-size: 12px;
}
.inbox-ingestion-compact-bottom {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(72px, auto);
  align-items: center;
  gap: 8px;
  color: var(--text-3);
  font-size: 11.5px;
}
.inbox-ingestion-compact-bottom > span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.inbox-ingestion-compact-bottom span:last-child {
  text-align: right;
}
.inbox-ingestion-status-cell {
  display: grid;
  justify-items: start;
  gap: 3px;
  min-width: 0;
}
.inbox-ingestion-status-cell .chip {
  max-width: 100%;
}
.inbox-ingestion-progress-count {
  color: var(--text-3);
  font-size: 12px;
  margin-right: 4px;
}
.inbox-ingestion-next {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.error-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--critical-soft);
  color: var(--critical);
  font-size: 12.5px;
  box-shadow: inset 0 -1px 0 var(--rule);
}
.error-banner strong { font-weight: 600; }

.suggestion-chip {
  display: inline-flex; align-items: center;
  padding: 1px 8px; border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 500;
  background: var(--surface-3); color: var(--text-2);
  margin-right: 4px;
}

.inbox-plan-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.inbox-filter-bar {
  align-items: center;
}
.app-page-body > .canvas-table-page.inbox-page {
  gap: 0;
}
.inbox-filter-bar-compact {
  gap: 8px;
}
.inbox-filter-bar-compact .filter-chip-select {
  max-width: 210px;
}
.inbox-filter-bar-compact .filter-bar-actions {
  margin-left: 0;
}
.inbox-row-actions {
  white-space: nowrap;
}
.inbox-row-dismissed {
  opacity: 0.72;
}
.inbox-row-dismissed .inbox-subject {
  text-decoration: line-through;
  text-decoration-color: color-mix(in srgb, var(--text-muted) 70%, transparent);
}
.inbox-plan-source {
  font-size: 12px;
  color: var(--text-2);
  padding: 8px 10px;
  background: color-mix(in srgb, var(--accent) 7%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--rule));
  border-radius: var(--radius);
}
.inbox-plan-section {
  display: grid;
  gap: 8px;
}
.inbox-plan-section-head {
  justify-content: space-between;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}
.ingestion-wizard {
  display: grid;
  gap: 6px;
}
.ingestion-step {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.ingestion-step.completed {
  background: var(--success-soft);
  border-color: color-mix(in srgb, var(--success) 24%, var(--rule));
}
.ingestion-step.blocked {
  background: var(--critical-soft);
  border-color: color-mix(in srgb, var(--critical) 24%, var(--rule));
}
.ingestion-step.ready {
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 18%, var(--rule));
}
.ingestion-step-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 22px;
  background: var(--surface);
  box-shadow: var(--ring-light);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-2);
}
.ingestion-step-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}
.ingestion-impact-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.ingestion-impact-grid > div {
  display: grid;
  gap: 2px;
  padding: 8px;
  border-radius: var(--radius);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}
.ingestion-impact-grid strong {
  font-size: 16px;
  font-weight: 600;
}
.ingestion-impact-grid span {
  font-size: 11px;
  color: var(--text-3);
}
.ingestion-impact-detail {
  display: grid;
  gap: 6px;
  margin: 10px 0;
}
.ingestion-impact-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--ring-light);
  font-size: 12px;
}
.ingestion-impact-row span:nth-child(2) {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ingestion-impact-row strong {
  font-size: 12px;
  font-weight: 600;
}
.ingestion-gaps {
  display: grid;
  gap: 8px;
}
.ingestion-gap {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 10px;
  border-radius: var(--radius);
  background: var(--surface-2);
  border: 1px solid var(--rule-soft);
}
.ingestion-gap.blocking {
  background: var(--critical-soft);
  border-color: color-mix(in srgb, var(--critical) 24%, var(--rule));
}
.review-file-flow {
  display: grid;
  gap: 0;
  padding-bottom: 8px;
}
.review-flow-header,
.review-flow-meta,
.review-flow-state,
.review-accordion-summary,
.review-owner-line,
.review-flow-foot,
.review-handoff-panel,
.review-selected-claim {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.review-flow-header {
  align-items: flex-start;
  padding: 16px 18px 14px;
  border-bottom: 1px solid var(--rule);
}
.review-flow-kicker {
  margin-bottom: 2px;
  color: var(--text-3);
  font-size: 10px;
  font-weight: 720;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.review-flow-title {
  font-size: 16px;
  font-weight: 720;
  color: var(--text);
  line-height: 1.2;
}
.review-flow-meta,
.review-flow-state {
  justify-content: flex-start;
  flex-wrap: wrap;
}
.review-flow-spine {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 6px;
}
.review-flow-spine-step {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-label);
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 650;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.review-flow-spine-step:hover {
  border-color: color-mix(in srgb, var(--accent) 24%, var(--rule));
  color: var(--text);
}
.review-flow-spine-step.done {
  border-color: color-mix(in srgb, var(--success) 22%, var(--rule));
  background: var(--success-soft);
  color: var(--success);
}
.review-flow-spine-step.active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  color: var(--text);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 16%, transparent);
}
.review-accordion-step {
  border: 0;
  border-bottom: 1px solid var(--rule);
  border-radius: 0;
  background: transparent;
  overflow: hidden;
}
.review-accordion-step.open {
  background: transparent;
}
.review-accordion-summary {
  align-items: flex-start;
  padding: 14px 18px;
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}
.review-accordion-summary:hover {
  background: color-mix(in srgb, var(--accent) 4%, transparent);
}
.review-accordion-main {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  min-width: 0;
}
.review-accordion-copy {
  min-width: 0;
}
.review-accordion-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.review-accordion-title {
  font-size: 14px;
  font-weight: 720;
  color: var(--text);
  line-height: 1.25;
}
.review-accordion-line {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.review-owner-line {
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 11px;
}
.review-inline-fields,
.review-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: 10px;
}
.review-edit-grid .list-row {
  grid-template-columns: 24px minmax(0, 1fr);
}
.review-edit-grid .list-row-main,
.review-edit-grid .list-row-title-wrap,
.review-edit-grid .list-row-title {
  min-width: 0;
  width: 100%;
}
.review-edit-grid .list-row-title-wrap {
  flex: 1 1 auto;
}
.review-edit-grid .list-row-aside {
  margin-left: 8px;
}
.review-edit-grid .list-row-title > .input {
  width: 100%;
  min-width: min(420px, 100%);
}
.review-claim-updates-section {
  grid-column: 1 / -1;
}
.review-output-reason {
  min-height: 58px;
}
.review-output-stack {
  display: grid;
  gap: 12px;
}
.review-output-stack .review-stage-card {
  padding: 12px;
}
.cac-update-decision-select {
  width: min(220px, 100%);
}
.cac-data-update-detail {
  background: var(--surface);
  overflow: hidden;
}
.cac-data-update-detail.inbox-detail-view-workspace {
  height: auto;
}
.inbox-cac-update-workspace {
  flex: 0 1 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px 20px 20px;
  min-height: 0;
  overflow: visible;
}
.inbox-cac-update-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
}
.inbox-cac-update-head h2 {
  margin: 0;
  font-size: 20px;
  line-height: 1.25;
  letter-spacing: 0;
}
.inbox-cac-update-head p {
  margin: 4px 0 0;
}
.inbox-cac-update-callout {
  padding: 10px 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.inbox-cac-update-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 12px;
  margin-top: 4px;
  border-top: 1px solid var(--rule);
}
.inbox-cac-update-footer-batch .inbox-cac-update-footer-summary {
  flex: 1 1 auto;
}
.inbox-cac-update-footer-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.inbox-cac-update-workspace .claim-update-table-shell {
  flex: 0 1 auto;
}
.inbox-cac-section-label {
  padding: 4px 2px 0;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.inbox-cac-update-workspace .claim-update-list {
  display: grid;
  gap: 10px;
  flex: 0 1 auto;
  align-content: start;
  max-height: min(60vh, 640px);
  overflow: auto;
}
.inbox-cac-update-workspace .claim-update-row {
  margin: 0;
  align-self: start;
}
.cac-data-update-shell {
  flex: 1;
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 24px;
  min-height: 0;
  overflow: auto;
}
.cac-data-update-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--rule);
}
.cac-data-update-header h2,
.cac-data-review-title h3,
.cac-data-field-heading h4 {
  margin: 0;
  letter-spacing: 0;
}
.cac-data-update-header h2 {
  font-size: 22px;
  line-height: 1.2;
}
.cac-data-update-header p,
.cac-data-review-title p {
  margin: 6px 0 0;
  color: var(--text-2);
}
.overline {
  display: block;
  margin-bottom: 4px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 720;
  letter-spacing: 0;
  text-transform: uppercase;
}
.cac-data-context-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.cac-data-bulk-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 13px;
}
.cac-data-bulk-summary span {
  padding: 3px 8px;
  border-radius: var(--radius-pill);
  background: var(--bg);
}
.cac-data-context-card,
.cac-data-review-panel,
.cac-data-resolved-card,
.cac-data-field-card {
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--bg);
}
.cac-data-context-card {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 12px;
}
.cac-data-context-card span,
.cac-data-context-card small,
.cac-data-value span,
.cac-data-decision-cell > span {
  color: var(--text-3);
  font-size: 12px;
}
.cac-data-context-card strong,
.cac-data-value strong {
  min-width: 0;
  overflow-wrap: anywhere;
  color: var(--text);
}
.cac-data-review-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
}
.cac-data-review-title,
.cac-data-field-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.cac-data-field-list {
  display: grid;
  gap: 12px;
}
.cac-data-section-list {
  display: grid;
  gap: 14px;
}
.cac-data-section-card {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
}
.cac-data-section-head,
.cac-data-section-actions,
.cac-data-bulk-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.cac-data-section-head {
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule-soft);
}
.cac-data-section-head h4,
.cac-data-section-head p {
  margin: 0;
  letter-spacing: 0;
}
.cac-data-section-head p {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 13px;
}
.cac-data-section-actions,
.cac-data-bulk-toolbar {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.cac-data-bulk-toolbar {
  justify-content: flex-start;
}
.cac-data-field-card {
  display: grid;
  gap: 12px;
  padding: 14px;
}
.cac-data-field-paths {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 12px;
}
.cac-data-field-paths code {
  padding: 1px 4px;
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--text-2);
  font-family: var(--font-mono);
  font-size: 11px;
}
.cac-data-value-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(220px, 280px);
  gap: 12px;
  align-items: stretch;
}
.cac-data-value,
.cac-data-decision-cell {
  display: grid;
  align-content: start;
  gap: 5px;
  min-width: 0;
  padding: 10px;
  border-radius: var(--radius);
  background: var(--surface-2);
}
.cac-data-value.incoming {
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-2));
}
.cac-data-task-row {
  margin-top: -2px;
}
.cac-data-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding-top: 4px;
}
.cac-data-resolved-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
}
.cac-data-apply-summary {
  display: grid;
  gap: 16px;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--success) 24%, var(--rule));
  border-radius: var(--radius-lg);
  background: var(--bg);
}
.cac-data-apply-summary-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.cac-data-apply-summary-head h3,
.cac-data-apply-summary-head p,
.cac-data-apply-columns h4,
.cac-data-apply-columns p {
  margin: 0;
  letter-spacing: 0;
}
.cac-data-apply-summary-head p {
  margin-top: 6px;
  color: var(--text-2);
}
.cac-data-apply-metrics,
.cac-data-apply-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.cac-data-apply-metrics > div,
.cac-data-apply-columns > div {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
}
.cac-data-apply-metrics span {
  display: block;
  color: var(--text-3);
  font-size: 12px;
}
.cac-data-apply-metrics strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
}
.cac-data-apply-columns h4 {
  font-size: 14px;
}
.cac-data-apply-columns ul {
  display: grid;
  gap: 6px;
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--text-2);
}
.chip-muted {
  background: var(--surface-2);
  color: var(--text-2);
}
@media (max-width: 980px) {
  .cac-data-context-grid,
  .cac-data-value-grid,
  .cac-data-apply-metrics,
  .cac-data-apply-columns {
    grid-template-columns: 1fr;
  }
  .cac-data-update-header,
  .cac-data-review-title,
  .cac-data-field-heading,
  .cac-data-section-head,
  .cac-data-resolved-card,
  .cac-data-apply-summary-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .cac-data-section-actions {
    justify-content: flex-start;
  }
  .cac-data-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}
.review-handoff-panel {
  align-items: flex-start;
  padding: 11px 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--rule));
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
}
.review-handoff-title {
  font-weight: 720;
  color: var(--text);
}
.review-accordion-body {
  display: grid;
  gap: 12px;
  padding: 0 18px 16px 50px;
}
.review-accordion-panel {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  transform: translateY(-4px);
  transition:
    max-height 360ms cubic-bezier(.2, .7, .2, 1),
    opacity 220ms ease,
    transform 260ms ease;
  visibility: hidden;
}
.review-accordion-step.open .review-accordion-panel {
  max-height: 6400px;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  visibility: visible;
}
.review-accordion-step.complete .ingestion-step-num {
  background: var(--success-soft);
  color: var(--success);
}
.review-accordion-step.processing .ingestion-step-num {
  background: var(--surface);
  color: var(--accent);
}
.review-step-spinner {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, var(--accent) 22%, var(--rule));
  border-top-color: var(--accent);
  animation: review-step-spin 700ms linear infinite;
}
@keyframes review-step-spin {
  to {
    transform: rotate(360deg);
  }
}
.review-panel-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: flex-end;
}
.review-detail-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: var(--text-2);
  font-size: 12px;
}
.review-claim-stage {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
}
.review-step-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}
.review-file-step-actions {
  justify-content: flex-start;
  flex-wrap: wrap;
  padding-top: 4px;
}
.review-file-step-actions .btn-primary {
  min-width: 220px;
}
.review-source-step-actions {
  justify-content: flex-start;
}
.review-savebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 18px;
  border-top: 1px solid var(--rule);
  background: var(--surface);
}
.review-savebar-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--success);
  font-size: 12px;
  font-weight: 650;
}
.review-confirmed-line {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--success);
  font-size: 12px;
  font-weight: 650;
}
.review-step-thinking {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 620;
}
.review-step-thinking-dot {
  width: 7px;
  height: 7px;
  border-radius: var(--radius-pill);
  background: var(--accent);
  animation: review-step-thinking-pulse 900ms ease-in-out infinite;
}
@keyframes review-step-thinking-pulse {
  0%, 100% {
    opacity: .35;
    transform: scale(.78);
  }
  50% {
    opacity: 1;
    transform: scale(1);
  }
}
.review-type-evidence {
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
}
.review-evidence-label {
  margin-bottom: 6px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 650;
}
.review-signal-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.review-type-candidates {
  display: grid;
  gap: 6px;
}
.review-type-candidate {
  min-height: 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--text);
  font: inherit;
  font-size: 12px;
  text-align: left;
  cursor: pointer;
  padding: 7px 9px;
}
.review-type-candidate.selected {
  border-color: color-mix(in srgb, var(--success) 28%, var(--rule));
  background: var(--success-soft);
}
.review-selected-claim {
  justify-content: flex-start;
  padding: 8px 10px;
  border-radius: var(--radius);
  background: var(--surface-2);
  font-size: 12px;
}
.review-facts-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 10px;
}
.review-fact {
  display: grid;
  gap: 2px;
  padding: 10px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.review-fact-label,
.review-fact-source {
  color: var(--text-3);
  font-size: 11px;
}
.review-fact-value {
  color: var(--text);
  font-weight: 720;
}
.review-flow-foot {
  align-items: flex-start;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--success) 22%, var(--rule));
  border-radius: var(--radius-lg);
  background: var(--success-soft);
  color: var(--text);
  font-size: 12px;
}
.review-flow-foot .filing-protection-chip {
  flex: 0 1 25%;
  max-width: 25%;
  min-width: 104px;
  justify-content: center;
  text-align: center;
  white-space: normal;
  line-height: 1.2;
}
@media (max-width: 980px) {
  .inbox-detail-topbar,
  .inbox-detail-shell .lx-q3hiop,
  .review-flow-spine,
  .review-inline-fields,
  .review-edit-grid,
  .review-facts-grid {
    grid-template-columns: 1fr;
  }
  .inbox-detail-topbar {
    align-items: flex-start;
  }
}
.document-playbook-catalog {
  margin-top: 14px;
  display: grid;
  gap: 12px;
}
.admin-playbook-body .document-playbook-catalog {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.admin-playbook-body .document-playbook-toolbar {
  flex: 0 0 auto;
}
.admin-playbook-body .document-playbook-split,
.admin-playbook-body .document-playbook-index,
.admin-playbook-body .document-playbook-table-shell {
  flex: 1;
  min-height: 0;
}
.admin-playbook-body .document-playbook-index {
  display: flex;
  flex-direction: column;
}
.admin-playbook-body .document-playbook-table-shell .table-wrap {
  max-height: none;
}
.admin-playbook-body .document-playbook-detail {
  min-height: 0;
  overflow: visible;
}
.admin-playbook-body .document-playbook-catalog.is-list-view .document-playbook-split {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.admin-playbook-body:has(.document-playbook-catalog.is-detail-view) .admin-playbook-heading {
  display: none;
}
.document-playbook-catalog.is-detail-view {
  margin-top: 0;
  padding-bottom: 90px;
}
.document-playbook-toolbar {
  padding: 10px 0 12px;
}
.document-playbook-search {
  flex-basis: 320px;
}
.document-playbook-count {
  white-space: nowrap;
}
.document-playbook-split {
  display: grid;
  grid-template-columns: minmax(300px, 31%) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  min-height: min(760px, calc(100vh - 238px));
}
.document-playbook-catalog.is-list-view .document-playbook-split {
  display: block;
}
.document-playbook-split.is-detail-mode {
  display: block;
  min-height: 0;
}
.document-playbook-index,
.document-playbook-detail {
  min-width: 0;
}
.document-playbook-catalog.is-list-view .document-playbook-index {
  width: 100%;
}
.document-playbook-table-shell .table-wrap {
  max-height: calc(100vh - 286px);
  overflow: auto;
  box-shadow: inset 0 1px 0 var(--rule), inset 0 -1px 0 var(--rule);
}
.document-playbook-table {
  table-layout: fixed;
}
.document-playbook-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 8px 7px;
  font-size: 12px;
  background: var(--bg);
}
.document-playbook-table td {
  padding: 7px;
  font-size: 12.5px;
  line-height: 1.25;
}
.document-playbook-table th:nth-child(1),
.document-playbook-table td:nth-child(1) {
  width: 42%;
}
.document-playbook-table th:nth-child(2),
.document-playbook-table td:nth-child(2) {
  width: 20%;
}
.document-playbook-table th:nth-child(3),
.document-playbook-table td:nth-child(3) {
  width: 14%;
}
.document-playbook-table th:nth-child(4),
.document-playbook-table td:nth-child(4),
.document-playbook-table th:nth-child(5),
.document-playbook-table td:nth-child(5),
.document-playbook-table th:nth-child(6),
.document-playbook-table td:nth-child(6) {
  width: 10%;
}
.document-playbook-table tbody tr {
  cursor: pointer;
}
.document-playbook-table tbody tr.active td {
  background: var(--accent-soft);
}
.document-playbook-mini-metrics {
  display: inline-flex;
  gap: 5px;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  color: var(--text-2);
}
.document-playbook-title-cell {
  min-width: 0;
}
.document-playbook-title-cell .cell-strong,
.document-playbook-title-cell .muted {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.document-playbook-detail {
  display: grid;
  gap: 12px;
  align-content: start;
  padding-left: 18px;
  box-shadow: inset 1px 0 0 var(--rule);
}
.document-playbook-split.is-detail-mode .document-playbook-detail {
  padding-left: 0;
  box-shadow: none;
}
.document-playbook-detail-head {
  display: grid;
  align-items: start;
  gap: 14px;
  padding-bottom: 12px;
  box-shadow: inset 0 -1px 0 var(--rule);
}
.document-playbook-back {
  justify-self: start;
}
.document-playbook-split:not(.is-detail-mode) .document-playbook-back {
  display: none;
}
.document-playbook-detail-title {
  font-size: 18px;
  font-weight: 650;
  line-height: 1.25;
}
.document-playbook-detail-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 5px;
  color: var(--text-3);
  font-size: 12px;
}
.document-playbook-actions {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  flex-wrap: wrap;
}
.document-playbook-stat-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  box-shadow: inset 0 1px 0 var(--rule), inset 0 -1px 0 var(--rule);
}
.document-playbook-stat {
  display: grid;
  gap: 3px;
  padding: 8px 10px;
  box-shadow: inset -1px 0 0 var(--rule-soft);
}
.document-playbook-stat:last-child {
  box-shadow: none;
}
.document-playbook-stat span {
  color: var(--text-3);
  font-size: 11.5px;
}
.document-playbook-stat strong {
  color: var(--text);
  font-size: 13px;
}
.document-playbook-stat.has-warning strong {
  color: var(--warn);
}
.document-playbook-section-tabs {
  min-width: 0;
  overflow-x: auto;
  padding-bottom: 2px;
}
.document-playbook-detail-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}
.document-playbook-detail-body .document-playbook-side {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.document-playbook-split.is-detail-mode .document-playbook-detail-body {
  grid-template-columns: minmax(0, 1fr);
}
.document-playbook-editor,
.document-playbook-side {
  display: grid;
  gap: 10px;
  align-content: start;
}
.document-playbook-editor .form-grid {
  gap: 10px;
}
.document-playbook-basics {
  grid-template-columns: minmax(220px, 1fr) minmax(160px, 0.6fr) minmax(220px, 0.8fr) 160px;
}
.modal .document-playbook-basics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.document-playbook-editor .textarea {
  min-height: 76px;
}
.document-playbook-editor .document-playbook-textarea-signals {
  min-height: 132px;
}
.document-playbook-editor .document-playbook-textarea-schema {
  min-height: 156px;
}
.document-playbook-section {
  display: grid;
  gap: 10px;
  min-width: 0;
}
.document-playbook-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.playbook-help-heading {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  position: relative;
}
.playbook-help-trigger {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-3);
  cursor: help;
  position: relative;
  flex: 0 0 auto;
}
.playbook-help-trigger:hover,
.playbook-help-trigger:focus-visible {
  color: var(--text);
  background: var(--surface-3);
}
.playbook-help-popover {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  z-index: 20;
  width: min(360px, calc(100vw - 48px));
  transform: translateX(-16px) translateY(4px);
  opacity: 0;
  pointer-events: none;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--text);
  color: var(--bg);
  padding: 9px 10px;
  box-shadow: var(--shadow-2);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.4;
  text-align: left;
  white-space: normal;
}
.playbook-help-trigger:hover .playbook-help-popover,
.playbook-help-trigger:focus-visible .playbook-help-popover {
  opacity: 1;
  transform: translateX(-16px) translateY(0);
}
.playbook-chip-editor {
  display: grid;
  gap: 10px;
}
.playbook-chip-list {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
  min-height: 34px;
}
.playbook-removable-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  max-width: 100%;
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text);
  padding: 4px 9px;
  font: inherit;
  font-size: 12px;
  cursor: pointer;
}
.playbook-removable-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.playbook-removable-chip:hover {
  background: var(--hover-2);
}
.playbook-removable-chip.outline {
  background: var(--bg);
}
.playbook-inline-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content;
  gap: 8px;
}
.playbook-inline-add .btn {
  white-space: nowrap;
}
.playbook-inline-hint {
  color: var(--warn);
  margin-top: -4px;
}
.playbook-structured-wrap {
  width: 100%;
  max-width: 100%;
  max-height: min(520px, calc(100vh - 390px));
  overflow: auto;
  box-shadow: inset 0 1px 0 var(--rule), inset 0 -1px 0 var(--rule);
}
.app-page-body .playbook-structured-wrap {
  overflow: auto;
}
.document-playbook-split.is-detail-mode .playbook-structured-wrap {
  max-height: none;
}
.playbook-structured-table {
  table-layout: fixed;
}
.playbook-structured-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--bg);
  font-size: 11.5px;
}
.playbook-structured-table th,
.playbook-structured-table td {
  padding: 6px;
  vertical-align: top;
}
.playbook-structured-table .input,
.playbook-structured-table .select {
  min-height: 30px;
  font-size: 12px;
}
.playbook-fact-table {
  min-width: 1180px;
}
.playbook-fact-table th:nth-child(1),
.playbook-fact-table td:nth-child(1) { width: 170px; }
.playbook-fact-table th:nth-child(2),
.playbook-fact-table td:nth-child(2) { width: 190px; }
.playbook-fact-table th:nth-child(3),
.playbook-fact-table td:nth-child(3) { width: 112px; }
.playbook-fact-table th:nth-child(4),
.playbook-fact-table td:nth-child(4) { width: 104px; }
.playbook-fact-table th:nth-child(5),
.playbook-fact-table td:nth-child(5) { width: 210px; }
.playbook-fact-table th:nth-child(6),
.playbook-fact-table td:nth-child(6) { width: 82px; }
.playbook-fact-table th:nth-child(7),
.playbook-fact-table td:nth-child(7) { width: 130px; }
.playbook-fact-table th:nth-child(8),
.playbook-fact-table td:nth-child(8) { width: 170px; }
.playbook-fact-table th:nth-child(9),
.playbook-fact-table td:nth-child(9) { width: 48px; }
.playbook-dynamic-table {
  min-width: 1160px;
}
.playbook-dynamic-table th:nth-child(1),
.playbook-dynamic-table td:nth-child(1) { width: 170px; }
.playbook-dynamic-table th:nth-child(2),
.playbook-dynamic-table td:nth-child(2) { width: 190px; }
.playbook-dynamic-table th:nth-child(3),
.playbook-dynamic-table td:nth-child(3) { width: 96px; }
.playbook-dynamic-table th:nth-child(4),
.playbook-dynamic-table td:nth-child(4) { width: 160px; }
.playbook-dynamic-table th:nth-child(5),
.playbook-dynamic-table td:nth-child(5) { width: 330px; }
.playbook-dynamic-table th:nth-child(6),
.playbook-dynamic-table td:nth-child(6) { width: 110px; }
.playbook-dynamic-table th:nth-child(7),
.playbook-dynamic-table td:nth-child(7) { width: 72px; }
.playbook-dynamic-table th:nth-child(8),
.playbook-dynamic-table td:nth-child(8) { width: 48px; }
.playbook-table-editor-list {
  display: grid;
  gap: 14px;
}
.playbook-table-editor-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg);
}
.playbook-table-editor-card .table-wrap {
  border: 0;
  border-radius: 0;
}
.playbook-columns-head {
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg-soft);
}
.playbook-table-column-table {
  min-width: 1060px;
}
.playbook-table-column-table th:nth-child(1),
.playbook-table-column-table td:nth-child(1) { width: 180px; }
.playbook-table-column-table th:nth-child(2),
.playbook-table-column-table td:nth-child(2) { width: 210px; }
.playbook-table-column-table th:nth-child(3),
.playbook-table-column-table td:nth-child(3) { width: 120px; }
.playbook-table-column-table th:nth-child(4),
.playbook-table-column-table td:nth-child(4) { width: 104px; }
.playbook-table-column-table th:nth-child(5),
.playbook-table-column-table td:nth-child(5) { width: 82px; }
.playbook-table-column-table th:nth-child(6),
.playbook-table-column-table td:nth-child(6) { width: 130px; }
.playbook-table-column-table th:nth-child(7),
.playbook-table-column-table td:nth-child(7) { width: 180px; }
.playbook-table-column-table th:nth-child(8),
.playbook-table-column-table td:nth-child(8) { width: 48px; }
.playbook-clock-table th:nth-child(1),
.playbook-clock-table td:nth-child(1) { width: 17%; }
.playbook-clock-table th:nth-child(2),
.playbook-clock-table td:nth-child(2) { width: 22%; }
.playbook-clock-table th:nth-child(3),
.playbook-clock-table td:nth-child(3) { width: 22%; }
.playbook-clock-table th:nth-child(4),
.playbook-clock-table td:nth-child(4) { width: 72px; }
.playbook-clock-table th:nth-child(5),
.playbook-clock-table td:nth-child(5) { width: 112px; }
.playbook-clock-table th:nth-child(6),
.playbook-clock-table td:nth-child(6) { width: 19%; }
.playbook-clock-table th:nth-child(7),
.playbook-clock-table td:nth-child(7) { width: 48px; }
.playbook-task-table th:nth-child(1),
.playbook-task-table td:nth-child(1) { width: 24%; }
.playbook-task-table th:nth-child(2),
.playbook-task-table td:nth-child(2) { width: 38%; }
.playbook-task-table th:nth-child(3),
.playbook-task-table td:nth-child(3) { width: 76px; }
.playbook-task-table th:nth-child(4),
.playbook-task-table td:nth-child(4) { width: 26%; }
.playbook-task-table th:nth-child(5),
.playbook-task-table td:nth-child(5) { width: 48px; }
.playbook-update-table th:nth-child(1),
.playbook-update-table td:nth-child(1) { width: 18%; }
.playbook-update-table th:nth-child(2),
.playbook-update-table td:nth-child(2) { width: 40%; }
.playbook-update-table th:nth-child(3),
.playbook-update-table td:nth-child(3) { width: 110px; }
.playbook-update-table th:nth-child(4),
.playbook-update-table td:nth-child(4) { width: 130px; }
.playbook-update-table th:nth-child(5),
.playbook-update-table td:nth-child(5) { width: 48px; }
.playbook-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  color: var(--text-2);
  font-size: 12px;
}
.playbook-token-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.playbook-validation-panel.has-errors {
  box-shadow: inset 3px 0 0 var(--danger, #a12b2b), inset 0 0 0 1px var(--rule);
}
.playbook-validation-panel.has-warnings {
  box-shadow: inset 3px 0 0 var(--warn), inset 0 0 0 1px var(--rule);
}
.playbook-validation-row {
  color: var(--text);
}
.playbook-preview-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.playbook-version-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
}
.playbook-preview-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 10px;
  background: var(--surface);
}
@media (max-width: 1280px) {
  .document-playbook-split {
    grid-template-columns: 1fr;
  }
  .document-playbook-detail {
    padding-left: 0;
    padding-top: 16px;
    box-shadow: inset 0 1px 0 var(--rule);
  }
  .document-playbook-split.is-detail-mode .document-playbook-detail {
    padding-top: 0;
    box-shadow: none;
  }
  .document-playbook-table-shell .table-wrap {
    max-height: 420px;
  }
  .playbook-structured-wrap {
    max-height: 520px;
  }
}
@media (max-width: 1500px) {
  .document-playbook-table th:nth-child(3),
  .document-playbook-table td:nth-child(3),
  .document-playbook-table th:nth-child(5),
  .document-playbook-table td:nth-child(5),
  .document-playbook-table th:nth-child(6),
  .document-playbook-table td:nth-child(6) {
    display: none;
  }
  .document-playbook-table th:nth-child(1),
  .document-playbook-table td:nth-child(1) {
    width: 50%;
  }
  .document-playbook-table th:nth-child(2),
  .document-playbook-table td:nth-child(2) {
    width: 30%;
  }
  .document-playbook-table th:nth-child(4),
  .document-playbook-table td:nth-child(4) {
    width: 20%;
  }
}
@media (max-width: 860px) {
  .document-playbook-detail-head,
  .document-playbook-detail-body {
    grid-template-columns: 1fr;
  }
  .document-playbook-detail-head {
    display: grid;
  }
  .document-playbook-stat-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .document-playbook-basics,
  .playbook-preview-grid,
  .playbook-version-grid,
  .document-playbook-detail-body .document-playbook-side {
    grid-template-columns: 1fr;
  }
  .playbook-structured-wrap {
    overflow-x: auto;
  }
  .playbook-structured-table {
    min-width: 760px;
  }
}
.inline-error {
  padding: 8px 10px;
  border-radius: var(--radius);
  background: var(--critical-soft);
  color: var(--critical);
  font-size: 12px;
}

/* ============================================================
 * 17. DRAWERS / MODALS
 * ============================================================ */
.drawer-backdrop, .modal-backdrop, .scrim, .assistant-scrim {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.32);
  z-index: 50;
}
.modal-backdrop {
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  z-index: var(--z-modal-backdrop);
}
.drawer-backdrop {
  z-index: var(--z-modal-backdrop);
}
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: var(--drawer-width, 480px);
  background: var(--bg);
  box-shadow: var(--ring-light), -12px 0 32px rgba(0,0,0,0.06);
  z-index: var(--z-modal);
  display: flex; flex-direction: column;
}
.modal {
  position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: var(--bg);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  z-index: var(--z-modal);
  width: var(--modal-width, auto);
  min-width: 480px; max-width: var(--modal-max-width, 600px);
  max-height: 86vh;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.modal-full-height { height: calc(100vh - 60px); max-height: calc(100vh - 60px); }
.modal-wide {
  width: min(860px, calc(100vw - 48px));
  max-width: calc(100vw - 48px);
}
.modal-workspace {
  width: calc(100vw - 48px);
  max-width: calc(100vw - 48px);
  height: calc(100vh - 48px);
  max-height: calc(100vh - 48px);
  box-shadow: var(--shadow-pop), 0 0 0 1px var(--rule);
}
.modal-workspace-fit {
  width: calc(100vw - 48px);
  max-width: calc(100vw - 48px);
  height: auto;
  max-height: calc(100vh - 48px);
  box-shadow: var(--shadow-pop), 0 0 0 1px var(--rule);
}
.modal-motion-backdrop {
  animation: modal-motion-backdrop-in var(--modal-motion-backdrop-in-duration) ease-out both;
}
.modal-motion {
  --modal-open-offset-x: 0px;
  --modal-open-offset-y: 0px;
  --modal-open-scale-x: 0.96;
  --modal-open-scale-y: 0.96;
  transform-origin: center center;
  animation: modal-motion-open var(--modal-motion-open-duration) var(--modal-motion-open-easing) both;
  will-change: transform, opacity;
}
.modal-motion-backdrop.is-continuing {
  animation: none;
}
.modal-motion.is-continuing {
  animation: modal-motion-swap 260ms var(--modal-motion-open-easing) both;
}
.modal-motion-backdrop.is-closing {
  animation: modal-motion-backdrop-out var(--modal-motion-backdrop-out-duration) ease-in both;
}
.modal-motion.is-closing {
  pointer-events: none;
  animation: modal-motion-close var(--modal-motion-close-duration) var(--modal-motion-close-easing) both;
}
@keyframes modal-motion-backdrop-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes modal-motion-backdrop-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes modal-motion-open {
  0% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--modal-open-offset-x)), calc(-50% + var(--modal-open-offset-y)))
      scale(var(--modal-open-scale-x), var(--modal-open-scale-y));
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1, 1);
  }
}
@keyframes modal-motion-swap {
  0% {
    opacity: 0.92;
    transform: translate(-50%, -50%) scale(0.985, 0.985);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1, 1);
  }
}
@keyframes modal-motion-close {
  0% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1, 1);
  }
  100% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--modal-open-offset-x)), calc(-50% + var(--modal-open-offset-y)))
      scale(var(--modal-open-scale-x), var(--modal-open-scale-y));
  }
}
.modal-content-stage {
  animation: modal-content-stage-in 240ms var(--modal-motion-open-easing) both;
}
@keyframes modal-content-stage-in {
  0% {
    opacity: 0;
    transform: translateY(8px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.modal-pdf-reader {
  width: calc(100vw - 24px);
  max-width: calc(100vw - 24px);
  height: calc(100vh - 24px);
  max-height: calc(100vh - 24px);
}
.modal.modal-knowledge-viewer {
  width: calc(100vw - 48px);
  max-width: calc(100vw - 48px);
  height: calc(100vh - 48px);
  max-height: calc(100vh - 48px);
  border-radius: var(--radius-container);
  box-shadow: var(--shadow-pop), inset 0 0 0 1px var(--rule);
}
.modal-workspace .modal-body {
  min-height: 0;
  padding: 0;
}
.modal-workspace-fit .modal-body {
  min-height: 0;
  padding: 0;
  overflow: auto;
  flex: 0 1 auto;
}
.modal-head { padding: 14px 18px; box-shadow: inset 0 -1px 0 var(--rule); display: flex; align-items: center; gap: 10px; }
.modal-title { margin: 0; font-size: 16px; font-weight: 600; letter-spacing: -0.02em; flex: 1; line-height: 1.25; }
.modal-close { margin-left: auto; }
.modal-body { padding: 16px 18px; overflow: auto; flex: 1; }
.drawer-stack { display: grid; gap: 14px; }
.modal-body-full-height { overflow: hidden; display: flex; flex-direction: column; }
.pdf-reader-modal-body {
  padding: 0;
  min-height: 0;
}
.pdf-reader-modal-frame {
  display: block;
  width: 100%;
  flex: 1;
  min-height: 0;
  border: 0;
  background: var(--surface);
}
.modal-foot { padding: 12px 18px; box-shadow: inset 0 1px 0 var(--rule); display: flex; justify-content: flex-end; gap: 8px; }
.modal-actions { padding: 12px 18px; box-shadow: inset 0 1px 0 var(--rule); display: flex; justify-content: flex-end; gap: 8px; }
@media (max-width: 720px) {
  .modal {
    min-width: 0;
    width: calc(100vw - 24px);
    max-width: calc(100vw - 24px);
  }
  .modal-workspace {
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    height: calc(100vh - 20px);
    max-height: calc(100vh - 20px);
  }
  .modal-workspace-fit {
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
  }
  .new-claim-mode-switch,
  .cac-bootstrap-hero,
  .cac-bootstrap-review-grid,
  .cac-bootstrap-facts,
  .cac-bootstrap-policy-grid,
  .cac-bootstrap-extracted-grid,
  .cac-import-success-summary {
    grid-template-columns: 1fr;
  }
  .cac-bootstrap-timeline {
    grid-template-columns: 1fr;
  }
  .cac-transfer-showcase-head,
  .cac-transfer-canvas {
    grid-template-columns: 1fr;
  }
  .cac-transfer-showcase-head {
    display: grid;
  }
  .cac-transfer-channel {
    min-height: 96px;
  }
  .cac-transfer-line {
    top: 24px;
    left: 8px;
    right: 8px;
  }
  .cac-transfer-log-row {
    grid-template-columns: 22px 20px minmax(0, 1fr) 46px;
  }
  .cac-transfer-log-cat,
  .cac-transfer-log-meta {
    display: none;
  }
  .cac-bootstrap-doc-card {
    grid-template-columns: 18px minmax(0, 1fr);
  }
  .cac-bootstrap-doc-card .chip {
    grid-column: 2;
    justify-self: start;
  }
  .cac-import-success-actions {
    justify-content: flex-start;
  }
}
@media (prefers-reduced-motion: reduce) {
  .modal-motion-backdrop,
  .modal-motion {
    animation: none;
  }
}
.notice {
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 10px;
  background: var(--surface-2);
  color: var(--text-2);
}
.notice.warn {
  border-color: #ead99c;
  background: var(--warn-soft);
  color: var(--warn);
}

/* ============================================================
 * 18. CAC STATUS
 * ============================================================ */
.cac-overview-card {
  padding: 10px;
}
.cac-card { padding: 0; box-shadow: none; border-radius: 0; background: transparent; }
.cac-status-control {
  position: relative;
  width: fit-content;
  max-width: 100%;
}
.cac-status-control-compact {
  width: 100%;
}
.cac-status-button {
  width: 100%;
  min-height: 32px;
  border: 0;
  border-radius: var(--radius-control);
  padding: 6px 9px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 7px;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  white-space: nowrap;
}
.cac-status-button:hover,
.cac-status-button:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}
.cac-status-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 50;
  width: 230px;
  padding: 6px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-pop);
}
.cac-status-menu-item {
  width: 100%;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  padding: 5px 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  cursor: pointer;
}
.cac-status-menu-item:hover,
.cac-status-menu-item:focus-visible {
  background: var(--surface-2);
  outline: none;
}
.cac-status-meta { margin-top: 8px; }
.cac-status-panel { display: flex; flex-direction: column; gap: 10px; }

/* ============================================================
 * 19. CONFIDENCE BAR
 * ============================================================ */
.confidence-bar { width: 100%; height: 3px; background: var(--surface-3); border-radius: var(--radius-pill); overflow: hidden; }
.confidence-bar-fill { height: 100%; background: var(--text); }

/* ============================================================
 * 20. STAGE STEPPER (prospects convert)
 * ============================================================ */
.stage-stepper { display: grid; grid-template-columns: auto minmax(0, 1fr); align-items: center; gap: 8px 12px; padding: 16px 24px; box-shadow: inset 0 -1px 0 var(--rule); }
.stage-stepper-track { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.stage-stepper-bar { flex: 1; min-width: 16px; height: 1px; background: var(--rule); }
.stage-stepper-bar.past { background: var(--text); }
.stage-stepper-dot { width: 20px; height: 20px; border-radius: 50%; background: var(--surface-2); color: var(--text-3); display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 500; flex-shrink: 0; }
.stage-stepper-label { font-family: var(--font-sans); font-size: 13px; color: var(--text-3); font-weight: 500; text-transform: none; letter-spacing: 0; flex-shrink: 0; }
.stage-stepper-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px 4px 4px;
  border-radius: var(--radius-pill);
  background: transparent; color: var(--text-3);
  font-size: 13px; font-weight: 500;
  border: 0; cursor: pointer; white-space: nowrap; flex-shrink: 0;
  font-family: var(--font-sans);
}
.stage-stepper-pill:hover { color: var(--text-2); }
.stage-stepper-pill.past .stage-stepper-dot { background: var(--ink); color: var(--ink-fg); }
.stage-stepper-pill.past { color: var(--text-2); }
.stage-stepper-pill.current { color: var(--text); }
.stage-stepper-pill.current .stage-stepper-dot { background: var(--ink); color: var(--ink-fg); font-weight: 600; }
.stage-stepper-desc {
  grid-column: 2;
  min-width: 0;
  color: var(--text-3);
  font-size: 12.5px;
  line-height: 1.35;
}

/* ============================================================
 * 21. CONVERT FLOW (prospects → claim)
 * ============================================================ */
.convert-form        { display: flex; flex-direction: column; gap: 14px; }
.convert-step        { padding: 14px 0; box-shadow: inset 0 -1px 0 var(--rule-soft); }
.convert-step-bar    { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.convert-step-num    { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); width: 22px; text-align: right; }
.convert-stepper     { display: flex; align-items: center; gap: 6px; }
.convert-field       { display: flex; flex-direction: column; gap: 4px; }
.convert-input,
.convert-select      { /* inherit from input/select */ }
.convert-summary     { display: flex; flex-direction: column; gap: 4px; padding: 10px 0; }
.convert-summary-row { display: flex; justify-content: space-between; gap: 10px; font-size: 13px; }
.convert-fee-card    { padding: 10px 12px; box-shadow: var(--ring-light); border-radius: var(--radius); background: var(--surface); }
.convert-economics-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.convert-fee-row     { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.convert-conflict-card  { padding: 10px 12px; box-shadow: var(--ring-light); border-radius: var(--radius); background: var(--surface); }
.convert-conflict-list  { display: flex; flex-direction: column; gap: 4px; }
.convert-conflict-row   { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 12.5px; }
.convert-conflict-result.ok  { color: var(--success); font-weight: 500; }
.convert-conflict-result.bad { color: var(--critical); font-weight: 500; }

/* ============================================================
 * 22. PROSPECT DRAWER
 * ============================================================ */
.prospect-banner {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: var(--surface-2);
  box-shadow: inset 0 -1px 0 var(--rule);
  flex-wrap: wrap;
}
.my-work-summary-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 24px;
}
.my-work-stat {
  min-width: 0;
  cursor: help;
}
.my-work-stat:focus {
  outline: none;
}
.my-work-stat:focus-visible {
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 2px var(--focus);
}
.prospect-drawer-strip  { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding: 16px 24px; box-shadow: inset 0 -1px 0 var(--rule); }
.prospect-details       { padding: 16px 24px; }
.prospect-section       { padding: 16px 0; box-shadow: inset 0 -1px 0 var(--rule-soft); }
.prospect-section:last-child { box-shadow: none; }
.prospect-section-title { font-family: var(--font-sans); font-size: 13px; text-transform: none; letter-spacing: 0; color: var(--text-3); font-weight: 500; margin-bottom: 10px; }
.prospect-section-body  { font-size: 13px; color: var(--text-2); line-height: 1.5; }
.prospect-kv            { display: grid; grid-template-columns: 100px 1fr; gap: 8px; padding: 4px 0; font-size: 13px; }
.prospect-kv-k          { color: var(--text-3); }
.prospect-kv-v          { color: var(--text); }
.prospect-textarea      { min-height: 80px; }
.prospect-notes-body    { font-size: 13px; line-height: 1.5; color: var(--text-2); }
.prospect-log           { display: flex; flex-direction: column; gap: 0; }
.prospect-log-entry     { display: grid; grid-template-columns: 80px 1fr; gap: 12px; padding: 8px 0; box-shadow: inset 0 -1px 0 var(--rule-soft); font-size: 12.5px; }
.prospect-log-marker    { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); }
.prospect-log-composer  { padding: 10px 0; }

/* ============================================================
 * 23. DIRECTORY
 * ============================================================ */
.dir-quick { display: flex; flex-direction: column; gap: 8px; }
.dir-quick-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.dir-section-title { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; color: var(--text-3); font-weight: 500; padding: 12px 0 6px; }
.dir-row { display: grid; grid-template-columns: 200px 1fr; gap: 8px; padding: 6px 0; font-size: 13px; }
.dir-row-label { color: var(--text-3); }
.dir-row-value { color: var(--text); }
.dir-org-name {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.35;
}
.dir-tag {
  display: inline-flex; align-items: center;
  padding: 1px 8px; height: 20px;
  border-radius: var(--radius-pill);
  background: #F4F4F4; color: #4D4D4D;
  font-size: 11px; font-weight: 500;
}
.dir-claim-count {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--text-2);
  font-weight: 500;
  white-space: nowrap;
}
.dir-drawer-head { padding: 14px 16px; box-shadow: inset 0 -1px 0 var(--rule); }
.dir-link-card  { padding: 10px 12px; box-shadow: var(--ring-light); border-radius: var(--radius); }
.dir-link-head  { display: flex; align-items: center; gap: 8px; }
.dir-link-list  { display: flex; flex-direction: column; gap: 0; }
.dir-link-foot  { padding-top: 8px; font-size: 12px; color: var(--text-3); }

.linked-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: center; padding: 6px 0; box-shadow: inset 0 -1px 0 var(--rule-soft); font-size: 13px; }
.linked-row-unlink { color: var(--text-3); cursor: pointer; }
.linked-row-unlink:hover { color: var(--critical); }

/* ============================================================
 * 24. ASSISTANT (panel + page)
 * ============================================================ */
.assistant-fab {
  position: fixed; bottom: 20px; right: 20px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 0 14px; height: 38px;
  background: var(--ink); color: var(--ink-fg);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-md);
  font-size: 13px; font-weight: 500;
  z-index: 65;
}
.assistant-fab:hover { background: var(--ink-hover); }
.assistant-fab-mark { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; }
.assistant-fab-kbd  { font-family: var(--font-mono); font-size: 10.5px; opacity: 0.7; padding-left: 4px; border-left: 1px solid rgba(255,255,255,0.2); margin-left: 4px; padding: 0 0 0 8px; }
.assistant-mark { width: 22px; height: 22px; border-radius: var(--radius); background: var(--ink); color: var(--ink-fg); display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600; flex-shrink: 0; }

.assistant-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 460px;
  background: var(--bg);
  box-shadow: var(--ring-light), -12px 0 32px rgba(0,0,0,0.06);
  z-index: 60;
  display: flex; flex-direction: column;
  pointer-events: none;
}
.assistant-panel :is(button, a, input, textarea, select, summary, [role="button"], [role="switch"], .conv-scroll, .assistant-panel-source, .assistant-history-popover, .modal-backdrop) {
  pointer-events: auto;
}
.assistant-panel.with-source { width: min(640px, calc(100vw - 24px)); }
.assistant-panel-head { padding: 12px 14px; box-shadow: inset 0 -1px 0 var(--rule); display: flex; flex-direction: column; gap: 8px; }
.assistant-panel-title-row { display: flex; align-items: center; gap: 8px; }
.assistant-panel-actions { display: flex; align-items: center; gap: 4px; margin-left: auto; }

.assistant-page {
  display: grid;
  grid-template-columns: clamp(190px, 20vw, 240px) minmax(0, 0.95fr) minmax(300px, 1.05fr);
  height: calc(100dvh - 73px);
  min-height: 560px;
  overflow: hidden;
}
.assistant-page-main { display: flex; flex-direction: column; min-width: 0; min-height: 0; }
.assistant-page-side { display: flex; flex-direction: column; min-width: 0; min-height: 0; overflow: hidden; background: var(--surface-2); box-shadow: inset -1px 0 0 var(--rule); }
.assistant-page-side-head { padding: 16px; box-shadow: inset 0 -1px 0 var(--rule); }
.assistant-page-source { padding: 14px; min-height: 0; overflow: auto; flex: 1; box-shadow: inset 1px 0 0 var(--rule); }
.assistant-page-workspace {
  display: flex;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: var(--surface);
  box-shadow: inset 1px 0 0 var(--rule);
}

.assistant-history { flex: 1; overflow: auto; padding: 8px; }
.assistant-history-popover { position: absolute; right: 12px; top: 44px; width: 280px; background: var(--bg); border-radius: var(--radius-lg); box-shadow: var(--shadow-pop); padding: 6px; z-index: 5; }
.assistant-source-pane { display: none; }
.assistant-panel-source {
  min-height: 180px;
  max-height: 38vh;
  display: flex;
  overflow: hidden;
  background: var(--surface);
  box-shadow: inset 0 -1px 0 var(--rule);
}

.assistant-thread-section { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.assistant-thread-section-head { padding: 12px 20px 4px; color: var(--text-3); font-size: 11px; font-weight: 600; }
.thread-list { display: flex; flex-direction: column; flex: 1; min-height: 0; gap: 1px; padding: 10px 8px 8px; }
.assistant-page-new-conversation { padding: 10px 8px 0; }
.assistant-page-new-conversation .thread-new-btn { margin-bottom: 0; }
.thread-new-btn { width: 100%; justify-content: center; margin-bottom: 6px; }
.thread-new-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.thread-items { display: flex; flex-direction: column; flex: 1; min-height: 0; gap: 1px; overflow: auto; }
.thread-item { display: flex; flex-direction: column; gap: 2px; padding: 8px 48px 8px 10px; border-radius: var(--radius); cursor: pointer; position: relative; }
.thread-item:hover { background: var(--hover-2); }
.thread-item.active { background: var(--surface-3); }
.thread-item.pinned { box-shadow: inset 2px 0 0 #b45309; }
.thread-item-title { display: flex; align-items: center; gap: 4px; min-width: 0; font-size: 12.5px; font-weight: 500; color: var(--text); overflow: hidden; }
.thread-item-title span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.thread-item-title svg { flex: 0 0 auto; color: #b45309; }
.thread-item-meta  { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 10.5px; color: var(--text-3); }
.thread-item-pin,
.thread-item-del   { position: absolute; top: 6px; opacity: 0; }
.thread-item-pin { right: 28px; }
.thread-item-del { right: 6px; }
.thread-item:hover .thread-item-pin,
.thread-item:hover .thread-item-del,
.thread-item-pin.active { opacity: 0.6; }
.thread-item-pin:hover,
.thread-item-pin.active:hover { opacity: 1; color: #b45309; }
.thread-item-del:hover { opacity: 1; color: var(--critical); }
.thread-empty { padding: 24px 12px; text-align: center; color: var(--text-3); font-size: 12px; }

.assistant-claim-picker { display: flex; flex-direction: column; gap: 8px; padding: 10px 12px; box-shadow: inset 0 -1px 0 var(--rule); }
.assistant-claim-picker.compact { gap: 7px; padding: 10px 12px 12px; }
.assistant-claim-picker.idle { padding-top: 8px; }
.assistant-claim-picker-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; min-height: 20px; }
.assistant-claim-picker-label { font-size: 11px; font-weight: 600; color: var(--text-3); }
.assistant-claim-actions { display: flex; align-items: center; gap: 2px; }
.assistant-context-add-btn { width: 100%; height: 30px; display: inline-flex; align-items: center; justify-content: center; gap: 6px; border: 0; border-radius: var(--radius); background: transparent; color: var(--text); box-shadow: var(--ring-light); font: inherit; font-size: 12.5px; font-weight: 500; cursor: pointer; }
.assistant-context-add-btn:hover,
.assistant-context-add-btn:focus-visible { background: var(--hover-2); outline: none; }
.assistant-claim-change { border: 0; border-radius: var(--radius-control); background: transparent; color: var(--text); font: inherit; font-size: 11.5px; font-weight: 500; line-height: 1; padding: 4px 5px; cursor: pointer; }
.assistant-claim-change:hover,
.assistant-claim-change:focus-visible { background: var(--hover-2); outline: none; }
.assistant-claim-picker-input { width: 100%; height: 30px; padding: 0 9px; border: 0; border-radius: var(--radius); background: var(--surface); box-shadow: var(--ring-light); font: inherit; font-size: 12.5px; outline: 0; }
.assistant-claim-picker-input:focus { box-shadow: 0 0 0 2px var(--focus); }
.assistant-claim-selected { display: flex; flex-direction: column; gap: 2px; min-width: 0; padding: 7px 8px; border-radius: var(--radius); background: var(--surface); box-shadow: inset 0 0 0 1px var(--rule); font-size: 12px; color: var(--text-2); }
.assistant-claim-selected > div { display: flex; align-items: baseline; gap: 6px; min-width: 0; }
.assistant-claim-selected-id { flex-shrink: 0; font-size: 10.5px; color: var(--text-3); }
.assistant-claim-selected-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text); font-weight: 500; }
.assistant-claim-selected-sub { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-3); font-size: 11px; }
.assistant-claim-options { display: flex; flex-direction: column; gap: 2px; max-height: 220px; overflow: auto; }
.assistant-claim-option { border: 0; border-radius: var(--radius); background: transparent; color: var(--text-2); display: grid; grid-template-columns: auto 1fr; gap: 1px 8px; padding: 7px 8px; text-align: left; font: inherit; cursor: pointer; }
.assistant-claim-option:hover,
.assistant-claim-option:focus-visible,
.assistant-claim-option.selected { background: var(--hover-2); outline: none; }
.assistant-claim-option-id { font-size: 10.5px; color: var(--text-3); grid-row: span 2; align-self: start; padding-top: 1px; }
.assistant-claim-option-main { font-size: 12.5px; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.assistant-claim-option-sub { font-size: 11px; color: var(--text-3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.assistant-claim-empty { padding: 10px 8px; text-align: center; }

/* Conversation surface */
.conv { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.conv-context-bar  { display: flex; align-items: center; gap: 6px; row-gap: 6px; padding: 10px 14px; box-shadow: inset 0 -1px 0 var(--rule-soft); flex-wrap: wrap; }
.conv-context-pill { display: inline-flex; align-items: center; gap: 5px; padding: 2px 9px; min-height: 22px; max-width: 240px; border-radius: var(--radius-pill); background: #F4F4F4; color: var(--text-2); font-size: 11.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conv-context-pill-knowledge { background: #eef2ff; color: #4338ca; }
.conv-context-pill-document  { background: #fff7ed; color: #b45309; }
.conv-context-manage {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 28px;
  padding: 0 12px;
  margin-left: auto;
  border: 0;
  border-radius: var(--radius-lg);
  background: #0f766e;
  color: #fff;
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(15, 118, 110, 0.18);
  transition: background 120ms ease;
}
.conv-context-manage:hover,
.conv-context-manage:focus-visible { background: #115e58; outline: none; }
.conv-context-manage-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.22);
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  font-family: var(--font-mono);
}
.conv-scroll       { flex: 1; overflow: auto; padding: 14px; display: flex; flex-direction: column; gap: 14px; }
.conv-empty        { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 60px 24px; text-align: center; color: var(--text-3); }
.conv-empty-mark   { width: 36px; height: 36px; border-radius: var(--radius-lg); background: var(--ink); color: var(--ink-fg); display: inline-flex; align-items: center; justify-content: center; font-weight: 600; }
.conv-empty-title  { font-size: 16px; font-weight: 600; color: var(--text); letter-spacing: -0.02em; }
.conv-empty-sub    { font-size: 12.5px; color: var(--text-3); }
.conv-fresh        { padding: 24px 16px; }
.conv-fresh-title  { font-size: 16px; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 6px; }
.conv-fresh-sub    { font-size: 12.5px; color: var(--text-3); margin-bottom: 12px; }
.conv-fresh-suggestions { display: flex; flex-direction: column; gap: 6px; }

/* ============================================================
   Manage Context modal — redesigned single-column layout
   ============================================================ */

.assistant-context-modal-v2 {
  height: min(720px, calc(100vh - 56px));
}
.assistant-context-modal-v2 .modal-body {
  padding: 0;
  overflow: hidden;
}
.assistant-context-shell {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Chip strip */
.assistant-context-strip {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px 16px;
  background: var(--surface-2);
  box-shadow: inset 0 -1px 0 var(--rule);
}
.assistant-context-strip-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-3);
  font-weight: 650;
  margin-right: 4px;
}
.assistant-context-strip-empty {
  font-size: 12px;
  color: var(--text-3);
}
.assistant-context-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text);
  font-size: 12px;
  box-shadow: inset 0 0 0 1px var(--rule);
}
.assistant-context-chip-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--text-3);
}
.assistant-context-chip-dot.kind-claim { background: #0f766e; }
.assistant-context-chip-dot.kind-document { background: #b45309; }
.assistant-context-chip-dot.kind-knowledge { background: #4338ca; }
.assistant-context-chip-detach {
  width: 18px;
  height: 18px;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: var(--text-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 2px;
  cursor: pointer;
}
.assistant-context-chip-detach:hover { background: var(--surface-3); color: var(--critical); }
.assistant-context-chip-detach:disabled { opacity: 0.5; cursor: not-allowed; }

/* Toolbar (search + tabs) */
.assistant-context-toolbar {
  padding: 12px 16px 8px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.assistant-context-search-v2 {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 12px;
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  box-shadow: inset 0 0 0 1px var(--rule);
  color: var(--text-3);
}
.assistant-context-search-v2 input {
  flex: 1;
  min-width: 0;
  height: 32px;
  border: 0;
  background: transparent;
  outline: 0;
  font: inherit;
  font-size: 13px;
  color: var(--text);
}
.assistant-context-tabs {
  display: flex;
  gap: 4px;
  overflow-x: auto;
  scrollbar-width: thin;
  padding-bottom: 2px;
}
.assistant-context-tab {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 30px;
  padding: 0 12px;
  border: 0;
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--text-2);
  font: inherit;
  font-size: 12.5px;
  font-weight: 550;
  cursor: pointer;
}
.assistant-context-tab .count {
  color: var(--text-3);
  font-size: 11px;
  font-family: var(--font-mono);
}
.assistant-context-tab:hover { background: var(--surface-2); color: var(--text); }
.assistant-context-tab.is-on { background: var(--text); color: #fff; }
.assistant-context-tab.is-on .count { color: rgba(255,255,255,0.7); }

/* List & sections */
.assistant-context-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 4px 12px 16px;
}
.assistant-context-section {
  padding-bottom: 6px;
}
.assistant-context-section-head {
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  background: var(--surface);
  padding: 12px 4px 8px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}
.assistant-context-section-head h3 {
  font-size: 12px;
  font-weight: 650;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-2);
  margin: 0;
}
.assistant-context-section-head .count {
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 11.5px;
}

/* Row */
.assistant-context-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 8px;
  border-radius: var(--radius-lg);
  min-height: 46px;
  cursor: pointer;
  user-select: none;
}
.assistant-context-row:hover { background: var(--surface-2); }
.assistant-context-row.is-included {
  background: color-mix(in srgb, #0f766e 6%, transparent);
}
.assistant-context-row.is-included:hover {
  background: color-mix(in srgb, #0f766e 10%, transparent);
}
.assistant-context-row-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--text-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 0 0 1px var(--rule-soft);
}
.assistant-context-row-icon.kind-claim { background: #f0fdfa; color: #0f766e; }
.assistant-context-row-icon.kind-document { background: #fff7ed; color: #b45309; }
.assistant-context-row-icon.kind-knowledge { background: #eef2ff; color: #4338ca; }
.assistant-context-row-copy {
  display: flex;
  flex-direction: column;
  min-width: 0;
  gap: 2px;
}
.assistant-context-row-title {
  font-size: 13px;
  font-weight: 550;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.assistant-context-row.is-included .assistant-context-row-title { color: #0f766e; }
.assistant-context-row-meta {
  font-size: 11.5px;
  color: var(--text-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Toggle switch */
.assistant-context-toggle {
  --t-w: 38px;
  --t-h: 22px;
  --t-pad: 2px;
  --t-knob: calc(var(--t-h) - var(--t-pad) * 2);
  position: relative;
  display: inline-flex;
  align-items: center;
  width: var(--t-w);
  height: var(--t-h);
  padding: 0;
  border: 0;
  border-radius: var(--radius-pill);
  background: var(--surface-3);
  box-shadow: inset 0 0 0 1px var(--rule);
  cursor: pointer;
  transition: background 160ms ease, box-shadow 160ms ease;
  flex: 0 0 auto;
}
.assistant-context-toggle::before {
  content: "";
  position: absolute;
  top: var(--t-pad);
  left: var(--t-pad);
  width: var(--t-knob);
  height: var(--t-knob);
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,0.18), 0 0 0 1px rgba(0,0,0,0.04);
  transition: transform 180ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.assistant-context-toggle:hover {
  background: color-mix(in srgb, var(--text-4) 30%, var(--surface-3));
}
.assistant-context-toggle.is-on {
  background: #0f766e;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, #0f766e 80%, transparent);
}
.assistant-context-toggle.is-on::before {
  transform: translateX(calc(var(--t-w) - var(--t-h)));
}
.assistant-context-toggle:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}
.assistant-context-toggle:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

/* Error / loading slots */
.assistant-context-error-v2 {
  margin: 0 16px 8px;
  padding: 8px 10px;
  border-radius: var(--radius);
  background: var(--critical-soft);
  color: var(--critical);
  font-size: 12px;
}
.assistant-context-loading-v2 {
  margin: 0 16px 8px;
  color: var(--text-3);
  font-size: 12px;
}

@media (max-width: 880px) {
  .assistant-context-modal-v2 { width: min(100%, calc(100vw - 24px)); }
}

/* Messages */
.msg { display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: start; }
.msg.msg-user { grid-template-columns: 1fr 28px; text-align: right; }
.msg-avatar { width: 26px; height: 26px; border-radius: var(--radius); background: var(--surface-3); display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600; color: var(--text-2); }
.msg.msg-assistant .msg-avatar { background: var(--ink); color: var(--ink-fg); }
.msg-bubble { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.msg-body  { font-size: 13.5px; line-height: 1.55; color: var(--text); }
.msg-rich { display: flex; flex-direction: column; gap: 8px; }
.msg-rich .msg-p { margin: 0; }
.msg-rich .msg-heading { margin: 4px 0 0; line-height: 1.25; font-weight: 650; letter-spacing: 0; color: var(--text); }
.msg-rich .msg-heading-1 { font-size: 17px; }
.msg-rich .msg-heading-2 { font-size: 15.5px; }
.msg-rich .msg-heading-3 { font-size: 14px; }
.msg-rich .msg-heading-4 { font-size: 13.5px; }
.msg-rich .msg-list { margin: 0; padding-left: 18px; display: flex; flex-direction: column; gap: 3px; }
.msg-rich .msg-list li { padding-left: 2px; }
.msg-rich .msg-rule { width: 100%; border: 0; border-top: 1px solid var(--rule-soft); margin: 2px 0; }
.msg-rich .msg-table-wrap { overflow-x: auto; border: 1px solid var(--rule-soft); border-radius: var(--radius-lg); background: var(--surface); }
.msg-rich .msg-table { width: 100%; border-collapse: collapse; min-width: 360px; font-size: 12.5px; }
.msg-rich .msg-table th,
.msg-rich .msg-table td { padding: 7px 9px; border-bottom: 1px solid var(--rule-soft); text-align: left; vertical-align: top; }
.msg-rich .msg-table th { background: var(--surface-2); color: var(--text); font-weight: 650; }
.msg-rich .msg-table tr:last-child td { border-bottom: 0; }
.msg-tools { display: flex; flex-direction: column; gap: 4px; }
.msg-error-actions { display: flex; align-items: center; gap: 6px; margin-top: 8px; }
.assistant-retry-btn { gap: 6px; }
.msg-citation-warning {
  margin-top: 8px;
  padding: 8px 10px;
  border: 1px solid color-mix(in srgb, var(--warn) 34%, var(--rule));
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--warn) 9%, var(--surface));
  color: var(--text);
}
.msg-citation-warning-title {
  font-size: 12px;
  font-weight: 650;
  line-height: 1.25;
}
.msg-citation-warning-text {
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.35;
  color: var(--text-2);
}
.msg-sources-foot { display: flex; flex-direction: column; gap: 4px; padding-top: 6px; box-shadow: inset 0 1px 0 var(--rule-soft); margin-top: 6px; }
.msg-sources-label { font-family: var(--font-mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0; color: var(--text-3); font-weight: 500; }
.msg-sources-list  { display: flex; flex-direction: column; gap: 2px; }
.msg-source-item   { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-2); cursor: pointer; padding: 2px 0; }
.msg-source-item:hover { color: var(--text); }
.msg-source-n     { font-family: var(--font-mono); font-size: 10.5px; color: var(--text-3); width: 16px; }
.msg-source-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Tool chips inside messages */
.tool-chip-row { display: flex; flex-direction: column; gap: 2px; }
.tool-chip {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 8px;
  background: var(--surface-2);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--text-2);
  cursor: pointer;
}
.tool-chip:hover { background: var(--surface-3); }
.tool-chip-icon { color: var(--text-3); }
.tool-chip-name { font-weight: 500; color: var(--text); }
.tool-chip-summary { color: var(--text-3); font-size: 11.5px; }
.tool-chip-caret  { margin-left: auto; opacity: 0.5; }
.tool-chip-detail { padding: 8px 10px; background: var(--surface-2); border-radius: var(--radius); margin-top: 4px; font-family: var(--font-mono); font-size: 11.5px; color: var(--text-2); white-space: pre-wrap; }

.thinking-row { display: flex; align-items: center; gap: 6px; padding: 4px 0; font-size: 12px; color: var(--text-3); }
.thinking-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--text-4); animation: thinking 1.4s infinite ease-in-out; }
.thinking-dot:nth-child(2) { animation-delay: 0.2s; }
.thinking-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes thinking { 0%, 100% { opacity: 0.3; } 50% { opacity: 1; } }

/* Composer */
.composer { box-shadow: inset 0 1px 0 var(--rule); padding: 10px 12px; display: flex; flex-direction: column; gap: 6px; }
.composer-row { display: flex; align-items: flex-end; gap: 8px; }
.composer-input {
  flex: 1; min-height: 36px; max-height: 200px;
  padding: 8px 10px;
  background: var(--surface);
  box-shadow: var(--ring-light);
  border-radius: var(--radius);
  font-size: 13px;
  resize: none; outline: 0; border: 0;
  font-family: inherit;
  line-height: 1.5;
}
.composer-input:focus { box-shadow: 0 0 0 2px var(--focus); }
.composer-send { flex-shrink: 0; }
.composer-foot { display: flex; align-items: center; gap: 6px; }
.composer-suggestions { display: flex; gap: 6px; flex-wrap: wrap; }
.composer-hint { font-size: 11px; color: var(--text-3); margin-left: auto; font-family: var(--font-mono); }
.assistant-model-toggle { display: inline-flex; align-items: center; gap: 2px; padding: 2px; border-radius: var(--radius); background: var(--surface-2); box-shadow: inset 0 0 0 1px var(--rule); flex-shrink: 0; }
.assistant-model-toggle button { min-width: 42px; height: 22px; border: 0; border-radius: var(--radius-sm); background: transparent; color: var(--text-3); font: inherit; font-size: 11px; font-weight: 600; cursor: pointer; }
.assistant-model-toggle button.active { background: var(--surface); color: var(--text); box-shadow: var(--ring-light); }
.assistant-model-toggle button:disabled { cursor: not-allowed; opacity: 0.55; }

/* Source viewer */
.source-viewer { display: flex; flex-direction: column; flex: 1; min-width: 0; max-width: 100%; min-height: 0; overflow: hidden; }
.source-viewer-head { position: sticky; top: 0; z-index: 1; padding: 12px 14px; box-shadow: inset 0 -1px 0 var(--rule); display: flex; align-items: flex-start; gap: 10px; min-width: 0; background: var(--surface); }
.source-viewer-title { font-size: 14px; font-weight: 600; letter-spacing: 0; overflow-wrap: anywhere; }
.source-viewer-sub   { font-size: 12px; color: var(--text-3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.source-viewer-meta  { display: flex; flex: 1; min-width: 0; flex-direction: column; gap: 2px; font-size: 11.5px; color: var(--text-3); }
.source-viewer-actions { display: flex; gap: 4px; margin-left: auto; min-width: 0; flex-shrink: 0; flex-wrap: wrap; justify-content: flex-end; }
.source-viewer-body { flex: 1; min-width: 0; max-width: 100%; overflow: auto; padding: 14px; }
.source-viewer-empty { padding: 60px 24px; text-align: center; color: var(--text-3); }
.source-pdf-panel {
  position: relative;
  min-height: 520px;
  height: min(72vh, 820px);
  margin-bottom: 16px;
  overflow: auto;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
}
.source-pdf-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: var(--surface);
}
.source-pdf-loading {
  display: grid;
  min-height: 100%;
  place-items: center;
  padding: 24px;
  color: var(--text-3);
  text-align: center;
}
.source-pdf-open {
  position: absolute;
  right: 12px;
  bottom: 12px;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}
.source-pdf-launch {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
}
.source-pdf-launch-title {
  font-size: 13px;
  font-weight: 600;
}
.source-pdf-launch-sub {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 12px;
}
.assistant-source-pdf-modal-body {
  padding: 0;
  min-height: 0;
}
.assistant-source-pdf-modal-tools {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--rule);
  background: var(--surface);
}
.assistant-source-highlight-reader {
  flex: 1;
  width: 100%;
  max-width: 100%;
  min-height: 0;
  overflow: auto;
  background: #f8fafc;
}
.assistant-source-highlight-reader .pdf-anchor-viewer {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
}
.assistant-source-highlight-reader .pdf-anchor-page {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.source-viewer-embedded-pdf .source-viewer-head {
  flex-wrap: wrap;
}
.source-viewer-embedded-pdf .source-viewer-body {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  min-height: 0;
  overflow: hidden;
  padding: 0;
}
.assistant-widget-pdf-tools {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--rule);
  background: var(--surface);
  overflow-x: auto;
}
.assistant-widget-pdf-reader {
  flex: 1;
  width: 100%;
  max-width: 100%;
  min-height: 0;
  overflow: auto;
  background: #f8fafc;
}
.assistant-widget-pdf-reader .pdf-anchor-viewer {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
}
.assistant-widget-pdf-reader .pdf-anchor-page {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.assistant-source-highlight-reader .pdf-anchor-toolbar,
.assistant-widget-pdf-reader .pdf-anchor-toolbar {
  min-width: 0;
}
.assistant-source-highlight-reader .pdf-anchor-layer,
.assistant-widget-pdf-reader .pdf-anchor-layer {
  width: 100%;
  overflow: hidden;
}
.assistant-source-highlight-reader .pdf-anchor-canvas,
.assistant-widget-pdf-reader .pdf-anchor-canvas {
  width: 100%;
  height: auto;
}
.assistant-source-highlight-reader .pdf-readable-text-layer,
.assistant-widget-pdf-reader .pdf-readable-text-layer,
.assistant-source-highlight-reader .pdf-readable-text-layer span,
.assistant-widget-pdf-reader .pdf-readable-text-layer span {
  overflow: hidden;
}
.assistant-widget-shell {
  position: relative;
  display: flex;
  flex: 1;
  min-width: 0;
  min-height: 0;
}
.assistant-widget-close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  background: var(--surface);
  box-shadow: var(--ring-light);
}
.assistant-workspace-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  gap: 8px;
  padding: 28px;
  text-align: center;
  color: var(--text-3);
}
.assistant-workspace-empty-title {
  color: var(--text);
  font-size: 16px;
  font-weight: 600;
}
.assistant-workspace-empty-copy {
  max-width: 240px;
  font-size: 12.5px;
  line-height: 1.45;
}
.assistant-timeline-widget {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  min-height: 0;
}
.assistant-widget-head {
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 42px 12px 16px;
  background: var(--surface);
  box-shadow: inset 0 -1px 0 var(--rule);
}
.assistant-widget-head-main {
  display: flex;
  flex-direction: column;
  gap: 9px;
  width: 100%;
  min-width: 0;
}
.assistant-widget-title {
  font-size: 15px;
  font-weight: 600;
}
.assistant-widget-sub {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11px;
}
.assistant-timeline-filters {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.assistant-timeline-filter {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 24px;
  padding: 0 7px;
  border-radius: var(--radius-pill);
  border: 0;
  background: var(--surface-2);
  color: var(--text-3);
  box-shadow: inset 0 0 0 1px var(--rule-soft);
  font: inherit;
  font-size: 10.5px;
  cursor: pointer;
}
.assistant-timeline-filter:hover,
.assistant-timeline-filter:focus-visible {
  color: var(--text);
  background: var(--hover-2);
  outline: none;
}
.assistant-timeline-filter.active {
  color: var(--text);
  background: var(--surface);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--ink) 22%, var(--rule)), 0 1px 5px rgba(15, 23, 42, 0.08);
}
.assistant-timeline-filter-dot {
  width: 7px;
  height: 7px;
  flex: 0 0 auto;
  border-radius: var(--radius-pill);
  background: var(--text-4);
}
.assistant-timeline-filter.deadline .assistant-timeline-filter-dot { background: #b45309; }
.assistant-timeline-filter.record .assistant-timeline-filter-dot { background: #0f766e; }
.assistant-timeline-filter.review .assistant-timeline-filter-dot { background: #991b1b; }
.assistant-timeline-scrubber {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14px, 1fr));
  align-items: center;
  gap: 4px;
  padding: 7px;
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  box-shadow: inset 0 0 0 1px var(--rule-soft);
}
.assistant-timeline-scrubber-dot {
  height: 8px;
  min-width: 12px;
  border: 0;
  border-radius: var(--radius-pill);
  background: #cbd5e1;
  cursor: pointer;
}
.assistant-timeline-scrubber-dot.record { background: #99f6e4; }
.assistant-timeline-scrubber-dot.deadline { background: #fcd34d; }
.assistant-timeline-scrubber-dot.review { background: #fecaca; }
.assistant-timeline-scrubber-dot.active {
  background: var(--ink);
  box-shadow: 0 0 0 2px var(--surface), 0 0 0 4px color-mix(in srgb, var(--ink) 18%, transparent);
}
.assistant-timeline-list {
  flex: 1;
  min-height: 0;
  overflow: auto;
  padding: 14px 16px 18px;
}
.assistant-timeline-item {
  display: grid;
  grid-template-columns: 82px 22px minmax(0, 1fr);
  gap: 0 8px;
  position: relative;
  min-width: 0;
  cursor: pointer;
  outline: none;
}
.assistant-timeline-item + .assistant-timeline-item { margin-top: 2px; }
.assistant-timeline-date {
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
  padding-top: 12px;
}
.assistant-timeline-date span {
  display: inline-flex;
  max-width: 100%;
  padding: 2px 0;
}
.assistant-timeline-rail {
  position: relative;
  display: flex;
  justify-content: center;
}
.assistant-timeline-rail::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: -2px;
  width: 2px;
  border-radius: var(--radius-pill);
  background: #e5e7eb;
}
.assistant-timeline-item:first-child .assistant-timeline-rail::before { top: 14px; }
.assistant-timeline-item:last-child .assistant-timeline-rail::before { bottom: calc(100% - 22px); }
.assistant-timeline-node {
  position: relative;
  z-index: 1;
  width: 12px;
  height: 12px;
  margin-top: 13px;
  border-radius: var(--radius-pill);
  background: var(--surface);
  border: 2px solid #94a3b8;
  box-shadow: 0 0 0 3px var(--surface);
}
.assistant-timeline-item.record .assistant-timeline-node { border-color: #0f766e; }
.assistant-timeline-item.deadline .assistant-timeline-node { border-color: #b45309; background: #fef3c7; }
.assistant-timeline-item.review .assistant-timeline-node { border-color: #991b1b; background: #fee2e2; }
.assistant-timeline-item.selected .assistant-timeline-node {
  background: var(--ink);
  border-color: var(--ink);
  box-shadow: 0 0 0 3px var(--surface), 0 0 0 6px color-mix(in srgb, var(--ink) 12%, transparent);
}
.assistant-timeline-card {
  min-width: 0;
  margin-bottom: 10px;
  padding: 10px 11px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  transition: border-color 120ms ease, background 120ms ease, box-shadow 120ms ease;
}
.assistant-timeline-item:hover .assistant-timeline-card,
.assistant-timeline-item:focus-visible .assistant-timeline-card {
  border-color: color-mix(in srgb, var(--ink) 22%, var(--rule));
  box-shadow: 0 1px 8px rgba(15, 23, 42, 0.06);
}
.assistant-timeline-item.selected .assistant-timeline-card {
  border-color: color-mix(in srgb, var(--ink) 35%, var(--rule));
  background: color-mix(in srgb, var(--surface) 90%, #ecfeff);
  box-shadow: 0 1px 10px rgba(15, 23, 42, 0.08);
}
.assistant-timeline-item.risk .assistant-timeline-card {
  border-left: 3px solid #d97706;
}
.assistant-timeline-item.review .assistant-timeline-card {
  border-left: 3px solid #dc2626;
}
.assistant-timeline-card-head {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 5px;
  min-width: 0;
}
.assistant-timeline-badge {
  display: inline-flex;
  align-items: center;
  height: 19px;
  padding: 0 7px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-3);
  box-shadow: inset 0 0 0 1px var(--rule-soft);
  font-size: 10.5px;
  font-weight: 650;
}
.assistant-timeline-badge.record {
  background: #ecfdf5;
  color: #0f766e;
}
.assistant-timeline-badge.deadline {
  background: #fffbeb;
  color: #92400e;
}
.assistant-timeline-badge.review {
  background: #fef2f2;
  color: #991b1b;
}
.assistant-timeline-source-count {
  min-width: 0;
  color: var(--text-3);
  font-size: 10.5px;
}
.assistant-timeline-text {
  min-width: 0;
  color: var(--text);
  font-size: 12.5px;
  line-height: 1.45;
}
.assistant-timeline-sources {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 8px;
}
.assistant-timeline-source {
  border: 0;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-2);
  box-shadow: inset 0 0 0 1px var(--rule);
  font: inherit;
  font-size: 11px;
  line-height: 1.2;
  max-width: 100%;
  padding: 3px 7px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
}
.assistant-timeline-source:hover,
.assistant-timeline-source:focus-visible {
  background: var(--hover-2);
  color: var(--text);
  outline: none;
}
.assistant-widget-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 1;
  min-height: 220px;
  color: var(--text-3);
  text-align: center;
  font-size: 12.5px;
}

.src-doc-header { padding: 10px 12px; background: var(--surface-2); border-radius: var(--radius); margin-bottom: 12px; }
.src-doc-meta   { display: grid; grid-template-columns: 100px 1fr; gap: 4px 8px; font-size: 12px; }
.src-doc-meta-k { color: var(--text-3); font-family: var(--font-mono); font-size: 11px; }
.src-doc-meta-v { color: var(--text); }
.src-page       { margin-bottom: 18px; }
.src-page-num   { font-family: var(--font-mono); font-size: 10.5px; text-transform: uppercase; color: var(--text-3); margin-bottom: 4px; }
.src-page-text  { font-size: 13px; line-height: 1.65; color: var(--text); white-space: pre-wrap; }
.src-highlight  { background: #FEF6DD; padding: 0 2px; border-radius: var(--radius-xs); }
.pdf-anchor-viewer { display: flex; flex-direction: column; gap: 8px; min-width: max-content; min-height: 0; }
.pdf-anchor-toolbar {
  position: sticky;
  z-index: 3;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 100%;
  padding: 8px 10px;
  border-bottom: 1px solid var(--rule);
  background: var(--surface-2);
}
.pdf-anchor-toolbar-pages {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.pdf-anchor-page-nav {
  border: 1px solid var(--rule);
  background: var(--surface);
  color: var(--text-2);
  border-radius: var(--radius-sm);
  padding: 3px 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  line-height: 1.3;
  cursor: pointer;
}
.pdf-anchor-page-nav:hover,
.pdf-anchor-page-nav:focus-visible {
  background: var(--surface-2);
  color: var(--text);
}
.inbox-pdf-embed-shell .pdf-anchor-page-label {
  display: none;
}
.pdf-anchor-pages {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
  box-sizing: border-box;
  overflow: auto;
  min-height: 320px;
  max-height: 62vh;
  padding: 18px;
  background: #f8fafc;
}
.pdf-anchor-page {
  position: relative;
  width: max-content;
  min-width: 100%;
  margin: 0 auto;
  background: white;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.14);
}
.pdf-anchor-page-label {
  position: absolute;
  z-index: 2;
  top: 8px;
  right: 8px;
  padding: 3px 6px;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.72);
  color: white;
  font-family: var(--font-mono);
  font-size: 10.5px;
  pointer-events: none;
}
.pdf-anchor-layer { position: relative; width: max-content; }
.pdf-anchor-canvas {
  display: block;
  width: auto;
  max-width: none;
  height: auto;
  background: white;
  filter: contrast(1.1) brightness(0.98);
}
.pdf-readable-text-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}
.pdf-readable-text-layer span {
  position: absolute;
  overflow: visible;
  color: transparent;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 600;
  line-height: 1;
  white-space: pre;
  text-shadow: none;
}
.pdf-anchor-locator {
  position: absolute;
  display: block;
  pointer-events: none;
  z-index: 3;
  min-width: 12px;
  min-height: 12px;
  border: 2px solid #2563eb;
  border-radius: 4px;
  background: rgba(37, 99, 235, 0.12);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.14), 0 2px 8px rgba(15, 23, 42, 0.2);
}
.pdf-anchor-locator::after {
  content: "";
  position: absolute;
  inset: -5px;
  border: 1px solid rgba(37, 99, 235, 0.32);
  border-radius: 7px;
}
.pdf-document-viewer {
  flex: 1;
  min-height: 0;
  overflow: auto;
  display: grid;
  justify-items: center;
  gap: 18px;
  padding: 18px;
  background: #f8fafc;
}
.pdf-document-page {
  position: relative;
  margin: 0;
  background: white;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.14);
}
.pdf-document-page img {
  display: block;
  width: auto;
  max-width: none;
  height: auto;
  filter: contrast(1.1) brightness(0.98);
}
.pdf-document-page-label {
  position: absolute;
  z-index: 2;
  top: 8px;
  right: 8px;
  padding: 3px 6px;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.72);
  color: white;
  font-size: 10.5px;
}
.review-source-open { margin-top: 6px; width: fit-content; }

/* ============================================================
 * 25. NOTES / TEMPLATES / DOC PAGE — light treatment
 * ============================================================ */
.note-actions { display: flex; gap: 6px; margin-top: 8px; }
.note-body    { font-size: 13px; line-height: 1.55; color: var(--text-2); }
.note-body p,
.note-body ul,
.note-body ol,
.note-body blockquote {
  margin: 0 0 10px;
}
.note-body p:last-child,
.note-body ul:last-child,
.note-body ol:last-child,
.note-body blockquote:last-child {
  margin-bottom: 0;
}
.note-body ul,
.note-body ol {
  padding-left: 18px;
}
.note-body blockquote {
  border-left: 2px solid var(--border-firm);
  padding-left: 10px;
  color: var(--text-3);
}
.note-body code {
  background: var(--surface-3);
  padding: 1px 4px;
  border-radius: var(--radius-control);
  font-size: 0.92em;
}
.note-mention {
  background: #E6E2D8;
  color: #5A5044;
  padding: 1px 5px;
  border-radius: var(--radius-control);
  font-weight: 500;
}
.markdown-editor {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  overflow: hidden;
}
.markdown-editor-toolbar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px;
  border-bottom: 1px solid var(--rule-soft);
  background: var(--surface-2);
}
.markdown-editor-tool {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 26px;
  padding: 0 7px;
  border: 1px solid transparent;
  border-radius: var(--radius-control);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
}
.markdown-editor-tool:hover,
.markdown-editor-tool:focus-visible {
  border-color: var(--border-firm);
  background: var(--surface);
  color: var(--text);
}
.notes-toolbar-bold {
  font-weight: 800;
}
.notes-toolbar-italic {
  font-style: italic;
}
.markdown-editor-surface {
  display: block;
  min-height: 150px;
  padding: 12px 14px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.6;
  outline: none;
  background: var(--surface);
  cursor: text;
}
.modal .markdown-editor-surface,
.drawer .markdown-editor-surface {
  min-height: 180px;
}
.markdown-editor-surface:empty::before {
  content: attr(data-placeholder);
  color: var(--text-3);
  pointer-events: none;
}
.markdown-editor-surface p,
.markdown-editor-surface ul,
.markdown-editor-surface ol,
.markdown-editor-surface blockquote {
  margin: 0 0 10px;
}
.markdown-editor-surface ul,
.markdown-editor-surface ol {
  padding-left: 18px;
}
.markdown-editor-surface blockquote {
  border-left: 2px solid var(--border-firm);
  padding-left: 10px;
  color: var(--text-3);
}
.markdown-editor-surface code {
  background: var(--surface-3);
  padding: 1px 4px;
  border-radius: var(--radius-control);
}
.directory-link-modal {
  display: grid;
  gap: 14px;
}
.directory-link-layout {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(260px, 0.9fr);
  gap: 14px;
  min-height: 340px;
}
.directory-link-results {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: auto;
  background: var(--surface);
}
.directory-link-result {
  width: 100%;
  display: grid;
  gap: 3px;
  padding: 11px 12px;
  border-bottom: 1px solid var(--rule-soft);
  text-align: left;
  color: var(--text);
}
.directory-link-result:hover,
.directory-link-result.active {
  background: var(--surface-2);
}
.directory-link-result.active {
  box-shadow: inset 3px 0 0 var(--accent);
}
.directory-link-form {
  display: grid;
  align-content: start;
  gap: 12px;
}
.directory-link-preview {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
}
@media (max-width: 760px) {
  .directory-link-layout {
    grid-template-columns: 1fr;
  }
}
.docgen-validation {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
}
.docgen-validation-block {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--rule);
  background: var(--surface-2);
}
.docgen-validation-block.critical { border-color: var(--critical); background: var(--critical-soft); color: var(--critical); }
.docgen-validation-block.warn { border-color: var(--warn); background: var(--warn-soft); color: var(--warn); }
.docgen-validation-title { display: flex; align-items: center; gap: 6px; font-weight: 600; font-size: 12.5px; color: var(--text); }
.docgen-editor-grid {
  min-height: 0 !important;
  grid-template-rows: minmax(0, 1fr);
}
.docgen-merge-panel {
  height: 100%;
  min-height: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.docgen-merge-panel::-webkit-scrollbar {
  width: 6px;
}
.docgen-merge-panel::-webkit-scrollbar-track {
  background: transparent;
}
.docgen-merge-panel::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: var(--radius-control);
}
.docgen-merge-panel::-webkit-scrollbar-thumb:hover {
  background: var(--border-firm);
}
.docgen-field-required-label::after {
  content: ' *';
  color: var(--critical);
  font-weight: 700;
}
.docgen-field-required-input {
  box-shadow: 0 0 0 1px var(--critical) !important;
  background: var(--critical-soft) !important;
}
.docgen-validation-link {
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  color: inherit;
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  display: inline;
}
.docgen-validation-link:hover {
  opacity: 0.75;
}

.notifications-tray {
  position: fixed;
  top: 58px;
  right: 18px;
  width: min(430px, calc(100vw - 36px));
  max-height: calc(100vh - 84px);
  display: flex;
  flex-direction: column;
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  z-index: 70;
}
.notifications-tray-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-height: 50px;
  padding: 10px 12px;
  box-shadow: inset 0 -1px 0 var(--rule);
  overflow: visible;
}
.notifications-tray-head .card-head-title {
  min-width: 0;
  white-space: nowrap;
}
.notifications-tray-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  min-width: 0;
}
.notifications-tray-actions .btn {
  flex: 0 0 auto;
  min-height: 28px;
  white-space: nowrap;
}
.notifications-filter-strip {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 4px;
  min-height: 44px;
  padding: 8px 10px 10px;
  overflow-x: auto;
  overflow-y: hidden;
  border-bottom: 1px solid var(--rule-soft);
  box-shadow: none;
  scrollbar-width: none;
}
.notifications-filter-strip::-webkit-scrollbar {
  display: none;
}
.notifications-filter-strip .filter-pill {
  flex: 0 0 auto;
  box-sizing: border-box;
  height: 28px;
  padding: 0 9px;
  border: 1px solid transparent;
  line-height: 1;
  box-shadow: var(--ring-light);
  white-space: nowrap;
}
.notifications-filter-strip .filter-pill.active {
  border-color: var(--text);
  box-shadow: none;
  color: var(--text);
}
.notifications-filter-strip.wide {
  padding: 0;
  box-shadow: none;
  flex-wrap: wrap;
  scrollbar-width: auto;
}
.notifications-filter-strip.wide::-webkit-scrollbar {
  display: initial;
}
.notifications-filter-strip.wide .filter-pill {
  height: 26px;
  padding: 3px 10px;
}
.notifications-tray-body {
  display: grid;
  gap: 8px;
  padding: 12px;
  overflow: auto;
}
.notifications-state {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px;
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--text-2);
}
.notifications-state.error {
  background: var(--critical-soft);
  color: var(--critical);
}
.notifications-state-title { font-weight: 600; color: var(--text); margin-bottom: 2px; }
.notification-bell-button {
  position: relative;
}
.notification-bell-badge {
  align-self: flex-start;
  min-width: 17px;
  height: 17px;
  margin-left: -14px;
  margin-right: 2px;
  padding: 0 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--critical);
  color: white;
  box-shadow: 0 0 0 2px var(--bg);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  z-index: 1;
}
.notifications-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: flex-start;
  padding: 10px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
}
.notifications-item.center {
  padding: 12px;
}
.notifications-item.unread {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--rule));
  background: color-mix(in srgb, var(--accent) 7%, var(--surface));
}
.notifications-item-main {
  appearance: none;
  border: 0;
  background: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 3px;
  min-width: 0;
  text-align: left;
  color: inherit;
  cursor: pointer;
}
.notifications-item-main:hover .notifications-item-title {
  text-decoration: underline;
  text-underline-offset: 2px;
}
.notifications-item-kicker {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 7px;
  color: var(--text-3);
  font-size: 11px;
}
.notifications-item-kicker span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.notifications-item-kicker span + span::before {
  content: "•";
  color: var(--text-4);
}
.notifications-item-title { font-size: 13px; font-weight: 600; color: var(--text); }
.notifications-item-controls {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
}
.notifications-read-toggle {
  position: relative;
  align-self: start;
  width: 28px;
  min-width: 28px;
  min-height: 24px;
  height: 24px;
  padding: 0;
  justify-content: center;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-3);
  box-shadow: none;
}
.notifications-read-toggle:hover {
  background: var(--hover);
}
.notifications-item.unread .notifications-read-toggle {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  color: var(--accent);
}
.notifications-item.unread .notifications-read-toggle:hover {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
}
.notifications-read-toggle::after {
  content: attr(data-tooltip);
  position: absolute;
  z-index: 20;
  top: 50%;
  right: calc(100% + 8px);
  max-width: 160px;
  padding: 5px 8px;
  border-radius: 6px;
  background: var(--text);
  color: var(--surface);
  font-size: 11px;
  font-weight: 500;
  line-height: 1.2;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transform: translate(4px, -50%);
  transition: opacity 120ms ease, transform 120ms ease;
}
.notifications-read-toggle:hover::after,
.notifications-read-toggle:focus-visible::after {
  opacity: 1;
  transform: translate(0, -50%);
}
.notifications-center {
  display: grid;
  gap: 14px;
}
.notifications-center-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.notifications-center-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex: 0 0 auto;
}
.notifications-center .filter-search {
  min-width: min(420px, 100%);
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  min-height: 34px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
}
.notifications-center .filter-search input {
  border: 0;
  outline: 0;
  background: transparent;
  width: 100%;
  min-width: 0;
  color: var(--text);
}
.notifications-list {
  display: grid;
  gap: 8px;
}
.alert-rules-drawer {
  display: grid;
  gap: 14px;
}
.alert-rules-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}
.alert-rules-toolbar .filter-search {
  min-height: 34px;
}
.alert-rules-create {
  white-space: nowrap;
}
.alert-rules-filters {
  grid-column: 1 / -1;
  min-height: 0;
  padding: 0;
  border-bottom: 0;
  flex-wrap: wrap;
  overflow: visible;
}
.alert-rule-editor {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--ring-light);
}
.alert-rule-editor-header,
.alert-rule-editor-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.alert-rule-editor-title {
  font-weight: 700;
  color: var(--text);
}
.alert-rule-editor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.alert-rule-enabled-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  color: var(--text);
}
.alert-rule-enabled-toggle input {
  width: 16px;
  height: 16px;
}
.alert-rule-test-panel {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.alert-rule-test-header,
.alert-rule-preview-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.alert-rule-preview-panel {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
}
.alert-rule-preview-panel.matched {
  border-color: color-mix(in srgb, var(--success) 35%, var(--rule));
}
.alert-rule-preview-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-weight: 700;
  color: var(--text);
}
.alert-rule-source-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  color: var(--accent);
  font-size: 12px;
  font-weight: 650;
  text-decoration: none;
}
.alert-rule-trace-list {
  display: grid;
  gap: 6px;
}
.alert-rule-trace-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 8px;
  padding: 8px;
  border-radius: var(--radius);
  background: var(--surface-2);
}
.alert-rule-trace-row[data-pass="true"] {
  color: var(--success);
}
.alert-rule-trace-row[data-pass="false"] {
  color: var(--danger);
}
.alert-rule-trace-title {
  color: var(--text);
  font-weight: 650;
}
.alert-rules-message {
  padding-left: 2px;
}
.alert-rules-list {
  display: grid;
  gap: 8px;
}
.alert-rule-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-bottom: 1px solid var(--rule-soft);
}
.alert-rule-row:last-child {
  border-bottom: 0;
}
.alert-rule-main {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.alert-rule-title-row,
.alert-rule-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px 8px;
  min-width: 0;
}
.alert-rule-title {
  font-weight: 650;
  color: var(--text);
}
.alert-rule-status {
  min-width: 34px;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 650;
  text-align: center;
}
.alert-rule-status[data-enabled="true"] {
  background: var(--success-soft);
  color: var(--success);
}
.alert-rule-meta {
  color: var(--text-3);
  font-size: 12px;
}
.alert-rule-meta span + span::before {
  content: "•";
  margin-right: 8px;
  color: var(--text-4);
}
.alert-rule-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  justify-content: flex-end;
  min-width: 190px;
}
.alert-rule-action-muted {
  color: var(--text-3);
  opacity: 0.72;
}
.alert-rule-action-muted[aria-disabled="true"]:hover {
  background: var(--surface-2);
  color: var(--text-3);
}
@media (max-width: 760px) {
  .notifications-center-toolbar {
    align-items: stretch;
    flex-direction: column;
  }
  .notifications-center-actions {
    justify-content: space-between;
  }
  .alert-rules-toolbar,
  .alert-rule-editor-grid {
    grid-template-columns: minmax(0, 1fr);
  }
  .alert-rule-row {
    grid-template-columns: minmax(0, 1fr);
  }
  .alert-rule-actions {
    justify-content: flex-start;
    min-width: 0;
    flex-wrap: wrap;
  }
}
.admin-rule-chip {
  margin-left: 8px;
}

.template-card {
  padding: 14px;
  box-shadow: var(--ring-light);
  border-radius: var(--radius-lg);
  background: var(--surface);
  cursor: pointer;
  display: flex; flex-direction: column; gap: 6px;
}
.template-card:hover { background: var(--hover); }

/* LexRio Word Add-In prototype */
.word-addin-modal {
  height: min(920px, calc(100vh - 32px));
}

.word-addin-modal-body {
  padding: 0;
  overflow: hidden;
}

.word-prototype-shell {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 376px;
  background: #eef1f5;
}

.word-prototype-main {
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.word-prototype-ribbon {
  min-height: 58px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: #ffffff;
  border-bottom: 1px solid #d7dce3;
}

.word-prototype-ribbon strong,
.word-addin-brand strong {
  display: block;
  color: #0f172a;
  font-weight: 700;
}

.word-prototype-ribbon span,
.word-addin-brand span {
  display: block;
  margin-top: 2px;
  color: #64748b;
  font-size: 12px;
}

.word-prototype-app-badge {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 6px;
  background: #185abd;
  color: #fff;
  font-weight: 800;
  box-shadow: inset -8px 0 0 rgba(255,255,255,0.12);
}

.word-prototype-page-wrap {
  min-height: 0;
  flex: 1;
  overflow: auto;
  padding: 28px;
}

.word-prototype-page {
  width: min(100%, 820px);
  min-height: 960px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid #d9dee6;
  box-shadow: 0 12px 32px rgba(15,23,42,0.12);
}

.word-prototype-preview,
.word-prototype-editor {
  width: 100%;
  min-height: 960px;
  margin: 0;
  padding: 72px 82px;
  border: 0;
  outline: none;
  resize: none;
  background: transparent;
  color: #1f2937;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 15px;
  line-height: 1.75;
  white-space: pre-wrap;
}

.word-addin-pane {
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: auto;
  padding: 16px;
  background: #fbfcfd;
  border-left: 1px solid #d7dce3;
}

.word-addin-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.word-addin-logo {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 6px;
  background: #087f83;
  color: #fff;
  font-weight: 800;
}

.word-addin-auth-card,
.word-addin-pane-section,
.word-addin-alert,
.word-addin-status {
  border: 1px solid #d8e0e7;
  border-radius: 8px;
  background: #fff;
}

.word-addin-auth-card {
  display: grid;
  gap: 5px;
  padding: 10px;
  color: #334155;
}

.word-addin-auth-card div {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #0f766e;
  font-weight: 700;
}

.word-addin-auth-card small {
  color: #64748b;
  font-size: 11px;
}

.word-addin-claim-table {
  display: grid;
  gap: 0;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}

.word-addin-claim-table > div {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 8px;
  padding: 8px 10px;
  border-bottom: 1px solid #edf2f7;
  font-size: 12px;
}

.word-addin-claim-table > div:last-child {
  border-bottom: 0;
}

.word-addin-claim-table span {
  color: #64748b;
}

.word-addin-claim-table strong {
  color: #1f2937;
  font-weight: 650;
  overflow-wrap: anywhere;
}

.word-addin-pane-section {
  padding: 12px;
}

.word-addin-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.word-addin-section-title {
  margin-bottom: 10px;
  color: #0f172a;
  font-size: 13px;
  font-weight: 750;
}

.word-addin-template-list {
  display: grid;
  gap: 8px;
}

.word-addin-template-button {
  display: grid;
  gap: 4px;
  width: 100%;
  padding: 10px;
  text-align: left;
  border: 1px solid #d8e0e7;
  border-radius: 8px;
  background: #fff;
  color: #1f2937;
  cursor: pointer;
}

.word-addin-template-button:hover {
  border-color: #087f83;
  background: #f1fafa;
}

.word-addin-template-button span {
  font-weight: 700;
}

.word-addin-template-button small {
  color: #64748b;
  line-height: 1.35;
}

.word-addin-template-button em {
  width: max-content;
  padding: 2px 6px;
  border-radius: 999px;
  background: #e8f3f1;
  color: #0f766e;
  font-style: normal;
  font-size: 11px;
}

.word-addin-field-group {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.word-addin-field-group-title {
  color: #64748b;
  font-size: 11px;
  font-weight: 750;
  text-transform: uppercase;
}

.word-addin-field {
  display: grid;
  gap: 5px;
}

.word-addin-field > span {
  color: #334155;
  font-size: 12px;
  font-weight: 650;
}

.word-addin-field > span b {
  color: #b42318;
}

.word-addin-field textarea {
  min-height: 96px;
}

.word-addin-alert {
  display: flex;
  gap: 8px;
  padding: 10px;
  color: #9a3412;
  background: #fff7ed;
  border-color: #fdba74;
  font-size: 12px;
  line-height: 1.4;
}

.word-addin-wide-action {
  width: 100%;
  justify-content: center;
}

.word-addin-pane-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.word-addin-pane-actions .btn {
  justify-content: center;
}

.word-addin-action-stack {
  display: grid;
  gap: 8px;
}

.word-addin-action-stack .btn {
  justify-content: flex-start;
}

.word-addin-status {
  padding: 10px;
  color: #334155;
  font-size: 12px;
  line-height: 1.45;
}

.word-launch-dialog {
  align-items: flex-start;
  display: grid;
  gap: 14px;
  grid-template-columns: 46px minmax(0, 1fr);
}

.word-launch-icon {
  align-items: center;
  background: #1455b8;
  border-radius: 6px;
  color: #fff;
  display: inline-flex;
  font-size: 22px;
  font-weight: 800;
  height: 46px;
  justify-content: center;
  width: 46px;
}

.word-launch-title {
  color: #101828;
  font-size: 16px;
  font-weight: 800;
  margin: 0 0 8px;
}

.word-launch-copy,
.word-launch-note {
  color: #475467;
  font-size: 13px;
  line-height: 1.45;
  margin: 0;
}

.word-launch-error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 6px;
  color: #991b1b;
  font-size: 13px;
  line-height: 1.45;
  margin: 10px 0 0;
  padding: 9px 10px;
}

.word-launch-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}

@media (max-width: 980px) {
  .word-prototype-shell {
    grid-template-columns: 1fr;
  }

  .word-addin-pane {
    border-left: 0;
    border-top: 1px solid #d7dce3;
  }

  .word-prototype-page-wrap {
    padding: 16px;
  }

  .word-prototype-preview,
  .word-prototype-editor {
    min-height: 620px;
    padding: 42px 28px;
  }
}

.doc-page {
  background: var(--surface);
  box-shadow: var(--ring-light);
  border-radius: var(--radius);
  padding: 24px;
  font-size: 13px;
  line-height: 1.55;
}
.document-pdf-frame {
  width: 100%;
  min-height: 520px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}
.hub-pdf-viewer {
  position: relative;
  width: 100%;
  box-sizing: border-box;
  min-height: 520px;
  max-height: calc(100vh - 240px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 16px;
  padding: 16px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-sm);
  background: #f8fafc;
}
.hub-pdf-pages {
  width: 100%;
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.hub-pdf-page {
  position: relative;
  margin: 0;
  max-width: 100%;
  background: white;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.14);
}
.hub-pdf-page-layer {
  position: relative;
  width: max-content;
  max-width: 100%;
}
.hub-pdf-page canvas {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  background: white;
  filter: contrast(1.08) brightness(0.99);
}
.hub-pdf-page-label {
  position: absolute;
  z-index: 1;
  top: 8px;
  right: 8px;
  padding: 3px 6px;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.72);
  color: white;
  font-family: var(--font-mono);
  font-size: 10.5px;
  pointer-events: none;
}
.hub-pdf-anchor-highlight {
  z-index: 2;
}

/* ============================================================
 * 26. EMPTY STATES
 * ============================================================ */
.empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px;
  padding: 60px 24px;
  text-align: center;
  color: var(--text-3);
}
.empty-state-title { font-size: 18px; font-weight: 600; color: var(--text); letter-spacing: -0.02em; }
.empty-state-sub   { font-size: 13px; color: var(--text-3); }
.empty-state-compact { padding: 24px 18px; }

.table-shell-contained .table-wrap {
  overflow: auto;
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-card);
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.stat-card {
  display: grid;
  gap: 6px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 12px;
}
.stat-card span {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.stat-card strong {
  color: var(--text);
  font-size: 24px;
  line-height: 1;
}

.overview-dashboard {
  display: grid;
  gap: var(--work-widget-row-gap);
}
.cac-import-success-summary {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) max-content;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid #CFEFDB;
  border-radius: var(--radius-lg);
  background: #F1FAF4;
}
.cac-import-success-mark {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  color: #1A7D3A;
  background: #DFF5E7;
}
.cac-import-success-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.cac-import-success-copy strong {
  font-size: 16px;
}
.cac-import-success-copy span {
  color: var(--text-2);
  overflow-wrap: anywhere;
}
.cac-import-success-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.cac-sync-feedback-summary {
  margin: 12px 16px 0;
}
.cac-sync-feedback-lines {
  margin: 8px 0 0;
  padding-left: 18px;
  color: var(--text-2);
}
.cac-sync-feedback-lines li {
  margin: 4px 0;
  display: flex;
  gap: 8px;
  align-items: baseline;
  flex-wrap: wrap;
}
.cac-sync-kind-chip,
.inbox-cac-kind-chip {
  font-size: 11px;
  white-space: nowrap;
}
.inbox-source-pane .inbox-source-cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
}
.inbox-cac-import-status {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 8px;
}
.review-flow-cac-import {
  margin-bottom: 12px;
  padding: 10px 12px;
  border: 1px solid var(--rule-soft);
  border-radius: 8px;
  background: var(--surface-2);
}
.inbox-claim-scope-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}
.overview-work-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-areas:
    "deadlines tasks"
    "appointments issues";
  column-gap: var(--work-widget-column-gap);
  row-gap: var(--work-widget-row-gap);
  margin-top: var(--work-widget-intro-gap);
}
.overview-section-deadlines { grid-area: deadlines; }
.overview-section-tasks { grid-area: tasks; }
.overview-section-appointments { grid-area: appointments; }
.overview-section-issues { grid-area: issues; }
.overview-section-timeline {
  min-width: 0;
}
.overview-section-activity { grid-area: activity; }
.overview-work-grid .overview-row-section .card-body.tight > .work-row,
.overview-work-grid .overview-row-section .card-body.tight > .list-row,
.overview-work-grid .overview-row-section .card-body.tight > .overview-activity-compact-row {
  animation: overview-row-drop-in 460ms cubic-bezier(0.18, 0.9, 0.2, 1) both;
  transform-origin: top center;
  will-change: transform, opacity;
}
.overview-work-grid .overview-row-section .card-body.tight > :nth-child(1) { animation-delay: 150ms; }
.overview-work-grid .overview-row-section .card-body.tight > :nth-child(2) { animation-delay: 192ms; }
.overview-work-grid .overview-row-section .card-body.tight > :nth-child(3) { animation-delay: 234ms; }
.overview-work-grid .overview-row-section .card-body.tight > :nth-child(4) { animation-delay: 276ms; }
.overview-work-grid .overview-row-section .card-body.tight > :nth-child(5) { animation-delay: 318ms; }
@keyframes overview-row-drop-in {
  0% {
    opacity: 0;
    transform: translateY(-18px) scale(0.985);
  }
  58% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.overview-stickies {
  min-width: 0;
}
.overview-stickies-head {
  margin-bottom: 14px;
}
.overview-stickies .claim-sticky-note {
  animation: overview-sticky-slide-in 500ms cubic-bezier(0.18, 0.9, 0.2, 1) both;
  will-change: transform, opacity;
}
.overview-stickies .claim-sticky-note:nth-child(1) { animation-delay: 210ms; }
.overview-stickies .claim-sticky-note:nth-child(2) { animation-delay: 258ms; }
.overview-stickies .claim-sticky-note:nth-child(3) { animation-delay: 306ms; }
.overview-stickies .claim-sticky-note:nth-child(4) { animation-delay: 354ms; }
@keyframes overview-sticky-slide-in {
  0% {
    opacity: 0;
    transform: translateX(-18px) rotate(var(--sticky-note-rotate, 0deg)) scale(0.988);
  }
  64% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: translateX(0) rotate(var(--sticky-note-rotate, 0deg)) scale(1);
  }
}

@media (min-width: 1920px) {
  .overview-work-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-template-areas:
      "deadlines tasks appointments issues";
  }
}

.overview-lower-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--work-widget-row-gap) var(--work-widget-column-gap);
}
.overview-lower-grid .overview-section-activity {
  grid-area: auto;
}

@media (max-width: 1080px) {
  .overview-work-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "deadlines"
      "tasks"
      "appointments"
      "issues";
  }
  .overview-lower-grid {
    grid-template-columns: 1fr;
  }
}
.overview-row-section .card-head-title {
  min-width: 0;
  letter-spacing: 0;
}
.claim-timeline-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.claim-timeline-summary span {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 2px 8px;
  border: 1px solid var(--rule-soft);
  border-radius: 999px;
  background: var(--surface-2);
}
.claim-timeline-shell {
  --claim-timeline-rail-width: 132px;
  display: grid;
  grid-template-columns: var(--claim-timeline-rail-width) minmax(0, 1fr);
  min-width: 0;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius-md);
  background: var(--surface);
  overflow: hidden;
}
.claim-timeline-rail {
  position: relative;
  z-index: 2;
  min-height: var(--claim-timeline-height, 320px);
  background: var(--surface);
  box-shadow: 1px 0 0 var(--rule-soft);
}
.claim-timeline-rail::after {
  content: "";
  position: absolute;
  top: 0;
  right: -10px;
  width: 10px;
  height: 100%;
  pointer-events: none;
  background: linear-gradient(90deg, var(--surface) 0%, rgba(255,255,255,0));
}
.claim-timeline-track-label {
  position: absolute;
  left: 14px;
  width: 104px;
  transform: translateY(-50%);
  font-size: 11px;
  line-height: 1.15;
  font-weight: 800;
  overflow-wrap: anywhere;
}
.claim-timeline-scroll {
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
}
.claim-timeline-canvas-wrap {
  position: relative;
}
.claim-timeline-canvas {
  display: block;
}
.claim-timeline-cluster-popover {
  position: absolute;
  z-index: 3;
  width: min(236px, calc(100% - 24px));
  padding: 10px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  animation: claimTimelineFoldOut 160ms ease-out;
}
.claim-timeline-cluster-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
}
.claim-timeline-cluster-head button {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border: 1px solid var(--rule-soft);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--text-2);
  font: inherit;
  line-height: 1;
  cursor: pointer;
}
.claim-timeline-cluster-list {
  display: grid;
  gap: 7px;
}
.claim-timeline-cluster-item {
  display: grid;
  gap: 2px;
  min-width: 0;
  color: var(--text);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.2;
}
.claim-timeline-cluster-item small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 650;
}
@keyframes claimTimelineFoldOut {
  from {
    opacity: 0;
    transform: translateY(-6px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.overview-section-title-link {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 0;
  font: inherit;
  text-align: left;
  cursor: pointer;
}
.overview-section-title-link:hover span,
.overview-section-title-link:focus-visible span {
  text-decoration: underline;
  text-underline-offset: 3px;
}
.overview-section-title-link:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}
.overview-section-title-link svg {
  width: var(--headline-icon-size);
  height: var(--headline-icon-size);
  flex-shrink: 0;
  color: var(--text-3);
}
.overview-section-add {
  flex-shrink: 0;
}
.overview-row-section .list-row {
  grid-template-columns: minmax(0, 1fr);
  padding-left: 2px;
  padding-right: 2px;
}
.overview-row-section .list-row-aside {
  min-width: 86px;
}
.overview-row-section .list-row-right {
  justify-content: flex-end;
  text-align: right;
}
.overview-row-section .deadline-when {
  align-items: flex-end;
  text-align: right;
}
.overview-row-section .deadline-urgency-chip {
  align-self: flex-end;
}
.overview-row-section .list-row-title {
  display: block;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.overview-activity-row .list-row-head {
  align-items: flex-start;
}
.overview-activity-title {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
  font-weight: 500;
}
.overview-activity-row .list-row-title {
  display: block;
  overflow: visible;
  font-weight: 500;
  -webkit-line-clamp: unset;
  -webkit-box-orient: initial;
}
.overview-activity-title .avatar {
  flex: 0 0 auto;
}
.overview-activity-avatar {
  inline-size: 24px;
  block-size: 24px;
  min-inline-size: 24px;
  min-block-size: 24px;
  line-height: 1;
}
.overview-activity-avatar.system {
  background: var(--surface);
  color: var(--text);
}
.overview-activity-compact-row {
  display: grid;
  grid-template-columns: 74px 24px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 36px;
  padding: 7px 10px;
  border-bottom: 1px solid var(--rule-soft);
}
.overview-activity-compact-row:hover {
  background: var(--hover);
}
.overview-activity-compact-row .activity-time {
  color: var(--text-3);
}
.overview-activity-text {
  min-width: 0;
  overflow: hidden;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 400;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 760px) {
  .metric-strip {
    grid-template-columns: 1fr;
  }
  .metric-item {
    border-right: 0;
    border-bottom: 1px solid var(--rule);
  }
  .metric-item:last-child {
    border-bottom: 0;
  }
}

/* ============================================================
 * 27. TAGS / NAMES / MISC INLINE
 * ============================================================ */
.tag-bubble {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px;
  background: var(--surface-3);
  border-radius: var(--radius-sm);
  font-size: 11.5px;
  color: var(--text-2);
}
.name { font-weight: 500; color: var(--text); }

/* ============================================================
 * 28. TWEAKS PANEL — keep visually distinct but inheriting tokens
 * ============================================================ */
.twk-panel {
  background: var(--bg);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  padding: 0;
  width: 280px;
}
.twk-hd  { padding: 10px 12px; box-shadow: inset 0 -1px 0 var(--rule); display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; }
.twk-x   { margin-left: auto; cursor: pointer; opacity: 0.6; }
.twk-x:hover { opacity: 1; }
.twk-body { padding: 8px 12px; }
.twk-sect { padding: 8px 0; }
.twk-sect + .twk-sect { box-shadow: inset 0 1px 0 var(--rule-soft); }
.twk-row  { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.twk-row-h { font-size: 11px; font-family: var(--font-mono); text-transform: uppercase; color: var(--text-3); padding: 6px 0 4px; }
.twk-field { display: flex; flex-direction: column; gap: 4px; padding: 4px 0; }
.twk-lbl   { font-size: 12px; color: var(--text-2); }
.twk-num   { display: flex; align-items: center; gap: 6px; }
.twk-num-lbl { font-size: 11px; color: var(--text-3); }
.twk-num-unit { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); }
.twk-val   { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); }
.twk-slider { flex: 1; }
.twk-toggle { width: 32px; height: 18px; border-radius: var(--radius-pill); background: var(--surface-3); position: relative; cursor: pointer; }
.twk-toggle.on { background: var(--ink); }
.twk-toggle::after { content: ''; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-sm); transition: transform 0.15s; }
.twk-toggle.on::after { transform: translateX(14px); }
.twk-seg-thumb { position: absolute; top: 0; bottom: 0; background: var(--surface); border-radius: var(--radius-control); box-shadow: var(--ring-light); transition: left 0.15s; }
.twk-swatch { width: 18px; height: 18px; border-radius: 50%; box-shadow: var(--ring-light); }

/* ============================================================
 * 29. UTILITIES / LEGACY ALIASES
 * ============================================================ */
.full     { width: 100%; }
.solid    { background: var(--ink); color: var(--ink-fg); }
.tight    { padding: 0; }
.outline  { box-shadow: var(--ring-light); }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.cluster { display: flex; align-items: center; gap: var(--space-2); }
.cluster-end { display: flex; align-items: center; justify-content: flex-end; gap: var(--space-2); }
.stack { display: flex; flex-direction: column; gap: var(--space-2); }
.truncate { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.u-flex-1 { flex: 1; min-width: 0; }
.u-ml-auto { margin-left: auto; }
.data-num { font-variant-numeric: tabular-nums lining-nums; }

@container (max-width: 1379px) {
  .claims-table {
    min-width: 1200px;
  }
  .claims-table th,
  .claims-table td {
    padding-left: 8px;
    padding-right: 8px;
  }
  .claims-table col[data-col="select"] { width: 32px; }
  .claims-table col[data-col="claim"] { width: 72px; }
  .claims-table col[data-col="lni"] { width: 92px; }
  .claims-table col[data-col="claimant"] { width: 120px; }
  .claims-table col[data-col="doi"] { width: 58px; }
  .claims-table col[data-col="tags"] { width: 92px; }
  .claims-table col[data-col="note"] { width: 100px; }
  .claims-table col[data-col="employer"] { width: 110px; }
  .claims-table col[data-col="status"] { width: 118px; }
  .claims-table col[data-col="nextAction"],
  .claims-table col[data-col="deadline"] { width: 150px; }
  .claims-table col[data-col="timeline"] { width: 96px; }
  .claims-table col[data-col="issues"] { width: 56px; }
  .claims-table col[data-col="team"] { width: 48px; }
  .claims-table col[data-col="activity"] { width: 56px; }
}

@media (max-width: 980px) {
  .header { padding: 0 12px; }
  .header-actions .search-bar { max-width: 260px; }
  .claims-table th,
  .claims-table td {
    padding-left: 8px;
    padding-right: 8px;
  }
  .claims-table col[data-col="claim"] { width: 86px; }
  .claims-table col[data-col="lni"] { width: 110px; }
  .claims-table col[data-col="claimant"] { width: 180px; }
  .claims-table col[data-col="status"] { width: 168px; }
  .inbox-table {
    min-width: 1090px;
  }
  .inbox-table col[data-col="received"] { width: 94px; }
  .inbox-table col[data-col="source"] { width: 30px; }
  .inbox-table col[data-col="from"] { width: 210px; }
  .inbox-table col[data-col="subject"] { width: 230px; }
  .inbox-table col[data-col="claim"] { width: 215px; }
  .inbox-table col[data-col="ingestion"] { width: 220px; }
  .inbox-table col[data-col="status"] { width: 112px; }
  .inbox-table th,
  .inbox-table td {
    padding-left: 8px;
    padding-right: 8px;
  }
}

@media (max-width: 760px) {
  .app { grid-template-columns: 68px 1fr; }
  .sidebar { padding-left: 8px; padding-right: 8px; }
  .sidebar-brand-name,
  .sidebar-brand-firm,
  .sidebar-section-label,
  .sidebar-item > span:not(.sidebar-item-count):not(.dot),
  .sidebar-item-count,
  .sidebar-user > div {
    display: none;
  }
  .sidebar-item { justify-content: center; padding-left: 0; padding-right: 0; }
  .stat-grid {
    grid-template-columns: 1fr;
  }
  .responsive-card-table {
    display: block;
    width: 100%;
    min-width: 0;
  }
  .app-page-scaffold,
  .app-page-body {
    height: auto;
    min-height: 100%;
    overflow: visible;
  }
  .table-shell-with-rail,
  .table-shell-with-rail > .table-wrap,
  .table-scroll-region {
    display: block;
    overflow: visible;
  }
  .widget-scroll-region {
    max-height: none;
  }
  .claim-tab-scaffold,
  .claim-tab-body {
    height: auto;
    overflow: visible;
  }
  .table-shell-with-rail .table thead th,
  .table-shell-with-rail .tbl thead th {
    position: static;
  }
  .data-view-rail {
    align-items: flex-start;
    flex-direction: column;
  }
  .responsive-card-table colgroup,
  .responsive-card-table thead {
    display: none;
  }
  .responsive-card-table tbody {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .responsive-card-table tbody tr {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 12px 14px;
    background: var(--surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--ring-light);
    cursor: pointer;
  }
  .responsive-card-table tbody tr:hover td,
  .responsive-card-table tbody tr:last-child td {
    background: transparent;
    box-shadow: none;
  }
  .responsive-card-table tbody td {
    display: grid;
    grid-template-columns: minmax(86px, 34%) minmax(0, 1fr);
    align-items: start;
    gap: 10px;
    min-width: 0;
    padding: 5px 0;
    box-shadow: none;
    background: transparent;
    font-size: 13px;
  }
  .responsive-card-table tbody td[data-align] {
    text-align: left;
  }
  .responsive-card-table tbody td::before {
    content: attr(data-label);
    min-width: 0;
    color: var(--text-3);
    font-size: 12px;
    font-weight: 500;
  }
  .responsive-card-table tbody td[data-label=""]::before,
  .responsive-card-table .card-primary::before,
  .responsive-card-table .card-control::before,
  .responsive-card-table .card-action::before,
  .responsive-card-table .table-empty-cell::before {
    content: none;
  }
  .responsive-card-table .card-primary {
    display: block;
    padding-bottom: 8px;
  }
  .responsive-card-table .card-action {
    display: none;
  }
  .responsive-card-table tbody tr.table-empty-row {
    display: block;
    padding: 0;
    background: transparent;
    box-shadow: none;
  }
  .responsive-card-table .table-empty-cell {
    display: block;
  }

  .claims-table {
    min-width: 0;
  }
  .responsive-card-table.claims-table tbody td[data-col] {
    display: grid;
  }
  .responsive-card-table.claims-table tbody td.card-control {
    display: flex;
  }
  .claims-table [data-card="select"] { order: 1; }
  .claims-table [data-card="claim"] { order: 2; }
  .claims-table [data-card="claimant"] { order: 3; }
  .claims-table [data-card="status"] { order: 4; }
  .claims-table [data-card="timeline"] { order: 5; }
  .claims-table [data-card="nextAction"] { order: 6; }
  .claims-table [data-card="deadline"] { order: 6; }
  .claims-table [data-card="lni"] { order: 7; }
  .claims-table [data-card="doi"] { order: 8; }
  .claims-table [data-card="employer"] { order: 9; }
  .claims-table [data-card="tags"] { order: 10; }
  .claims-table [data-card="note"] { order: 11; }
  .claims-table [data-card="issues"] { order: 12; }
  .claims-table [data-card="team"] { order: 13; }
  .claims-table [data-card="activity"] { order: 14; }
  .claims-table tbody tr {
    padding-right: 44px;
  }
  .claims-table tbody tr[aria-selected="true"] {
    background: var(--hover-2);
    box-shadow: var(--ring-light), inset 3px 0 0 var(--text);
  }
  .claims-table .card-control {
    position: absolute;
    top: 12px;
    right: 14px;
    display: flex;
    width: auto;
    padding: 0;
  }
  .claims-table td[data-col="timeline"] .deadline-when {
    align-items: flex-start;
    min-height: 0;
    padding: 0;
    background: transparent;
  }
  .claims-table .claim-row-overdue td[data-col="timeline"] .deadline-when {
    background: transparent;
  }
  .claims-table td[data-col="claim"],
  .claims-table td[data-col="lni"],
  .claims-table td[data-col="doi"],
  .claims-table td[data-col="timeline"],
  .claims-table td[data-col="issues"] {
    white-space: normal;
  }

  .inbox-table {
    min-width: 0;
  }
    .inbox-table [data-card="received"] { order: 1; }
    .inbox-table [data-card="source"] { order: 2; }
    .inbox-table [data-card="from"] { order: 3; }
    .inbox-table [data-card="subject"] { order: 4; }
    .inbox-table [data-card="claim"] { order: 5; }
    .inbox-table [data-card="ingestion"] { order: 6; }
    .inbox-table [data-card="status"] { order: 7; }
    .inbox-table [data-card="actions"] { order: 8; }
  .inbox-table tbody tr {
    padding-right: 44px;
  }
  .inbox-table tbody tr.selected {
    background: var(--hover-2);
    box-shadow: var(--ring-light), inset 3px 0 0 var(--text);
  }
  .inbox-table tbody tr.selected td {
    background: transparent;
    box-shadow: none;
  }
  .inbox-table .card-control {
    position: absolute;
    top: 12px;
    right: 14px;
    display: flex;
    width: auto;
    padding: 0;
  }
  .inbox-table .inbox-source-cell {
    display: block;
    padding-left: 0 !important;
  }
  .inbox-table .inbox-source-cell::before {
    content: none;
  }
  .inbox-table .inbox-sender,
  .inbox-table .inbox-subject,
  .inbox-table .inbox-claim-name {
    white-space: normal;
  }
}

/* ============================================================
 * 30. ADMIN — settings console using shared app primitives
 * ============================================================ */
.admin-panel {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.admin-filter-bar {
  gap: 8px;
  flex: 0 0 auto;
}
.admin-filter-summary {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
}
.admin-table-pad {
  padding: var(--canvas-gutter-top) var(--canvas-gutter-side);
  width: 100%;
  box-sizing: border-box;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-rhythm);
  overflow: hidden;
}
.admin-table-pad > .table-shell-with-rail {
  flex: 1;
  min-height: 0;
}
.admin-action-notice {
  flex: 0 0 auto;
}
.admin-form-body {
  padding: var(--canvas-gutter-top) var(--canvas-gutter-side);
  max-width: 1100px;
  margin: 0 auto;
}
.admin-panel > .admin-form-body:not(.admin-playbook-body):not(.admin-rules-body) {
  flex: 1;
  min-height: 0;
  width: 100%;
  overflow: auto;
  scrollbar-gutter: stable;
}
.admin-form-body.admin-playbook-body {
  max-width: none;
  width: 100%;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.admin-form-body.admin-playbook-body:has(.document-playbook-catalog.is-detail-view) {
  overflow: auto;
  scrollbar-gutter: stable;
}
.admin-form-body.admin-rules-body {
  max-width: none;
  width: 100%;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow: auto;
  scrollbar-gutter: stable;
}
.admin-rules-body > .table-shell-with-rail {
  flex: 0 0 auto;
  height: min(360px, 36vh);
  min-height: 220px;
}
.admin-rules-body .form-grid.two {
  flex: 0 0 auto;
  align-items: stretch;
}
.admin-rules-body .form-grid.two > .table-shell-with-rail {
  height: 100%;
  min-height: 240px;
}
.admin-notification-rules-panel,
.admin-alert-templates-panel {
  min-height: calc(100vh - 150px);
}
.admin-form-body.admin-notification-rules-body,
.admin-form-body.admin-alert-templates-body {
  overflow: hidden;
}
.admin-notification-rules-body > .admin-notification-rules-table,
.admin-alert-templates-body > .admin-alert-templates-table {
  flex: 1 1 auto;
  height: auto;
  min-height: 360px;
}
.admin-form-body.admin-alert-templates-body:has(.admin-alert-template-editor) {
  overflow: auto;
}
.admin-alert-templates-body:has(.admin-alert-template-editor) > .admin-alert-templates-table {
  flex: 0 0 auto;
  min-height: 280px;
}
.admin-playbook-heading {
  display: grid;
  gap: 4px;
  max-width: 760px;
  flex: 0 0 auto;
}
.admin-save-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}
.admin-table-foot {
  flex: 0 0 auto;
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--text-3);
}
.admin-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.admin-audit-search {
  flex: 1 1 360px;
  min-width: 280px;
  max-width: 560px;
}
.admin-now {
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
}
.admin-check {
  color: var(--success);
}
.admin-warn {
  color: var(--warn);
}
.admin-action-notice {
  margin-bottom: 12px;
  padding: 8px 10px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 12.5px;
}
.admin-member-actions {
  position: relative;
  display: inline-flex;
  justify-content: flex-end;
}
.admin-member-menu {
  min-width: 190px;
}
.admin-member-menu .menu-item:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}
.critical-text {
  color: var(--critical);
  font-size: 13px;
  font-weight: 500;
}
.admin-people-table th,
.admin-people-table td,
.admin-portal-table th,
.admin-portal-table td,
.admin-audit-table th,
.admin-audit-table td,
.admin-permissions-table th,
.admin-permissions-table td {
  padding-left: 12px;
  padding-right: 12px;
}
.admin-people-table .is-muted td,
.admin-portal-table .is-muted td {
  opacity: 0.6;
}
.admin-permissions-table {
  table-layout: fixed;
}
.admin-permissions-table th:not(:first-child),
.admin-permissions-table td:not(:first-child) {
  text-align: center;
}
.admin-permissions-table th:first-child,
.admin-permissions-table td:first-child {
  width: 34%;
}
.admin-permissions-table .active-role {
  background: var(--surface-2);
}
.admin-permission-group td {
  padding-top: 18px;
  padding-bottom: 8px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 500;
  background: var(--bg);
}
.admin-role-lock {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 400;
}
.permission-mark {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
}
.permission-full {
  color: var(--success);
  background: var(--success-soft);
}
.permission-limited {
  border: 1px solid var(--text-2);
  background: var(--surface);
}

@media (max-width: 760px) {
  .app-page-body > .lx-1youv2o,
  .app-page-body > .lx-1qcw925,
  .admin-panel,
  .admin-table-pad,
  .admin-panel > .admin-form-body:not(.admin-playbook-body):not(.admin-rules-body),
  .admin-form-body.admin-playbook-body,
  .admin-form-body.admin-rules-body,
  .admin-playbook-body .document-playbook-catalog,
  .admin-playbook-body .document-playbook-catalog.is-list-view .document-playbook-split,
  .admin-playbook-body .document-playbook-index,
  .admin-playbook-body .document-playbook-table-shell {
    display: block;
    height: auto;
    min-height: 0;
    overflow: visible;
  }
  .app-page-body > .my-work-root {
    display: flex;
    flex-direction: column;
    gap: var(--widget-gap);
    height: auto;
    min-height: 0;
    overflow: visible;
  }
  .admin-table-pad,
  .admin-form-body {
    padding: 16px;
  }
  .admin-rules-body > .table-shell-with-rail,
  .admin-rules-body .form-grid.two > .table-shell-with-rail {
    height: auto;
    min-height: 0;
  }
  .admin-notification-rules-panel,
  .admin-alert-templates-panel,
  .admin-form-body.admin-notification-rules-body,
  .admin-form-body.admin-alert-templates-body,
  .admin-notification-rules-body > .admin-notification-rules-table,
  .admin-alert-templates-body > .admin-alert-templates-table {
    min-height: 0;
  }
  .admin-permissions-table {
    min-width: 720px;
  }
}

/* Edit-mode overrides slot — DO NOT REMOVE */

/* === Generated static style classes: start === */
/* Generated by scripts/lift-static-inline-styles.mjs. Keep static visual values out of JSX. */

.document-editor-mount {
  min-height: 620px;
}

.doc-workspace,
.template-workspace {
  display: grid;
  gap: 16px;
}

.doc-workspace {
  grid-template-columns: minmax(0, 1fr);
  min-height: calc(100vh - 150px);
}

.doc-workspace-sidebar,
.doc-workspace-main,
.template-editor-panel,
.merge-field-panel {
  border: 1px solid var(--border);
  border-radius: var(--lex-card-radius);
  background: var(--surface);
}

.doc-workspace-sidebar {
  overflow: hidden;
}

.doc-workspace-sidebar-head,
.doc-workspace-head,
.template-workspace-head,
.merge-field-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border);
  padding: 12px;
}

.doc-workspace-main {
  min-width: 0;
  overflow: hidden;
}

.doc-workspace-head > div:first-child {
  flex: 1;
  min-width: 0;
}

.doc-workspace-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

.doc-workspace-list-item {
  display: block;
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--border);
  background: transparent;
  padding: 10px 12px;
  text-align: left;
  color: var(--text);
  cursor: pointer;
}

.doc-workspace-list-item:hover,
.doc-workspace-list-item.active {
  background: var(--surface-2);
}

.doc-workspace-list-item span,
.doc-template-list button span {
  display: block;
  font-size: 13px;
  font-weight: 650;
}

.doc-workspace-list-item small,
.doc-template-list button small {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11px;
}

.doc-template-picker {
  display: grid;
  gap: 8px;
  padding: 12px;
}

.doc-template-picker label,
.template-editor-panel label {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.doc-template-picker input,
.doc-title-input,
.merge-field-row input,
.merge-field-row select,
.template-editor-panel textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  font: inherit;
}

.doc-template-picker input,
.merge-field-row input,
.merge-field-row select {
  height: 34px;
  padding: 0 9px;
}

.doc-title-input {
  height: 38px;
  min-width: 0;
  border-color: transparent;
  padding: 0;
  font-size: 20px;
  font-weight: 720;
}

.doc-title-input:focus {
  border-color: var(--border);
  padding: 0 8px;
  outline: none;
}

.doc-template-list {
  display: grid;
  gap: 4px;
  max-height: 310px;
  overflow: auto;
}

.doc-template-list button {
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  padding: 8px;
  text-align: left;
  cursor: pointer;
}

.doc-template-list button:hover {
  border-color: var(--border);
  background: var(--surface-2);
}

.doc-title-label {
  display: block;
  margin-bottom: 2px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
  text-transform: uppercase;
}

.doc-status {
  color: var(--accent);
  font-size: 12px;
  font-weight: 650;
}

.doc-save-callout {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border);
  padding: 10px 12px;
  color: var(--text-2);
  font-size: 13px;
}

.doc-save-callout.unsaved {
  background: var(--warn-soft);
  color: var(--warn);
}

.doc-save-callout.saved {
  background: var(--surface-2);
}

.new-document-chooser {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.new-document-option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  min-height: 132px;
  border: 1px solid var(--border);
  border-radius: var(--lex-card-radius);
  background: var(--surface);
  padding: 16px;
  text-align: left;
  color: var(--text);
  cursor: pointer;
}

.new-document-option:hover {
  border-color: var(--accent);
  background: var(--surface-2);
}

.new-document-option-icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  color: var(--accent);
}

.new-document-option-title {
  font-size: 15px;
  font-weight: 720;
}

.new-document-option-copy {
  margin-top: 6px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.4;
}

.doc-editor-shell {
  background: var(--surface);
}

.doc-editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  padding: 8px 10px;
}

.doc-editor-tool {
  min-width: 30px;
  height: 28px;
  border: 1px solid transparent;
  border-radius: var(--radius-control);
  background: transparent;
  color: var(--text);
  font-size: 12px;
  font-weight: 650;
  cursor: pointer;
}

.doc-editor-tool:hover,
.doc-editor-tool.active {
  border-color: var(--border);
  background: var(--surface-2);
}

.doc-editor-divider {
  width: 1px;
  height: 18px;
  background: var(--border);
  margin: 0 4px;
}

.doc-editor-surface {
  padding: 24px 32px;
  line-height: 1.65;
  outline: none;
}

.doc-editor-surface h2,
.doc-editor-surface h3 {
  margin: 18px 0 8px;
}

.doc-editor-surface p {
  margin: 0 0 12px;
}

.merge-field-chip {
  display: inline-flex;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--warning-soft);
  padding: 1px 6px;
  color: var(--accent);
  font-family: var(--mono-font, monospace);
  font-size: 11px;
  font-weight: 700;
}

.template-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 16px;
}

.template-editor-panel,
.merge-field-panel {
  padding: 12px;
}

.template-editor-panel {
  display: grid;
  gap: 10px;
}

.template-editor-panel textarea {
  min-height: 74px;
  resize: vertical;
  padding: 9px;
}

.merge-field-panel {
  align-self: start;
  padding: 0;
}

.merge-field-row {
  display: grid;
  gap: 6px;
  border-bottom: 1px solid var(--border);
  padding: 10px;
}

.success-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--success);
  border-radius: var(--lex-card-radius);
  background: var(--success-soft);
  color: var(--success);
  padding: 8px 10px;
  font-size: 13px;
  font-weight: 650;
}

@media (max-width: 980px) {
  .doc-workspace,
  .template-grid {
    grid-template-columns: 1fr;
  }

  .doc-title-input {
    min-width: 0;
    width: 100%;
  }
}
.lx-10432yj { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.lx-106h3gy { min-width: 160px; }
.lx-109c0zu { margin-bottom: 12px; padding: 16px; border: 1.5px dashed var(--border-strong); border-radius: var(--radius); text-align: center; cursor: pointer; background: var(--surface-2); }
.claim-upload-target { display: grid; width: 100%; gap: 6px; place-items: center; color: inherit; font: inherit; }
.claim-upload-target:focus-visible { outline: 2px solid var(--focus); outline-offset: 2px; }
.inbox-upload-target { width: 100%; color: inherit; font: inherit; }
.lx-10absrh { padding: 12px; background: var(--surface-2); border: 1px dashed var(--border-strong); border-radius: var(--radius); font-size: 12px; color: var(--text-2); }
.lx-10ex0cd { font-size: 13px; color: var(--text-2); line-height: 1.6; }
.lx-10gs2lv { padding: 20px 24px; max-width: 1100px; margin: 0 auto; }
.lx-10ow05s { white-space: nowrap; font-variant-numeric: tabular-nums; }
.lx-115o4ed { margin: 0; font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.lx-11eqgpp { padding: 2px 6px; font-size: 10px; background: var(--critical); color: white; border-color: var(--critical); }
.lx-11in013 { display: flex; gap: 10px; align-items: center; padding: 14px 0 18px; border-bottom: 1px solid var(--rule); margin-bottom: 4px; }
.lx-11k3dk9 { font-size: 11.5px; padding: 3px 6px; max-width: 200px; }
.lx-11qo9zy { margin-top: 12px; padding: 10px 12px; border: 1px solid var(--rule); background: var(--surface-2); font-size: 13px; color: var(--text-3); display: flex; gap: 8px; align-items: flex-start; }
.lx-11x7u1 { display: grid; grid-template-columns: 110px 1fr; gap: 14px; padding: 10px 14px; align-items: baseline; }
.lx-11zj8z7 { border-radius: 0; border: none; border-bottom: 1px solid var(--border); }
.lx-11zmobi { font-size: 12.5px; cursor: pointer; padding: 2px 4px; margin-left: -4px; border-radius: var(--radius-control); }
.lx-123baxy { height: 18px; }
.lx-12755hc { position: absolute; top: 2px; width: 12px; height: 12px; border-radius: 50%; background: var(--bg); transition: left 120ms; box-shadow: 0 1px 2px rgba(0,0,0,0.15); }
.lx-12bwc43 { margin-bottom: 14px; line-height: 1.55; }
.lx-12gxw59 { font-size: 13px; margin-right: 8px; }
.lx-12ql7hg { background: var(--accent-soft); border-color: var(--accent); }
.lx-12rr0i1 { display: grid; border-bottom: 1px solid var(--border); background: var(--surface); }
.lx-12tzurm { font-size: 10px; }
.lx-12xbtkj { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.lx-130hxdz { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.3; }
.lx-13dbzqa { padding: 12px 0; border-bottom: 1px solid var(--rule-soft); }
.lx-13eayqs { padding: 2px; height: 20px; width: 20px; opacity: 0.55; }
.lx-13fsz0w { display: inline-flex; align-items: center; gap: 6px; }
.lx-13j9wow { display: grid; grid-template-columns: repeat(7, 1fr); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--surface); }
.lx-13n0cpr { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; }
.lx-13qiog8 { width: 100%; min-height: 100px; font-size: 13px; line-height: 1.6; font-family: inherit; }
.lx-13qvf8l { display: flex; flex-direction: column; height: 100%; }
.lx-13urlpc { background: var(--surface); border-bottom: 1px solid var(--rule); padding: 14px 32px; display: flex; align-items: center; gap: 16px; }
.lx-13y1bkz { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 24px; align-items: start; margin-top: 24px; }
.lx-13zftl7 { font-size: 12.5px; }
.lx-140j8fz { font-size: 14px; font-weight: 500; color: var(--text); font-family: var(--font-sans); }
.lx-1453qfg { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.lx-146iul6 { font-weight: 600; font-size: 13px; }
.lx-14a9i0l { white-space: pre; }
.lx-14as06g { width: 100%; }
.lx-14dyjk4 { font-size: 12px; font-weight: 500; padding-top: 2px; }
.lx-14i0x9v { color: var(--text-2); }
.lx-14oqp12 { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-14zmgyl { font-size: 13px; color: var(--text-3); margin-top: 4px; }
.lx-158g0ur { cursor: pointer; display: inline-flex; }
.lx-15kjdyn { margin-bottom: 14px; }
.lx-15nlm8x { list-style: none; padding: 0; margin: 0; }
.lx-15s4z2v { width: 30px; }
.lx-15wh22 { display: grid; grid-template-columns: 2fr repeat(4, 1fr); border-bottom: 1px solid var(--rule-firm); background: var(--surface-2); }
.lx-15yt5km { margin-left: 30px; margin-top: 4px; }
.lx-15zv1d5 { display: grid; grid-template-columns: 1fr; gap: 12px; }
.lx-160w8zc { padding: 12px; background: #FBE3E1; border: 1px solid #F2C3BF; border-radius: var(--radius); margin-bottom: 12px; }
.lx-162f4jk { min-height: 600px; }
.lx-16ash7b { font-size: 12.5px; color: var(--text-2); line-height: 1.6; font-family: var(--font-sans); }
.lx-16c9iao { color: #3F6B2C; font-size: 11px; }
.lx-16ds5qz { font-size: 13px; color: var(--text-3); font-variant-numeric: tabular-nums; }
.lx-16ic45g { margin-bottom: 10px; font-size: 11.5px; }
.lx-16kgpua { font-weight: 600; }
.lx-16lia61 { width: 100%; padding: 12px 14px; text-align: left; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); font-family: inherit; font-size: 13px; color: var(--text-3); cursor: pointer; display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.lx-16ogups { margin: 0; }
.lx-16va8l5 { text-align: right; font-family: var(--font-mono); font-size: 10px; color: #888; }
.lx-174fz5p { display: flex; align-items: center; gap: 6px; margin-left: 4px; font-size: 12px; color: var(--muted); cursor: pointer; }
.lx-17bggxq { font-size: 13px; color: var(--text-3); font-weight: 500; margin-bottom: 10px; }
.lx-17h4zbm { border: 0; background: transparent; color: var(--text-3); cursor: pointer; padding: 0; font-size: 13px; line-height: 1; display: inline-flex; align-items: center; justify-content: center; }
.lx-17ndem8 { padding: 20px 24px; max-width: 1200px; margin: 0 auto; }
.lx-17smfpk { margin-left: auto; display: flex; gap: 6px; align-items: center; }
.lx-17wbxzk { flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--rule-firm); border-radius: 50%; background: var(--surface-2); font-family: var(--font-sans); font-weight: 500; color: var(--text-2); letter-spacing: -0.02em; }
.lx-183w7x2 { margin-top: 4px; }
.lx-185jg8l { width: 26%; }
.lx-1894lob { font-size: 14px; font-weight: 600; }
.lx-18bctci { margin-top: 10px; color: var(--critical); }
.lx-18ftw77 { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.lx-18m9zba { background: var(--surface-3); color: var(--text); flex-shrink: 0; width: 40px; height: 40px; font-size: 15px; }
.lx-18mzv45 { margin-bottom: 6px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.lx-18oy9jk { margin-right: 3px; }
.lx-18tax7v { color: #DC2626; }
.lx-18upteq { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: transparent; border: 1px solid var(--text); box-shadow: inset 0 0 0 2px var(--bg); }
.lx-18w8l3b { color: var(--info); }
.lx-18xugro { font-size: 9px; }
.lx-190i90e { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; row-gap: 5px; }
.lx-191a6go { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 28px; }
.lx-192ffa0 { padding-right: 14px; display: flex; gap: 6px; }
.lx-192nege { margin-bottom: 28px; }
.lx-1931hvp { color: var(--text-3); font-family: var(--font-sans); font-weight: 400; }
.lx-196jsdo { padding: 2px; height: 24px; width: 24px; }
.lx-19bne5f { text-align: right; }
.lx-19pu6i8 { max-height: 360px; overflow: auto; border: 1px solid var(--border); border-radius: var(--radius-sm); }
.lx-19zp8k9 { font-size: 16px; margin-top: 2px; }
.lx-1aepwji { padding: 0 8px; font-size: 12px; }
.lx-1agol7r { color: var(--text-3); font-weight: 400; }
.lx-1ahrpky { display: flex; flex: 1; }
.lx-1ai8wgj { position: fixed; top: 0; right: 0; bottom: 0; width: 460px; background: var(--surface); border-left: 1px solid var(--border); box-shadow: -12px 0 32px rgba(28,30,28,0.12); z-index: 61; display: flex; flex-direction: column; overflow: hidden; }
.lx-1aimgka { display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.lx-1aqa2z9 { font-size: 10.5px; }
.lx-1aqyeg0 { border-top: 1.5px solid #444; border-bottom: 1.5px solid #444; padding: 8px 0; display: grid; grid-template-columns: 1fr 1fr; font-size: 11px; margin-bottom: 18px; }
.lx-1atu59s { font-size: 18px; font-weight: 600; letter-spacing: -0.03em; }
.lx-1axcs5o { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.lx-1ay6fbd { grid-column: span 2; display: flex; justify-content: space-between; align-items: center; padding: 16px 18px; border: 1px solid rgba(157,45,36,0.3); border-radius: var(--radius-sm); background: rgba(157,45,36,0.03); }
.lx-1b4miso { padding-top: 28px; padding-bottom: 28px; border-bottom: 1px solid var(--rule); display: grid; grid-template-columns: 240px 1fr; gap: 36px; }
.lx-1b5bjus { display: flex; gap: 8px; justify-content: flex-end; }
.lx-1bv1wp3 { margin-left: 30px; }
.lx-1bwi5gt { justify-content: center; }
.lx-1bwxfwm { font-size: 12px; color: var(--text-2); line-height: 1.55; }
.lx-1bxdilm { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.lx-1c0wkxw { color: var(--text-3); }
.lx-1c54092 { display: grid; grid-template-columns: 60px 28px 1fr 110px 130px; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--rule-soft); align-items: center; position: relative; }
.lx-1c5dypu { width: 280px; }
.lx-1c9u0c4 { padding: 2px; height: 22px; width: 22px; }
.lx-1ciko4y { padding: 10px 4px; display: flex; gap: 14px; }
.lx-1ck5u2g { color: var(--text); }
.lx-1cn1ga1 { padding: 8px 32px 40px; max-width: 880px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr; gap: 28px; }
.lx-1cs2f3y { font-size: 12.5px; color: var(--text); font-weight: 500; }
.lx-1csa4gq { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--text); }
.lx-1cvaddt { min-width: 0; }
.lx-1cytbe0 { font-weight: 600; margin-bottom: 4px; font-size: 12px; }
.lx-1cz2ubw { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--text); }
.lx-1d1ni9l { font-size: 12px; margin-bottom: 8px; }
.lx-1d47n2n { text-align: center; margin-bottom: 32px; padding-bottom: 14px; border-bottom: 1px solid #C8B89D; }
.lx-1d4jplr { padding: 14px; text-align: center; }
.lx-1d57dfu { margin-top: 28px; padding-top: 16px; border-top: 1px solid var(--border); }
.lx-1d99ihu { flex: 1; height: 1px; background: var(--rule); }
.lx-1da1zpr { width: 26px; height: 26px; background: var(--ink); color: var(--ink-fg); display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 600; }
.lx-1dadp55 { text-decoration: underline; cursor: pointer; color: #2A5C36; }
.lx-1dfcg8x { margin-bottom: 14px; padding: 10px; border: 1px solid var(--border); border-radius: var(--radius); display: flex; align-items: center; justify-content: space-between; }
.lx-1dfpu8m { margin-top: 18px; display: flex; flex-direction: column; gap: 8px; }
.lx-1ecm070 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lx-1edk8pu { font-size: 32px; font-weight: 600; margin-top: 4px; letter-spacing: -0.02em; }
.lx-1ee6kwm { display: flex; gap: 6px; margin-right: 8px; }
.lx-1ef8l4v { margin-left: auto; }
.lx-1efgia8 { font-size: 13px; font-weight: 600; }
.lx-1en0zvr { flex: 1; overflow-y: auto; padding: 16px; }
.lx-1eoyck9 { margin: 0 0 16px; font-size: 15px; font-family: var(--font-sans); line-height: 1.4; cursor: pointer; padding: 4px 6px; margin-left: -6px; border-radius: var(--radius-sm); }
.lx-1erk0np { display: flex; justify-content: flex-end; }
.lx-1ert53o { width: 80px; font-size: 12px; padding-top: 3px; }
.lx-1etrlxh { display: flex; justify-content: space-between; padding: 4px 0; }
.lx-1eu4158 { padding: 12px; background: var(--surface-2); border-radius: var(--radius); margin-bottom: 16px; border: 1px solid var(--border); }
.lx-1ey6rt6 { grid-template-columns: 1fr; }
.lx-1f2brzp { padding: 12px 8px; text-align: center; border-left: 1px solid var(--rule); font-size: 13px; font-weight: 500; color: var(--text); }
.lx-1f4ai0h { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; }
.lx-1f4eqzg { font-size: 13px; line-height: 1.65; color: var(--text); white-space: pre-wrap; }
.lx-1f4w9hr { margin-top: 10px; }
.lx-1faktg1 { padding: 40px; }
.lx-1fgb5uz { font-size: 10.5px; padding: 2px 5px; border-radius: var(--radius-xs); cursor: pointer; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-1fh0eos { padding: 12px 16px; border-top: 1px solid var(--border); display: flex; gap: 8px; justify-content: space-between; background: var(--surface-2); }
.lx-1fjvgq9 { cursor: pointer; padding: 10px 12px; border-radius: var(--radius); display: flex; gap: 10px; align-items: center; }
.lx-1fmnxnk { width: 6px; height: 24px; border-radius: var(--radius-xs); }
.lx-1fqprg2 { color: var(--text); font-weight: 500; }
.lx-1g9to1h { font-size: 12px; padding-top: 1px; }
.lx-1geuv0t { position: fixed; inset: 0; background: rgba(15,15,14,0.55); z-index: 100; display: flex; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(2px); }
.lx-1gm3eiu { font-weight: 500; color: var(--text); }
.lx-1gslzoz { font-size: 13px; font-weight: 600; margin-top: 4px; }
.lx-1gygmxf { width: 30px; text-align: right; }
.lx-1h0nr6t { display: flex; gap: 16px; font-size: 12px; color: var(--text-3); }
.lx-1h173eq { font-size: 12.5px; font-weight: 500; max-width: 520px; border: 1px solid transparent; background: transparent; padding: 4px 6px; }
.lx-1h351y2 { font-size: 22px; color: var(--text); font-weight: 600; font-variant-numeric: tabular-nums; letter-spacing: -0.02em; }
.lx-1h8u1ka { margin-top: 28px; }
.lx-1hdmh2f { padding: 16px; font-size: 13px; color: var(--text-3); }
.lx-1hdy01o { display: flex; gap: 5px; flex-wrap: wrap; }
.lx-1hh523n { display: flex; align-items: center; gap: 4px; margin-left: 8px; }
.lx-1hhst95 { background: var(--surface); }
.lx-1htijjp { color: var(--accent); cursor: pointer; }
.lx-1hxf89b { background: var(--surface-2); border-color: var(--border); margin-bottom: 14px; }
.lx-1i39uw8 { height: 100%; background: var(--accent); }
.lx-1i6yjmb { font-size: 16px; color: var(--text-3); }
.lx-1i7pkku { padding: 12px; background: #E6F4EA; border: 1px solid #C4E0CB; border-radius: var(--radius); margin-bottom: 12px; }
.lx-1i9hqy3 { font-size: 28px; font-weight: 600; letter-spacing: -0.03em; }
.lx-1ifa83x { margin-top: 3px; }
.lx-1ilh3ut { cursor: pointer; font-size: 11px; padding: 4px 9px; border: 1px solid; }
.lx-1ipyvaq { font-size: 14px; color: var(--text); font-weight: 500; font-variant-numeric: tabular-nums; }
.lx-1irkt8q { height: 36px; }
.lx-1ixltai { border-right: 1px solid var(--border); overflow: auto; padding: 14px 16px; background: var(--surface-2); }
.lx-1ixne9e { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.lx-1iyal8l { width: 11px; height: 11px; border-radius: 50%; background: #FEBC2E; }
.lx-1j0il9s { font-size: 14px; font-weight: 700; font-family: var(--font-sans); }
.lx-1j3518m { border: 1.5px solid var(--surface); }
.lx-1j3z83k { display: flex; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--rule-soft); align-items: center; }
.lx-1j83yi2 { margin-top: 32px; padding: 14px 0 4px; border-top: 1px solid var(--rule); font-size: 13px; color: var(--text-3); }
.lx-1j8tcim { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 4px; }
.lx-1jd26nw { padding: 3px; border-left: 1px solid var(--border); display: flex; flex-direction: column; gap: 2px; }
.lx-1jejltp { font-size: 13px; color: var(--text-2); }
.lx-1jemtkw { text-transform: capitalize; }
.lx-1jg6kgk { margin-top: 16px; font-size: 13px; color: var(--text-3); }
.lx-1jntcpo { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.lx-1jq1n20 { font-size: 13px; font-weight: 500; margin-bottom: 2px; }
.lx-1k5u04m { display: flex; gap: 4px; }
.lx-1kd9zl6 { position: absolute; top: 14px; left: 50%; transform: translateX(-50%); background: var(--accent); color: var(--surface); padding: 4px 12px; font-size: 13px; font-weight: 700; border-radius: var(--radius-square); z-index: 2; pointer-events: none; }
.lx-1kft18o { margin-bottom: 14px; font-size: 11.5px; }
.lx-1kl7j89 { padding: 2px; height: 22px; width: 22px; opacity: 0.5; }
.lx-1kmxu58 { display: flex; flex-direction: column; overflow: hidden; }
.lx-1knytja { position: relative; display: inline-flex; align-items: center; gap: 6px; }
.lx-1kqwd9g { font-size: 10px; color: var(--text-3); margin-top: -1px; }
.lx-1l60p0v { font-weight: 600; font-variant-numeric: tabular-nums; }
.lx-1l6olmx { margin: 8px 0; color: #666; }
.lx-1la6wd7 { display: flex; gap: 6px; margin-right: 8px; flex-wrap: wrap; }
.lx-1lamyqz { font-size: 28px; font-weight: 600; color: var(--warn); letter-spacing: -0.03em; }
.lx-1laz8in { display: flex; gap: 5px; }
.lx-1ldaw1w { padding: 10px 14px 6px; display: flex; align-items: baseline; gap: 8px; border-top: 1px solid var(--border); background: var(--surface-2); }
.lx-1ldjydn { width: 28px; height: 36px; border: 1px solid var(--border); border-radius: var(--radius-xs); font-size: 9px; display: flex; align-items: center; justify-content: center; cursor: pointer; }
.lx-1lflf4f { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.lx-1lhymtu { display: grid; grid-template-columns: 2fr 0.9fr 1.1fr 1.3fr 0.7fr 80px; gap: 14px; padding: 12px 4px; border-bottom: 1px solid var(--rule); align-items: center; }
.lx-1lrhr8t { margin-bottom: 12px; }
.lx-1lx4ljm { margin: 12px 0; font-weight: 600; }
.lx-1m1chkg { margin: 0; font-family: var(--font-sans); font-size: 20px; font-weight: 600; letter-spacing: -0.02em; color: var(--text); white-space: nowrap; }
.lx-1m6e4ib { margin-bottom: 6px; font-size: 12px; font-weight: 500; }
.lx-1mhlme6 { font-size: 13px; color: var(--text-3); }
.lx-1mj6f1 { font-size: 11.5px; font-weight: 600; }
.lx-1mjd37s { margin-top: 16px; border: 1px solid var(--rule); padding: 14px 16px; background: var(--surface); }
.lx-1mjmp94 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 24px; }
.lx-1mtups7 { font-size: 12px; margin-top: 4px; }
.lx-1mxbtto { padding: 24px 24px 32px; max-width: 1100px; margin: 0 auto; position: relative; }
.lx-1mxen47 { padding: 12px 16px; font-size: 13px; color: var(--text-2); font-weight: 500; }
.lx-1mxqgdl { font-size: 12.5px; font-weight: 500; }
.lx-1mzhn5v { font-size: 13px; font-weight: 500; color: var(--text-2); }
.lx-1n7xfl7 { font-size: 9.5px; }
.lx-1n86ihy { font-size: 12px; color: var(--text-3); font-weight: 500; margin-bottom: 6px; }
.lx-1nbt6mh { padding: 12px 14px; }
.lx-1ncm6m2 { width: 6px; height: 6px; border-radius: 50%; background: #3F6B2C; }
.lx-1neh5hc { display: flex; gap: 6px; align-items: center; }
.lx-1nery57 { font-size: 13px; color: var(--text-3); line-height: 1.45; min-height: 36px; }
.lx-1nhpum { font-weight: 400; color: var(--text-3); margin-left: 6px; font-size: 13px; }
.lx-1niyjgz { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; box-shadow: inset 0 -1px 0 var(--rule); padding-bottom: 12px; }
.lx-1njkp9i { display: flex; gap: 12px; flex-wrap: wrap; }
.lx-1ntbvbi { padding: 24px 28px; border: 1px solid var(--rule-firm); border-radius: var(--radius-sm); background: var(--surface); position: relative; margin-bottom: 8px; }
.lx-1nueubk { font-size: 13px; margin-top: 4px; }
.lx-1nwu4wn { color: var(--warn); font-size: 12.5px; }
.lx-1nzd5xv { font-family: var(--font-sans); font-size: 26px; font-weight: 500; line-height: 1; }
.lx-1o1aftr { font-size: 12px; font-weight: 600; color: #2A5C36; margin-bottom: 4px; display: flex; align-items: center; gap: 4px; }
.lx-1o2bfu8 { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.lx-1o2gls5 { position: absolute; top: 14px; right: 16px; font-size: 12px; color: var(--text-3); }
.lx-1o800n6 { display: flex; gap: 6px; align-items: center; margin-bottom: 3px; }
.lx-1ocgly3 { display: flex; gap: 6px; margin-top: 4px; }
.lx-1oj6g0e { padding: 14px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
.lx-1ojm8c7 { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 10px; }
.lx-1ok41eg { padding: 8px 10px; font-size: 11px; text-align: center; border-left: 1px solid var(--border); }
.lx-1ok986p { padding: 24px; text-align: center; color: var(--text-3); }
.lx-1oojx8h { font-size: 13px; color: var(--warn, #B58200); }
.lx-1ooyt6r { text-align: center; padding: 40px; color: var(--muted); font-size: 13px; }
.lx-1ordblo { display: flex; justify-content: center; gap: 6px; margin-top: 12px; }
.lx-1owbooy { display: grid; grid-template-columns: 120px 1fr auto; gap: 16px; align-items: flex-start; }
.lx-1oya5rt { opacity: 0.6; }
.lx-1p0vuy0 { accent-color: var(--accent); }
.lx-1p2c6a6 { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 4px; }
.lx-1p5mj5z { font-size: 14px; font-weight: 500; margin-top: 4px; }
.lx-1p6sxll { position: relative; }
.lx-1pe8pfc { margin-top: 16px; color: #A02D24; font-weight: 600; }
.lx-1peob7i { font-size: 11px; color: var(--text-3); margin-top: 2px; line-height: 1.45; }
.lx-1pl9z5v { margin-top: 10px; color: var(--warn); }
.lx-1plb8ui { flex: 1; min-width: 0; }
.lx-1plp1w7 { color: var(--accent); font-weight: 500; }
.lx-1pvl1nt { display: flex; align-items: center; justify-content: space-between; }
.lx-1q2fdww { display: inline-flex; gap: 4px; align-items: center; }
.lx-1q64kww { margin: 0; padding: 0; list-style: none; font-size: 12px; color: var(--text-2); }
.lx-1qcnwtm { border: 1px solid var(--rule); background: var(--surface); position: relative; }
.lx-1qcw925 { padding: 24px; display: flex; flex-direction: column; gap: 16px; }
.lx-1qcyz0s { font-size: 10px; color: #666; margin-top: 2px; }
.lx-1qgmd29 { font-size: 12.5px; font-weight: 500; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-1qirer0 { margin-top: 2px; }
.lx-1qjnf86 { background: white; max-width: 720px; margin: 0 auto; padding: 60px 80px; min-height: 900px; box-shadow: 0 1px 3px rgba(0,0,0,0.08), 0 8px 24px rgba(0,0,0,0.06); font-size: 12px; line-height: 1.7; color: #1A1814; }
.lx-1qkzao4 { font-size: 10.5px; padding: 1px 4px; border-radius: var(--radius-xs); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text); }
.lx-1qrfbf0 { border-bottom: 1px solid var(--border); }
.lx-1qvjok5 { position: absolute; top: 80px; left: 14px; background: white; border: 1px solid var(--border); border-radius: var(--radius); box-shadow: 0 6px 16px rgba(0,0,0,0.12); padding: 4px; z-index: 10; min-width: 200px; }
.lx-1qw2ud1 { padding: 2px 6px; font-size: 11px; }
.lx-1qx34ee { text-align: center; font-size: 14px; margin: 0 0 18px; text-transform: uppercase; letter-spacing: 1px; }
.lx-1qz5ttn { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.lx-1r06904 { flex: 1; overflow-y: auto; padding: 0 24px 24px; }
.lx-1r30yeq { color: var(--accent); margin-top: 2px; }
.lx-1r3qz1x { display: grid; grid-template-columns: 1fr 36px; gap: 10px; padding: 8px 0; cursor: pointer; align-items: flex-start; border-bottom: 1px dashed var(--rule-soft); }
.lx-1r3t4bu { font-size: 13px; color: var(--text-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-1r8yoti { font-size: 12px; color: var(--accent); }
.lx-1r90pa4 { margin-top: 4px; line-height: 1.55; }
.lx-1rfh2z8 { font-weight: 500; text-transform: capitalize; font-size: 12.5px; }
.lx-1rftwyp { margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--rule-soft); display: flex; gap: 8px; justify-content: flex-end; }
.lx-1rj57uk { line-height: 1.3; margin-top: 1px; }
.lx-1rk1e8z { margin-top: 24px; padding: 12px 0; border-top: 1px solid var(--rule); font-size: 13px; color: var(--text-3); }
.lx-1rkct7 { position: relative; flex: 1; max-width: 320px; }
.lx-1rq0xz6 { color: var(--muted); }
.lx-1ru3gis { margin-top: 1px; color: var(--text-3); flex-shrink: 0; }
.lx-1s1blyj { grid-template-columns: 1fr 1fr; }
.lx-1s2cdiw { display: grid; grid-template-columns: 380px 1fr; gap: 0; height: calc(100vh - 160px); min-height: 600px; margin-left: -20px; margin-right: -20px; margin-bottom: -20px; }
.lx-1s3gd5j { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--rule); }
.lx-1s3x5yc { padding: 16px 16px 14px; cursor: pointer; position: relative; border-radius: var(--radius-sm); }
.lx-1s5kf3g { margin-left: 8px; }
.lx-1sb536q { background: var(--surface-2); padding: 24px; overflow-y: auto; border-right: 1px solid var(--border); }
.lx-1sf0b27 { color: var(--text); font-weight: 500; font-style: normal; font-family: var(--font-sans); }
.lx-1smckht { font-size: 12px; color: var(--text-3); margin-top: 4px; line-height: 1.5; }
.lx-1spkxmg { text-align: center; font-size: 12px; font-weight: 500; margin-bottom: 4px; }
.lx-1t1k9dr { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.lx-1t1tyz1 { padding: 24px 24px 32px; max-width: 1200px; margin: 0 auto; }
.lx-1t4cdz5 { padding: 0 8px; font-size: 11px; }
.lx-1t68xah { font-size: 11.5px; width: 20px; height: 20px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; }
.lx-1tct2r4 { display: flex; flex-direction: column; align-items: flex-end; gap: 5px; flex-shrink: 0; }
.lx-1tdkrw8 { font-size: 12.5px; color: var(--text-2); line-height: 1.5; }
.lx-1tfn5t1 { font-weight: 500; }
.lx-1tomx14 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; padding: 14px 18px; background: var(--surface-2); border: 1px solid var(--rule); }
.lx-1u6vxkq { padding: 6px 10px; font-size: 12px; color: var(--text-3); border-right: 1px solid var(--border); }
.lx-1ubvxlc { display: flex; flex-direction: column; gap: 2px; }
.lx-1ud3bac { padding: 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 8px; }
.lx-1ufdtsf { padding: 2px 6px; font-size: 11px; height: auto; min-width: 120px; }
.lx-1uy79w1 { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
.lx-1uyekm7 { position: relative; border-left: 1px solid var(--border); min-width: 0; overflow: hidden; }
.lx-1v490es { text-align: center; margin-bottom: 24px; font-size: 11px; color: #888; }
.lx-1vn1q3j { margin-top: 2px; color: var(--text-3); }
.lx-1vpuogs { margin-bottom: 6px; }
.lx-1vrxp02 { height: 22px; width: 22px; padding: 0; }
.lx-1vsoqjc { display: inline-block; width: 7px; height: 7px; border-radius: 50%; border: 1px solid var(--text); }
.claim-identity-header {
  display: grid;
  gap: var(--claim-header-tab-gap);
  padding: 12px 20px var(--claim-header-tab-gap);
  background: var(--page-header-bg);
  box-shadow: inset 0 -1px 0 var(--rule);
}
.claim-identity-main {
  display: flex;
  gap: 18px;
  align-items: center;
}
.claim-primary-tabs {
  width: fit-content;
  max-width: 100%;
}
.claim-tab-navigation {
  position: relative;
  z-index: 70;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: var(--claim-nav-group-gap);
  row-gap: var(--claim-nav-group-gap);
  min-width: 0;
  max-width: 100%;
  overflow: visible;
}
.claim-wide-tabs,
.claim-work-scope-group {
  flex: 0 0 auto;
}
.claim-work-scope-group {
  order: 1;
  display: inline-flex;
  align-items: stretch;
  max-width: 100%;
  min-width: 0;
}
.claim-wide-icon-tabs {
  order: 2;
}
.claim-work-scope-group .claim-work-tabs {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.claim-work-scope-group .claim-issue-scope {
  margin-left: -1px;
}
.claim-work-scope-group .claim-issue-scope-button {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.claim-wide-icon-tabs .tab svg {
  flex: 0 0 auto;
}
.claim-issue-scope {
  position: relative;
  z-index: 80;
  flex: 0 0 auto;
  perspective: 720px;
}
.claim-issue-scope-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: var(--tabs-control-height);
  max-width: 260px;
  padding: 6px 10px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-tab-track);
  background: linear-gradient(180deg, var(--surface-2) 0%, var(--surface-3) 100%);
  color: var(--text);
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  cursor: pointer;
  transition:
    background 250ms ease,
    border-color 250ms ease,
    box-shadow 250ms ease,
    color 150ms ease;
}
.claim-issue-scope-button:hover,
.claim-issue-scope-button:focus-visible,
.claim-issue-scope-button[aria-expanded="true"] {
  border-color: var(--text-2);
  background: var(--surface-2);
  color: var(--text);
}
.claim-issue-scope-button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--text-2) 12%, transparent);
}
.claim-issue-scope-button:active {
  transform: translateY(0.5px);
}
.claim-issue-scope-button.is-scoped {
  border-color: transparent;
  background: var(--filter-active-bg);
  color: var(--text);
  font-weight: 600;
}
.claim-issue-scope-button.is-scoped:hover,
.claim-issue-scope-button.is-scoped:focus-visible,
.claim-issue-scope-button.is-scoped[aria-expanded="true"] {
  border-color: transparent;
  background: var(--filter-active-bg-hover);
  color: var(--text);
}
.claim-issue-scope-button.is-scoped:focus-visible {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--filter-active-text) 14%, transparent);
}
.claim-issue-scope-button span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.claim-issue-scope-menu {
  position: absolute;
  z-index: 90;
  top: calc(100% + 6px);
  left: 50%;
  width: min(340px, calc(100vw - 40px));
  max-height: 340px;
  overflow: auto;
  padding: 6px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-tab-track);
  background: var(--surface);
  box-shadow: var(--shadow-pop);
  transform-origin: top center;
  transform: translateX(-50%);
  backface-visibility: hidden;
  will-change: transform, opacity;
  animation: claim-issue-scope-menu-unfurl 210ms cubic-bezier(0.32, 0, 0.15, 1);
}
.claim-issue-scope-option {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  border: 0;
  border-radius: var(--radius-control);
  background: transparent;
  color: var(--text-2);
  font: inherit;
  font-size: 13px;
  text-align: left;
  cursor: pointer;
}
.claim-issue-scope-option:hover,
.claim-issue-scope-option.active {
  background: var(--surface-2);
  color: var(--text);
}
.claim-issue-scope-divider {
  height: 1px;
  margin: 5px 2px;
  background: var(--rule-soft);
}
@media (max-width: 900px) {
  .claim-tab-navigation {
    align-items: stretch;
    flex-direction: column;
  }
  .claim-work-scope-group {
    width: fit-content;
  }
  .claim-issue-scope {
    width: fit-content;
  }
}
.lx-1vszg8f { background: var(--surface); border-radius: var(--radius); padding: 12px 14px; margin-bottom: 10px; position: relative; }
.notes-thread-surface {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
.notes-toolbar {
  width: 100%;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule-soft);
}
.notes-list {
  display: grid;
  gap: 14px;
  width: 100%;
}
.notes-list .note-card {
  width: 100%;
  margin: 0;
  padding: 18px 20px;
  border-radius: var(--radius-lg);
}
.notes-empty {
  border: 1px dashed var(--rule);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  margin-top: 2px;
}
@media (max-width: 760px) {
  .claim-tab-body:has(> .notes-tab-wrap) {
    padding: 16px;
  }
  .notes-list .note-card {
    padding: 14px;
  }
  .notes-list .note-card .lx-1jntcpo {
    align-items: flex-start;
  }
}
.lx-1vyz7j9 { font-size: 13px; color: var(--text-3); font-weight: 400; }
.lx-1w5p3xe { padding: 10px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: var(--surface); }
.lx-1wd0yn { font-size: 12.5px; color: var(--text-2); line-height: 1.5; margin-bottom: 6px; }
.lx-1wiau7g { width: 1px; height: 18px; background: var(--rule); margin: 0 6px; }
.lx-1wibw2u { display: grid; grid-template-columns: 70px 1fr; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--rule-soft); align-items: flex-start; }
.lx-1wl6f2a { display: grid; grid-template-columns: 2fr 0.9fr 1.1fr 1.3fr 0.7fr 80px; gap: 14px; padding: 8px 4px; border-bottom: 1px solid var(--rule-firm); font-size: 13px; color: var(--text-3); font-weight: 600; }
.lx-1wo6dpv { margin-top: 24px; padding: 12px; background: #f7f5ee; border-left: 3px solid #888; font-size: 10.5px; color: #555; }
.lx-1x2d82t { font-size: 13.5px; color: var(--text-3); }
.lx-1x2ddj4 { font-size: 12px; padding: 2px 8px; }
.lx-1x462w2 { padding: 11px 8px; text-align: center; border-left: 1px solid var(--rule-soft); }
.lx-1xasd0i { font-size: 12px; color: var(--text-3); text-align: right; font-variant-numeric: tabular-nums; }
.lx-1xdkl5c { margin-left: auto; display: flex; gap: 6px; }
.lx-1xo4npw { margin-top: 3px; font-size: 12px; font-weight: 500; }
.lx-1xqcmk { padding: 14px 18px 12px; border-bottom: 1px solid var(--rule-soft); display: flex; align-items: center; gap: 10px; }
.lx-1xuydp0 { width: 24px; height: 24px; background: var(--ink); color: var(--ink-fg); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 600; }
.lx-1xyv7zi { width: 1px; height: 14px; background: var(--rule); margin: 0 4px; }
.lx-1y1vehm { font-size: 16px; font-weight: 500; }
.lx-1y8nq6e { display: grid; grid-template-columns: 1.6fr 2fr 1fr 1fr 1.2fr 0.6fr 32px; gap: 14px; padding: 10px 12px; background: var(--surface-2); border-bottom: 1px solid var(--rule-firm); font-size: 13px; color: var(--text-2); font-weight: 500; }
.lx-1y9etd7 { font-size: 13px; color: var(--text-3); font-weight: 600; }
.lx-1yk3y5y { font-size: 13px; margin-top: 6px; color: var(--text-2); }
.lx-1ykj9q9 { padding-top: 2px; }
.lx-1ym802k { margin-top: 4px; font-weight: 500; }
.lx-1youv2o { flex: 1; overflow: auto; }
.lx-1yu7255 { font-size: 10px; border: 1px solid ' + kindMeta.color + '40; }
.lx-1yym02c { font-size: 15px; font-weight: 600; color: var(--text); letter-spacing: -0.01em; }
.lx-1yzk104 { padding: 2px 6px; font-size: 10px; }
.lx-206twp { text-transform: uppercase; letter-spacing: 0.04em; font-size: 10.5px; font-weight: 500; padding-top: 2px; }
.lx-28v4rf { padding: 24px; }
.lx-29dqv8 { padding: 8px; border-right: 1px solid var(--border); min-height: 100px; min-width: 0; overflow: hidden; }
.lx-2d7i85 { margin-top: 14px; padding: 10px 12px; border: 1px solid var(--rule); background: var(--surface-2); font-size: 11.5px; color: var(--text-3); display: flex; gap: 8px; align-items: flex-start; }
.lx-2fqhni { font-size: 15px; font-family: var(--font-sans); line-height: 1.4; min-height: 80px; }
.lx-2fqvnd { font-size: 13.5px; font-weight: 500; color: var(--text); line-height: 1.4; }
.lx-2ka3h8 { display: flex; gap: 8px; justify-content: flex-end; margin-top: 18px; }
.lx-2sfy7l { font-size: 14px; color: var(--text); line-height: 1.55; font-family: var(--font-sans); }
.lx-2ua71w { font-size: 14px; color: var(--text-2); line-height: 1.6; max-width: 640px; }
.lx-2x3xb3 { display: flex; flex-direction: column; gap: 5px; }
.lx-31ty98 { font-size: 14px; font-weight: 500; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-3ekypt { display: flex; flex-wrap: wrap; gap: 4px; }
.lx-3ii0tz { border: none; height: 22px; padding: 0 4px; flex: 1; min-width: 80px; }
.lx-3it9ax { font-size: 12px; color: var(--text-3); margin-top: 12px; }
.lx-3kv8xh { margin: 0; font-size: 25px; font-weight: 600; letter-spacing: -0.03em; line-height: 1.08; white-space: nowrap; font-family: var(--font-sans); }
.lx-3nk282 { padding: 18px; }
.lx-3oajou { font-size: 11.5px; margin-left: auto; }
.lx-44gqqs { line-height: 1.55; white-space: pre-wrap; }
.lx-486ani { font-size: 14px; }
.lx-48c9rw { display: flex; gap: 2px; }
.lx-4bd0q0 { padding: 5px 12px; border-radius: var(--radius-sm); font-size: 13px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; }
.lx-4dpnr0 { display: flex; align-items: center; gap: 8px; }
.lx-4pxtfe { padding: 8px 0; font-size: 11.5px; }
.lx-4s020j { padding: 10px 0 10px 16px; vertical-align: top; text-align: center; }
.lx-51qana { padding: 14px; }
.lx-569beu { display: none; }
.lx-56hac0 { width: 4px; align-self: stretch; border-radius: var(--radius-xs); }
.lx-5f7j30 { color: var(--success); font-size: 12.5px; }
.lx-5glqob { display: flex; align-items: baseline; gap: 6px; margin-bottom: 6px; }
.lx-5gn3fb { font-weight: 400; color: var(--text-3); }
.lx-5n0lrk { display: flex; gap: 10px; align-items: flex-start; }
.lx-5vb2e2 { margin-top: 12px; width: 100%; justify-content: center; }
.lx-5x44o { color: var(--text-3); font-size: 13px; }
.lx-6388hj { font-size: 12.5px; color: var(--text-2); }
.lx-6a726j { font-size: 11px; font-weight: 600; color: #A02D24; margin-bottom: 4px; }
.lx-6kjcpa { padding: 12px 18px; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: 6px; }
.lx-6l8ozy { font-style: normal; }
.lx-6mewdd { padding: 60px; text-align: center; color: var(--text-3); }
.lx-6ots5a { display: flex; gap: 6px; align-items: center; font-size: 12.5px; height: 28px; }
.lx-6uv99l { font-size: 13px; color: var(--text-3); font-weight: 500; margin-bottom: 8px; }
.lx-6vq0ca { display: grid; border-bottom: 1px solid var(--border); min-height: 28px; }
.lx-70ukvn { padding: 14px 18px; }
.lx-74nlwa { display: grid; grid-template-columns: repeat(7, 1fr); }
.lx-75gl5h { display: flex; gap: 6px; margin-bottom: 8px; }
.lx-779col { font-size: 10px; font-weight: 500; margin-bottom: 8px; }
.lx-7i5fiq { font-size: 12.5px; min-height: 60px; }
.lx-7m4qr1 { font-size: 12px; color: var(--text-3); margin-top: 6px; line-height: 1.45; }
.lx-7nvw0z { font-size: 28px; font-weight: 600; line-height: 1; margin-top: 2px; }
.lx-7tiv7o { font-family: var(--font-sans); font-size: 13px; color: var(--text-3); font-weight: 500; }
.lx-7vvzhu { margin-top: 8px; }
.lx-7ydnf { margin-bottom: 18px; }
.lx-7yukf9 { padding: 5px 0; display: flex; gap: 8px; align-items: center; }
.lx-7zz5u7 { display: flex; align-items: baseline; gap: 12px; padding-bottom: 14px; border-bottom: 1px solid var(--rule-firm); margin-bottom: 18px; flex-wrap: wrap; row-gap: 8px; }
.lx-80cguk { line-height: 1.45; }
.lx-81u855 { font-size: 10px; color: var(--text-3); }
.lx-86ltd8 { flex: 1; overflow: auto; padding: 24px; background: #E5DDD0; }
.lx-8agnn4 { padding: 20px 28px; font-size: 13px; color: var(--text); line-height: 1.7; white-space: pre-wrap; font-family: var(--font-sans); }
.lx-8bce8n { padding: 0 28px 22px; }
.lx-8md9g9 { font-size: 10.5px; padding: 2px 4px; margin-bottom: 2px; border-radius: var(--radius-xs); cursor: pointer; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-8qn5o2 { display: inline-block; padding: 10px 22px; background: var(--ink); color: var(--ink-fg); font-size: 13px; font-weight: 500; text-decoration: none; border-radius: var(--radius-xs); letter-spacing: 0.01em; }
.lx-8qopa8 { margin-left: 4px; }
.lx-8qsa4h { color: var(--text-2); font-weight: 500; }
.lx-8wphtz { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; align-items: center; }
.lx-8xt68c { padding: 8px 12px; border-bottom: 1px solid var(--border); cursor: pointer; font-size: 12px; }
.lx-91b5n2 { margin-top: 28px; font-size: 10px; color: #7A6D5C; text-align: right; }
.lx-975loh { font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; padding: 1px 5px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--muted); font-weight: 500; }
.lx-9ktnme { margin-top: 8px; padding: 10px; background: var(--surface-2); border-radius: var(--radius); }
.lx-9o5wnn { background: var(--critical); border-color: var(--critical); }
.lx-9omh4x { padding: 0 6px; font-size: 11px; white-space: nowrap; }
.lx-9w4qw9 { flex: 1; font-size: 12.5px; color: var(--text); }
.lx-a1qfvx { width: 10px; height: 10px; background: var(--critical-soft); border-left: 3px solid var(--critical); }
.lx-a4r6kj { font-size: 12px; color: var(--text-3); text-align: right; }
.lx-a9plws { width: 100%; max-width: 1080px; max-height: 92vh; background: var(--surface); box-shadow: 0 20px 60px rgba(0,0,0,0.4); display: flex; flex-direction: column; overflow: hidden; border: 1px solid var(--rule-firm); }
.lx-a9wos0 { width: 100%; padding-left: 30px; height: 32px; font-size: 13px; }
.lx-aa638o { display: grid; grid-template-columns: 1.6fr 2fr 1fr 1fr 1.2fr 0.6fr 32px; gap: 14px; padding: 14px 12px; border-bottom: 1px solid var(--rule); align-items: center; }
.lx-agdbdw { background: var(--accent); }
.lx-ahzg9m { background: var(--surface-3); padding: 8px 14px; border-bottom: 1px solid var(--rule-firm); display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.lx-ai0ed { background: white; max-width: 720px; margin: 0 auto; padding: 60px 80px; min-height: 900px; box-shadow: 0 1px 3px rgba(0,0,0,0.08), 0 8px 24px rgba(0,0,0,0.06); }
.lx-aqsq6g { display: flex; align-items: baseline; gap: 10px; padding: 10px 14px 8px; border-bottom: 1px solid var(--rule); }
.lx-aw1520 { font-size: 11px; color: var(--text-3); }
.lx-awwlkw { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--rule-soft); }
.lx-azg1du { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; color: var(--text); }
.lx-bf89sg { display: flex; align-items: baseline; gap: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--rule-firm); margin-bottom: 4px; }
.lx-bh2b54 { display: flex; gap: 6px; }
.lx-bn9dd9 { font-size: 13px; text-align: right; }
.lx-bsa9bg { font-size: 12.5px; margin-top: 6px; }
.lx-builys { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--text-3); }
.lx-bxy65q { display: inline-flex; align-items: center; gap: 4px; }
.lx-byd3nj { font-size: 13px; font-weight: 500; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-cdgdpi { flex: 1; font-size: 12.5px; }
.lx-chi0i7 { margin-top: 10px; font-size: 12px; color: var(--text-3); }
.lx-ckcso4 { width: 64px; text-align: center; font-variant-numeric: tabular-nums; }
.lx-cs0063 { font-size: 13.5px; font-weight: 600; }
.lx-cwu228 { min-width: 0; font-size: 13px; color: var(--text-2); line-height: 1.5; }
.lx-cxw6ye { padding: 24px 24px 32px; max-width: 1100px; margin: 0 auto; }
.lx-d0ysxz { background: var(--surface-2); border-color: var(--border); }
.lx-d1000j { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.lx-dbrbcw { flex: 1; padding: 4px 14px; background: var(--bg); border-radius: var(--radius-sm); border: 1px solid var(--rule); font-size: 13px; color: var(--text-3); display: flex; align-items: center; gap: 8px; }
.lx-dhceq5 { font-size: 10px; opacity: 0.7; }
.lx-ditxih { display: flex; gap: 14px; padding: 12px 0 4px; font-size: 12px; color: var(--text-3); flex-wrap: wrap; align-items: center; }
.lx-dluzdw { display: grid; gap: 10px; }
.lx-dsumfl { border: 1px solid var(--rule); background: var(--surface-2); padding: 14px 16px; }
.lx-dx6av7 { width: 55%; padding: 10px 0; vertical-align: top; border-right: 1px solid #1A1814; padding-right: 16px; }
.lx-e1p0df { margin-top: 20px; border: 1px solid var(--rule); background: var(--surface); }
.lx-e9rsti { display: block; font-size: 13px; color: var(--text-2); font-weight: 500; margin-bottom: 6px; }
.lx-edlr4p { display: flex; gap: 6px; align-items: center; margin-bottom: 12px; flex-wrap: wrap; }
.lx-ehrhpl { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.lx-ejetig { font-size: 12px; color: var(--text-3); font-weight: 500; margin-bottom: 4px; }
.lx-ejkaud { font-size: 13px; }
.lx-elltgp { display: inline-flex; align-items: center; gap: 6px; padding: 3px 9px; border: 1px solid var(--rule-firm); border-radius: var(--radius-control); font-size: 12px; font-weight: 500; background: var(--surface-2); }
.lx-erb4sm { white-space: pre-line; }
.lx-esn9v4 { width: 200px; font-size: 12.5px; }
.lx-esvzol { white-space: nowrap; }
.lx-eti4iq { display: block; font-size: 11px; color: var(--text-3); font-weight: 400; margin-top: 2px; }
.lx-ewift { flex: 1; font-size: 12px; color: #DC2626; }
.lx-exlz2m { color: #3F6B2C; }
.lx-ezreld { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 28px; border: 1px solid var(--rule); background: var(--surface); }
.lx-f2j629 { text-align: center; padding: 40px; color: var(--muted); }
.lx-f3nhlu { text-align: center; font-size: 11px; margin-bottom: 18px; }
.lx-f6e1j4 { background: transparent; }
.lx-ffaape { padding: 14px; max-width: 880px; margin: 0 auto; }
.notes-thread-surface.lx-ffaape { padding: 0; max-width: none; margin: 0; }
.lx-flrfh5 { padding: 14px 18px; border-right: 1px solid var(--rule); }
.lx-flrvjp { display: grid; grid-template-columns: 90px 4px 1fr auto; gap: 12px; padding: 10px 12px; border-top: 1px solid var(--border); cursor: pointer; align-items: flex-start; }
.lx-fqtfep { font-size: 12.5px; color: var(--text); cursor: pointer; min-height: 18px; padding: 2px 4px; margin-left: -4px; border-radius: var(--radius-control); }
.lx-frodw7 { padding: 20px; }
.lx-fw2l3x { display: flex; align-items: center; gap: 8px; padding: 6px 8px; width: 100%; background: transparent; border: none; cursor: pointer; font-family: inherit; font-size: 12px; text-align: left; }
.lx-g5vc8i { font-weight: 500; margin-top: 2px; }
.lx-g8til0 { margin-top: 22px; }
.lx-g9td40 { margin-top: 18px; margin-bottom: 8px; font-weight: 500; text-decoration: underline; font-size: 12px; }
.lx-gf5mn9 { display: flex; gap: 6px; justify-content: flex-end; margin-top: 8px; }
.lx-gfuet3 { display: flex; gap: 0; row-gap: 4px; font-size: 12px; color: var(--text-3); margin-top: 3px; flex-wrap: wrap; align-items: center; }
.lx-gjza0 { padding: 12px; background: #FBE3E1; border: 1px solid #F2C3BF; border-radius: var(--radius); display: flex; gap: 10px; align-items: center; }
.lx-gkn6vu { margin: 0 6px; }
.lx-glywfu { font-size: 13px; color: var(--text-3); font-weight: 600; margin-bottom: 8px; }
.lx-grf17i { margin-left: 6px; }
.lx-h3abd4 { font-size: 13px; min-height: 90px; line-height: 1.5; font-family: inherit; }
.lx-h4mlzt { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lx-h669rl { display: flex; gap: 24px; margin-top: 16px; font-size: 13px; color: var(--text-2); flex-wrap: wrap; }
.lx-hg3r3d { margin-bottom: 12px; background: var(--surface-2); border-color: var(--border); }
.lx-hlbdjj { display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.lx-ho4xph { padding: 20px 14px; font-size: 12px; color: var(--text-3); font-family: var(--font-sans); text-align: center; }
.lx-hojevg { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.lx-hr1uzg { font-size: 12px; font-weight: 600; color: #A02D24; margin-bottom: 4px; }
.lx-hzp4mz { padding: 5px 0; display: flex; gap: 8px; }
.lx-i6it7h { height: 40px; }
.lx-i8f53x { padding: 36px 32px 24px; max-width: 880px; margin: 0 auto; }
.lx-ilhuhf { font-size: 13px; color: var(--text-3); font-weight: 500; padding: 8px 14px 4px; }
.lx-iqtl2k { min-height: 104px; padding: 6px; cursor: pointer; min-width: 0; overflow: hidden; }
.lx-j1mhkr { padding: 10px 12px; border-bottom: 1px solid var(--border); display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.lx-j66r9p { display: flex; align-items: center; gap: 10px; }
.lx-jh378x { border-top: 1px solid var(--rule); padding: 20px 32px; max-width: 880px; margin: 0 auto; text-align: center; font-size: 13px; color: var(--text-3); }
.lx-ji59mb { font-size: 14px; color: var(--text); font-weight: 500; }
.lx-jk66v5 { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.lx-jmpm8y { padding: 8px 12px; border-bottom: 1px solid var(--border); display: grid; grid-template-columns: auto 1fr auto; gap: 8px; align-items: center; }
.lx-jq4luk { width: 100%; justify-content: center; margin-top: 10px; }
.lx-jqba7q { padding: 8px 0; border-bottom: 1px solid var(--border); display: grid; grid-template-columns: 110px 1fr auto; gap: 10px; align-items: flex-start; }
.lx-jwrel1 { border-color: rgba(157,45,36,0.4); color: var(--critical); }
.lx-k4xskl { display: flex; align-items: baseline; gap: 12px; margin-bottom: 10px; }
.lx-k5gvwl { font-size: 13px; color: var(--text-2); text-align: right; }
.lx-kbpaku { margin-bottom: 8px; }
.lx-kd3v7a { font-size: 12px; font-weight: 500; white-space: nowrap; }
.lx-kfgv96 { color: var(--warn); margin-left: 6px; }
.lx-kijswb { font-size: 10px; color: #52525B; margin-top: 4px; }
.lx-kjd79j { font-size: 12px; color: var(--text-3); }
.lx-kmq3yz { display: flex; align-items: baseline; gap: 10px; }
.lx-ku8rve { display: flex; gap: 24px; margin-bottom: 12px; }
.lx-ky9yva { padding: 11px 16px; font-size: 13px; color: var(--text-2); }
.lx-l10jcj { margin-bottom: 10px; }
.lx-l42jsa { color: var(--critical); }
.lx-l459y { border-top: 1px solid #1A1814; width: 240px; padding-top: 4px; }
.lx-le9tjt { display: grid; grid-template-columns: 2fr repeat(4, 1fr); border-top: 1px solid var(--rule-soft); align-items: center; }
.lx-lhi6q2 { font-size: 13px; color: var(--text-3); font-weight: 500; padding: 12px 14px 4px; }
.lx-liz352 { background: var(--critical); color: white; border-color: var(--critical); }
.lx-lnkopf { border: 1px solid var(--rule); border-radius: var(--radius-sm); overflow: hidden; }
.lx-lpj9au { font-size: 32px; font-weight: 600; margin-top: 4px; }
.lx-lpoogo { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.lx-lql403 { display: flex; align-items: baseline; gap: 10px; min-width: 0; white-space: nowrap; }
.lx-ltg5jr { display: flex; flex-wrap: wrap; gap: 6px; }
.lx-lttbef { width: 100%; min-height: 130px; font-size: 13px; line-height: 1.6; font-family: inherit; resize: vertical; border: none; padding: 4px; }
.lx-ltwmow { font-size: 11.5px; }
.lx-lwx9fb { display: flex; align-items: center; gap: 6px; font-size: 12px; }
.lx-m1tiiz { display: flex; flex-direction: column; gap: 10px; }
.lx-m91apm { position: relative; display: grid; }
.lx-maples { font-weight: 500; margin-bottom: 8px; }
.lx-mba11l { width: 140px; }
.lx-mfaben { display: flex; align-items: center; gap: 10px; min-width: 0; }
.lx-mgx2c9 { margin-bottom: 16px; }
.lx-mozcyn { font-size: 12.5px; color: var(--text); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lx-mrs45z { padding: 12px 28px; border-top: 1px solid var(--rule-soft); font-size: 12px; color: var(--text-3); background: var(--surface-2); }
.lx-msnoxj { display: flex; gap: 8px; margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border); align-items: center; flex-wrap: wrap; }
.lx-mtpthz { font-family: var(--font-sans); font-size: 12.5px; line-height: 1.55; }
.lx-mwhyiq { margin-bottom: 16px; font-size: 12.5px; color: var(--text-2); line-height: 1.5; }
.lx-mzava6 { font-size: 12px; font-weight: 500; }
.lx-n17r6i { margin-top: 8px; display: flex; align-items: center; }
.lx-n2o3bq { font-size: 12px; color: var(--text-3); font-variant-numeric: tabular-nums; }
.lx-n7ajl9 { position: fixed; inset: 0; background: rgba(28,30,28,0.32); z-index: 60; }
.lx-nbq4if { border-top: 1px solid var(--border); padding-top: 12px; }
.lx-ncr22 { opacity: 0.85; }
.lx-nds3by { display: grid; grid-template-columns: 1.6fr 1fr; gap: 24px; align-items: flex-start; }
.lx-ndydwe { display: grid; grid-template-columns: 140px 1fr; padding: 7px 0; border-bottom: 1px dashed var(--border); font-size: 12.5px; }
.lx-nnaqba { height: 32px; font-size: 13px; }
.lx-np8shd { border: 1px solid var(--rule-firm); background: var(--surface); position: relative; }
.lx-nqezzu { flex: 1; height: 14px; background: var(--surface-2); border-radius: var(--radius-control); overflow: hidden; }
.lx-nza3rp { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.lx-o43o0j { width: 11px; height: 11px; border-radius: 50%; background: #28C840; }
.lx-odd25k { padding: 16px; }
.lx-ogxnl1 { color: var(--accent); }
.lx-ohmbel { padding: 16px 16px 14px; border: 1px solid var(--rule); border-radius: var(--radius-sm); background: var(--surface); }
.lx-oji1mo { margin-top: 8px; color: var(--muted-strong); line-height: 1.5; }
.lx-oobb9q { width: 30px; height: 16px; display: inline-block; position: relative; border-radius: var(--radius-pill); transition: background 120ms; }
.lx-oq6lr7 { padding: 10px 16px 6px; font-size: 12px; color: var(--text-3); font-weight: 500; background: var(--bg); }
.lx-oso3of { font-size: 13px; color: var(--text-3); margin-top: 2px; }
.lx-ot9ldp { font-weight: 500; color: var(--text-2); }
.lx-p01yvu { position: absolute; top: calc(100% + 6px); left: 0; z-index: 200; width: 320px; padding: 10px 12px; background: var(--text); color: var(--surface); border-radius: var(--radius); font-size: 13px; line-height: 1.5; box-shadow: var(--shadow-pop); pointer-events: none; }
.lx-p3kd4y { min-width: 0; flex: 1; }
.lx-p6qihj { font-size: 13px; font-weight: 500; }
.lx-p931pw { font-size: 11px; padding: 4px 8px; background: var(--surface-2); border-radius: var(--radius-sm); }
.lx-pcj01c { overflow: auto; flex: 1; background: var(--bg); }
.lx-pj4fc1 { max-width: 280px; }
.lx-pkbebr { padding: 0; height: 18px; width: 18px; opacity: 0.7; }
.lx-pkn96w { text-align: left; padding: 12px; border-radius: var(--radius); cursor: pointer; font-family: inherit; display: flex; flex-direction: column; gap: 6px; }
.lx-pog01x { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; min-height: 32px; padding: 5px 8px; border: 1px solid var(--rule); border-radius: var(--radius-sm); background: var(--surface); }
.lx-psjzm8 { margin: 8px 0; }
.lx-psmt7l { width: 11px; height: 11px; border-radius: 50%; background: #FF5F57; }
.lx-pyafsr { cursor: pointer; }
.lx-q2rf22 { font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lx-q3hiop { display: grid; grid-template-columns: 1fr 420px; gap: 0; height: 100%; margin: -16px; }
.lx-qehdbu { white-space: pre-line; font-size: 12px; color: #52525B; margin-top: 2px; }
.lx-qej50h { width: 320px; }
.lx-qlnzbl { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.lx-qtmyku { background: var(--surface); border-radius: var(--radius); padding: 14px; margin-bottom: 18px; position: relative; }
.lx-qw3u8q { flex: 1; overflow: auto; padding: 14px 16px; display: flex; flex-direction: column; gap: 14px; }
.lx-qwtcji { width: 100%; margin-bottom: 14px; justify-content: center; }
.lx-r22787 { display: flex; align-items: center; }
.lx-r3823a { margin: 0; padding: 0 0 0 14px; font-size: 13px; color: var(--text-2); line-height: 1.5; }
.lx-r3etn2 { text-align: center; }
.lx-r3g2l4 { padding: 2px 6px 0; font-size: 10px; color: var(--text-3); text-align: right; border-bottom: 1px solid var(--border); }
.lx-r3rkw { flex: 1; }
.lx-r54h61 { width: 10px; height: 10px; background: var(--surface-2); }
.lx-r5r0yr { color: var(--critical); margin-top: 2px; }
.lx-rddkcs { font-size: 11px; color: var(--text-3); margin-top: 1px; font-family: var(--font-sans); }
.lx-rdh00h { text-align: justify; }
.lx-rfj9kr { line-height: 1.2; }
.lx-rkjooj { display: flex; align-items: center; gap: 8px; padding: 5px 0; }
.lx-romabo { border-radius: var(--radius); padding: 14px; }
.lx-roo9tv { margin-top: 28px; padding-top: 16px; border-top: 1px solid var(--border); display: flex; gap: 8px; align-items: center; }
.lx-rp7wwq { display: flex; justify-content: flex-end; gap: 4px; }
.lx-rpo5z0 { padding: 2px 6px; font-size: 11px; height: auto; min-width: 130px; }
.lx-rtyltz { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--surface); }
.lx-rwxumw { margin-top: 6px; }
.lx-s0obu6 { display: flex; align-items: center; gap: 6px; }
.lx-sfhavv { border-bottom: 2px solid #222; padding-bottom: 12px; margin-bottom: 16px; }
.lx-si9izv { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.lx-silukr { font-size: 11px; }
.lx-soerqg { margin-bottom: 22px; }
.lx-st7ftq { color: #467852; }
.lx-su2aud { width: 1px; }
.lx-swaypb { font-size: 14px; font-weight: 500; color: var(--text); }
.lx-syl70 { padding: 20px; min-height: 280px; }
.lx-t19aqt { color: var(--text-3); margin-top: 2px; }
.lx-t78vfv { display: flex; flex-wrap: wrap; gap: 4px; max-width: 280px; }
.lx-ta6sj3 { display: flex; gap: 4px; margin-top: 8px; align-items: center; }
.lx-tbtdf4 { text-align: center; margin-bottom: 24px; margin-top: 12px; font-size: 11px; letter-spacing: 2px; color: #555; }
.lx-tfy11i { background: var(--critical); color: #fff; border-color: var(--critical); }
.lx-tfy11i:hover { background: color-mix(in srgb, var(--critical) 88%, #000); color: #fff; border-color: color-mix(in srgb, var(--critical) 88%, #000); }
.lx-th2h3k { display: flex; align-items: center; gap: 5px; font-size: 11.5px; cursor: pointer; }
.lx-tlgp1b { padding: 8px 10px; border-bottom: 1px solid var(--border); cursor: pointer; display: flex; gap: 10px; align-items: center; }
.lx-tpa1aq { position: absolute; left: 3px; right: 3px; border-radius: var(--radius-control); padding: 3px 5px; cursor: pointer; overflow: hidden; font-size: 10.5px; line-height: 1.3; }
.lx-tthces { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
.lx-tv8lfg { font-size: 13px; color: var(--text-3); margin-top: 6px; line-height: 1.5; }
.lx-u3e3eq { padding: 10px 12px; display: flex; gap: 10px; align-items: flex-start; }
.lx-u82ak2 { margin-top: 24px; padding: 14px 12px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; align-items: center; font-size: 13px; color: var(--text-3); }
.lx-ud5rj9 { font-size: 24px; font-weight: 600; letter-spacing: -0.02em; color: var(--text); }
.lx-ueui9m { font-size: 36px; font-weight: 600; letter-spacing: -0.025em; margin: 6px 0 14px; line-height: 1.15; }
.lx-uhkhgi { display: grid; gap: 12px; }
.lx-ujef51 { display: flex; flex-wrap: wrap; gap: 4px; padding: 4px; border: 1px solid var(--border); border-radius: var(--radius-sm); min-height: 28px; align-items: center; }
.lx-uldevn { margin-top: 14px; }
.lx-umrm2x { font-size: 13px; font-weight: 500; margin-top: 12px; }
.lx-un8ce1 { padding: 10px 14px 8px; border-bottom: 1px solid var(--rule); display: flex; align-items: baseline; gap: 8px; }
.lx-ute9ds { display: flex; gap: 6px; align-items: center; white-space: nowrap; }
.lx-utqgoj { font-size: 12px; color: var(--text-3); margin-top: 1px; }
.lx-uv04q4 { margin-bottom: 18px; font-size: 11.5px; }
.lx-v3wu3v { font-size: 13px; line-height: 1.55; margin-bottom: 16px; }
.lx-v9gnok { display: flex; gap: 18px; align-items: center; }
.lx-vbefz2 { width: 100%; border-top: 1.5px solid #1A1814; border-bottom: 1.5px solid #1A1814; }
.lx-vgcprr { display: flex; gap: 8px; align-items: center; margin-bottom: 4px; }
.lx-vjyr1k { font-size: 13px; font-weight: 500; color: var(--text); }
.lx-vqpbqk { position: absolute; left: -8px; top: 0; bottom: 0; width: 2px; background: var(--critical); }
.lx-vu6z7t { display: flex; gap: 6px; margin-top: 6px; justify-content: flex-end; }
.lx-wgn2h2 { padding: 6px 8px; border-radius: var(--radius-sm); background: var(--surface-2); margin-bottom: 4px; display: flex; gap: 8px; align-items: center; }
.lx-wh4kyi { display: flex; gap: 4px; align-items: center; }
.lx-wq12nt { margin-top: 12px; }
.lx-wqgxs { padding: 10px 12px; border-bottom: 1px solid var(--border); display: grid; grid-template-columns: 60px 22px 1fr; gap: 10px; }
.lx-x2girr { margin-top: 36px; }
.lx-x51vgm { border-radius: 50%; color: white; display: inline-flex; align-items: center; justify-content: center; font-weight: 500; flex-shrink: 0; }
.lx-xd1a07 { width: 20%; }
.lx-xdhsil { margin-top: 0; border-bottom: 0; }
.lx-xg1t7l { margin-top: 4px; line-height: 1.5; }
.lx-xsoera { display: flex; gap: 8px; align-items: center; }
.lx-xtqi9o { margin-top: 8px; max-height: 240px; overflow-y: auto; border: 1px solid var(--border); border-radius: var(--radius); }
.lx-xyksiy { margin-top: 14px; padding: 10px; border: 1px solid #F2C3BF; background: #FFF6F4; border-radius: var(--radius); }
.lx-y3j6y5 { display: flex; gap: 4px; align-items: center; font-size: 11px; color: var(--critical); }
.lx-ya7377 { padding: 10px 12px; font-size: 13px; color: var(--text-3); font-weight: 500; border-bottom: 1px solid var(--border); background: var(--surface); }
.lx-yfwzig { margin: 0 0 12px; text-indent: 24px; }
.lx-ygtf4b { margin-right: 4px; }
.lx-yjywa7 { height: 22px; width: 22px; padding: 0; color: var(--critical); }
.lx-yn6tld { padding: 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.lx-ynqod4 { padding-top: 10px; }
.lx-yu6avr { cursor: default; }
.lx-yvjfi3 { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; gap: 10px; }
.lx-yvls8c { padding: 40px 0; text-align: center; }
.lx-zbao5a { font-size: 12px; color: var(--text-2); margin-top: 1px; }
.lx-zditdc { font-size: 12.5px; color: var(--text-2); line-height: 1.5; margin-bottom: 16px; }
.lx-zfhi01 { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border: 1px solid var(--rule); background: var(--surface-2); margin-bottom: 14px; }
.lx-zjfx3z { display: flex; gap: 6px; justify-content: flex-end; margin-top: 6px; }
.lx-zjrbla { margin-left: auto; display: flex; gap: 4px; }
.lx-zorliu { font-size: 15px; line-height: 1.4; min-height: 60px; font-family: var(--font-sans); }
.lx-zxoi8z { padding: 0 4px; font-size: 12px; margin-top: 2px; }
.lx-zz7phi { margin-top: 2px; font-family: var(--font-sans); }
/* === Generated static style classes: end === */

.claim-tags-wrap {
  position: relative;
  width: fit-content;
  max-width: 100%;
}

.claim-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 5px;
  align-items: center;
}

.claim-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  max-width: 150px;
  min-height: 18px;
  padding: 2px 6px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 11px;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.claim-tag-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
  padding: 3px 2px;
  color: var(--text-2);
  font-size: 12px;
}

.claim-tag-option input {
  margin: 0;
}

.claim-tag-option.disabled {
  color: var(--text-3);
}

.claim-tag-hint {
  margin-left: auto;
  color: var(--text-3);
  font-size: 11px;
}

.claim-tag-manage-link {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
}
.claim-tag-manage-link:hover,
.claim-tag-manage-link:focus-visible {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.claim-tag-error {
  margin-top: 8px;
  color: #8D2B25;
  font-size: 12px;
}

.claim-tag-modal-content {
  display: grid;
  gap: 14px;
}

.claim-tag-modal-list {
  display: grid;
  gap: 4px;
}

.claim-tag-modal .claim-tag-option {
  min-height: 36px;
  padding: 6px 8px;
  border-radius: var(--radius-control);
}

.claim-tag-modal .claim-tag-option:hover {
  background: var(--surface-2);
}

.claim-tag-modal .claim-tag-option.disabled:hover {
  background: transparent;
}

.bulk-edit {
  display: grid;
  gap: 14px;
}

.bulk-edit-layout {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.bulk-edit-list {
  display: grid;
  gap: 6px;
}

.bulk-edit-list-item {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  min-height: 48px;
  padding: 8px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
}

.bulk-edit-list-item.active {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--rule));
  background: color-mix(in srgb, var(--accent-soft) 55%, var(--surface));
  box-shadow: inset 3px 0 0 var(--accent);
}

.bulk-edit-list-item.enabled:not(.active) {
  background: var(--surface-2);
}

.bulk-edit-list-item.enabled .bulk-edit-list-copy strong {
  color: var(--accent);
}

.bulk-edit-list-checkbox {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: var(--accent);
}

.bulk-edit-list-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.bulk-edit-list-copy:disabled {
  cursor: default;
}

.bulk-edit-list-copy strong {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
}

.bulk-edit-list-copy span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.2;
}

.bulk-edit-panel {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface);
}

.bulk-edit-panel-head {
  display: flex;
  gap: 10px;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 10px;
}

.bulk-edit-field {
  display: grid;
  gap: 8px;
}

.bulk-edit-note {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.35;
}

.bulk-claim-tags-list {
  display: grid;
  gap: 8px;
}

.bulk-claim-tag-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
}

.bulk-claim-tag-option input {
  width: 14px;
  height: 14px;
  margin: 0;
  flex: 0 0 auto;
  accent-color: var(--accent);
}

@media (max-width: 760px) {
  .bulk-edit-layout {
    grid-template-columns: 1fr;
  }
}

.claim-tag-red { border-color: #F2C3BF; background: #FFF6F4; color: #8D2B25; }
.claim-tag-blue { border-color: #B9D5F5; background: #F3F8FE; color: #225C91; }
.claim-tag-orange { border-color: #F4D0A1; background: #FFF8ED; color: #84520E; }
.claim-tag-green { border-color: #B8DDBD; background: #F4FBF5; color: #276B35; }

.claim-sticky-purple {
  margin-top: 5px;
  padding: 4px 6px;
  border-left: 3px solid #7B61FF;
  background: #F6F3FF;
  color: #43318E;
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.claim-sticky-yellow {
  padding: 10px 12px;
  border: 1px solid #E6CF7A;
  background: #FFF9D8;
  color: #5F4B00;
  border-radius: var(--radius-sm);
  font-size: 13px;
  line-height: 1.45;
}

.claim-sticky-note {
  --sticky-note-rotate: -0.45deg;
  position: relative;
  display: inline-block;
  vertical-align: top;
  width: min(278px, 100%);
  min-height: 148px;
  margin: 14px 14px 4px 0;
  padding: 14px 14px 12px;
  border: 0;
  border-radius: var(--radius-xs);
  white-space: normal;
  overflow: visible;
  box-shadow: 0 12px 18px rgba(36, 31, 20, 0.15), 0 2px 5px rgba(36, 31, 20, 0.13);
  transform: rotate(var(--sticky-note-rotate));
}

.claim-sticky-note:nth-child(even) {
  --sticky-note-rotate: 0.35deg;
}

.claim-sticky-note::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0) 36%),
    linear-gradient(90deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 18%);
}

.claim-sticky-note::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 22px;
  height: 22px;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,0) 50%, rgba(120, 95, 18, 0.13) 51%);
  border-bottom-right-radius: 2px;
}

.claim-sticky-note.claim-sticky-purple {
  background: #EEE7FF;
  color: #342166;
}

.claim-sticky-note.claim-sticky-yellow {
  background: #FFF4A8;
  color: #4F3F00;
}

.claim-sticky-note .lx-1jntcpo {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.claim-sticky-note .lx-1jntcpo .btn {
  margin-left: auto;
  flex: 0 0 auto;
}

.claim-sticky-note textarea.textarea {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 86px;
  padding: 4px 0 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  resize: vertical;
  color: inherit;
}

.claim-sticky-note textarea.textarea:focus {
  box-shadow: none;
  outline: 2px solid rgba(84, 64, 14, 0.16);
  outline-offset: 2px;
}

.claim-sticky-note textarea.textarea::placeholder {
  color: color-mix(in srgb, currentColor 58%, transparent);
}

.claim-sticky-note .small.muted {
  position: relative;
  z-index: 1;
  color: color-mix(in srgb, currentColor 62%, transparent);
}

.economics-workspace {
  display: grid;
  gap: 14px;
  padding: 0 24px 24px;
}

.economics-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
}

.economics-title {
  font-weight: 750;
  font-size: 15px;
}

.economics-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.economics-summary-tile {
  min-height: 84px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}

.economics-summary-tile.ok {
  border-color: #B8DDBD;
  background: #F4FBF5;
}

.economics-summary-tile.warn {
  border-color: #EBD3A8;
  background: #FFF9EC;
}

.economics-summary-label {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}

.economics-summary-value {
  margin-top: 8px;
  color: var(--text);
  font-size: 22px;
  font-weight: 800;
  line-height: 1.05;
}

.economics-summary-detail {
  margin-top: 6px;
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.3;
}

.economics-workpaper-grid {
  display: grid;
  gap: 14px;
}

.economics-workpaper {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.85fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  overflow: hidden;
}

.economics-workpaper-main {
  padding: 14px;
}

.economics-workpaper-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.economics-workpaper-title {
  font-weight: 750;
  font-size: 14px;
}

.economics-input-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.economics-check-field {
  grid-column: span 2;
}

.economics-result-panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  border-left: 1px solid var(--border);
  background: var(--surface-2);
}

.economics-result-title {
  font-size: 12px;
  font-weight: 750;
  color: var(--text-2);
}

.economics-result-empty {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.economics-result-list {
  display: grid;
  gap: 6px;
}

.economics-result-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}

.economics-result-row span {
  color: var(--text-3);
}

.economics-result-row strong {
  text-align: right;
  white-space: nowrap;
}

.economics-warning-list {
  display: grid;
  gap: 4px;
  padding: 8px;
  border: 1px solid #EBD3A8;
  border-radius: var(--radius-control);
  background: #FFF9EC;
}

.economics-result-footer {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-top: auto;
}

.economics-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

@media (max-width: 980px) {
  .economics-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .economics-workpaper {
    grid-template-columns: 1fr;
  }

  .economics-result-panel {
    border-left: 0;
    border-top: 1px solid var(--border);
  }

  .economics-input-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .economics-summary-grid,
  .economics-input-grid {
    grid-template-columns: 1fr;
  }

  .economics-check-field {
    grid-column: auto;
  }
}

.backlog-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.backlog-workplan {
  margin-top: 14px;
  display: grid;
  gap: 8px;
}

.backlog-workplan-item {
  border: 1px solid var(--border);
  background: var(--surface-2);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  font-size: 12px;
  line-height: 1.4;
}

.issue-workspace-root {
  min-width: 0;
}

.issue-workspace-shell {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.issue-rail {
  position: sticky;
  top: 12px;
  display: grid;
  gap: 8px;
  max-height: calc(100vh - 190px);
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 8px;
}

.issue-rail-back {
  justify-content: flex-start;
}

.issue-rail-list {
  display: grid;
  gap: 6px;
}

.issue-rail-item {
  display: grid;
  gap: 3px;
  width: 100%;
  padding: 8px;
  border: 1px solid transparent;
  border-radius: var(--radius-control);
  background: transparent;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.issue-rail-item:hover,
.issue-rail-item.active {
  border-color: var(--border);
  background: var(--surface-2);
}

.issue-rail-title {
  font-size: 12px;
  font-weight: 650;
}

.issue-rail-objective {
  font-size: 12px;
  line-height: 1.35;
  color: var(--text-2);
}

.issue-rail-meta {
  font-size: 11px;
  color: var(--text-3);
}

.issue-workspace-panel {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 14px;
}

.issue-workspace-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.issue-workspace-header-main {
  flex: 1;
  min-width: 0;
}

.issue-workspace-title {
  margin: 10px 0 0;
  font-size: 21px;
  line-height: 1.25;
  letter-spacing: 0;
}

.issue-workspace-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}

.issue-workspace-stats > div {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-control);
  background: var(--surface-2);
}

.issue-workspace-stats strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
}

.issue-workspace-section {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.issue-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.task-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.issue-linked-overview {
  display: grid;
  gap: 10px;
}

.issue-workspace-danger {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}

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

  .issue-rail {
    position: static;
    max-height: none;
  }

  .issue-workspace-stats,
  .issue-summary-grid,
  .task-summary-grid {
    grid-template-columns: 1fr;
  }
}

/* === Slice C — work-rows shared display components === */

.work-row {
  display: flex;
  gap: 12px;
  position: relative;
  padding: 10px 12px 10px 18px;
  border-bottom: 1px solid var(--rule-soft, #F0F0F0);
  align-items: flex-start;
}
.work-row.is-clickable { cursor: pointer; }
.work-row.is-clickable:hover { background: var(--hover, #FAFAFA); }
.work-row.selected { box-shadow: inset 3px 0 0 var(--accent-text, #6B29C0); background: var(--surface-2, #FAFAFA); }
.work-row.overdue::before,
.work-row.critical::before,
.work-row.warn::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 10px;
  bottom: 10px;
  width: 2px;
  border-radius: var(--radius-pill);
  background: var(--warn, #8B6914);
}
.work-row.overdue::before,
.work-row.critical::before { background: var(--critical, #C0291F); }
.work-row-variant-claim:is(.overdue, .critical, .warn)::before {
  top: 8px;
  bottom: 8px;
}
.work-row-variant-register:is(.overdue, .critical, .warn)::before {
  top: 12px;
  bottom: 12px;
}
.work-row.closed .work-row-title-line { color: var(--text-3, #666); }

.work-row-lead { flex: none; display: flex; align-items: center; gap: 8px; }
.work-row-with-proximity .work-row-lead,
.work-row-kind-deadline .work-row-lead {
  align-self: stretch;
  align-items: stretch;
  flex: 0 0 104px;
  width: 104px;
}
.work-row-proximity,
.work-row-kind-deadline .deadline-when {
  width: 100%;
  box-sizing: border-box;
  justify-content: center;
  padding: 6px 8px 6px 10px;
}
.work-row-kind-deadline .deadline-when {
  align-items: flex-start;
  text-align: left;
}
.work-row-proximity {
  display: flex;
  flex-direction: column;
}
.work-row-proximity.critical {
  background: color-mix(in srgb, var(--critical-soft, #FFEAE7) 58%, transparent);
}
.work-row-proximity-days {
  font-size: 18px;
  line-height: 1;
  font-weight: 600;
  color: var(--text, #1F1F1F);
}
.work-row-proximity.critical .work-row-proximity-days {
  color: var(--critical, #C0291F);
}
.work-row-proximity.warn .work-row-proximity-days {
  color: var(--warn, #8B6914);
}
.work-row-proximity.muted .work-row-proximity-days {
  color: var(--text-3, #666);
}
.work-row-proximity-date {
  margin-top: 4px;
  color: var(--text-3, #666);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0;
}
.work-row-kind-deadline.overdue .deadline-when {
  background: color-mix(in srgb, var(--critical-soft, #FFEAE7) 58%, transparent);
}
.work-row-main { flex: 1; min-width: 0; }
.work-row-title-line {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  font-weight: 500;
}
.work-row-title-text { font-weight: 500; }
.work-row-context-line {
  margin-top: 3px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-2, #4D4D4D);
}
.work-row-meta {
  font-size: 12px; color: var(--text-3, #666);
  margin-top: 3px;
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.work-row-meta-claim { font-weight: 500; color: var(--text-2, #4D4D4D); }
.work-row-source-spacer { margin-top: 4px; }
.work-row-aside { flex: none; display: flex; gap: 8px; align-items: center; justify-content: flex-end; }
.appointment-row-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
}

.work-row-due-inline { font-size: 12px; font-weight: 500; }
.work-row-due-critical { color: var(--critical, #C0291F); }
.work-row-due-warn { color: var(--warn, #8B6914); }
.work-row-due-muted { color: var(--text-3, #666); }

.work-row-due-block { display: flex; flex-direction: column; align-items: flex-end; min-width: 70px; }
.work-row-due-block.critical .work-row-due-days { color: var(--critical, #C0291F); font-weight: 600; }
.work-row-due-block.warn .work-row-due-days { color: var(--warn, #8B6914); font-weight: 600; }
.work-row-due-block.muted .work-row-due-days { color: var(--text-3, #666); }
.work-row-due-days { font-size: 13px; font-weight: 600; }
.work-row-due-date { font-size: 11px; color: var(--text-3, #666); }

.work-row-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 4px 14px;
  font-size: 12px;
  color: var(--text-3, #666);
  margin-top: 6px;
}
.work-row-detail-grid strong { color: var(--text-2, #4D4D4D); font-weight: 500; margin-right: 4px; }

.work-row .indicator-inline { color: var(--text-3, #666); font-style: italic; }

.ime-readiness-chip-row {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

/* Variant tweaks */
.work-row-variant-myday { padding: 10px 12px 10px 18px; }
.work-row-variant-claim { padding: 8px 10px 8px 18px; }
.work-row-variant-register { padding: 12px 12px 12px 18px; }

.work-widget-grid {
  column-gap: var(--work-widget-column-gap);
  row-gap: var(--work-widget-row-gap);
  margin-top: 0;
}

.calendar-event-card {
  position: relative;
  padding-left: 10px;
}
.calendar-event-card::before,
.calendar-agenda-row::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 3px;
  bottom: 3px;
  width: 2px;
  border-radius: var(--radius-pill);
  background: var(--calendar-event-color, var(--accent));
}
.calendar-event-card-timed::before,
.calendar-agenda-row::before {
  top: 6px;
  bottom: 6px;
}
.calendar-event-card-compact::before {
  top: 2px;
  bottom: 2px;
}
.calendar-agenda-row {
  position: relative;
  grid-template-columns: 90px 1fr auto;
  padding-left: 24px;
}

/* SourceProvenanceChip atom */
.source-prov-chip {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--surface-3, #F4F4F4); color: var(--text-2, #4D4D4D);
  padding: 2px 8px 2px 6px; border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 500; white-space: nowrap;
}
.source-prov-chip-info { background: var(--info-soft, #EBF5FF); color: var(--info, #0068D6); }
.source-prov-chip-accent { background: var(--accent-soft, #F3EBFF); color: var(--accent-text, #6B29C0); }
.source-prov-chip-success { background: var(--success-soft, #E7F8ED); color: var(--success, #1A7D3A); }
.source-prov-chip-neutral { background: var(--surface-3, #F4F4F4); color: var(--text-2, #4D4D4D); }
.source-prov-chip-warn { background: var(--warn-soft, #FEF6DD); color: var(--warn, #8B6914); }
.source-prov-chip-critical { background: var(--critical-soft, #FFEAE7); color: var(--critical, #C0291F); }
.source-prov-chip-compact { padding: 2px 6px; }
.source-prov-chip-label { font-weight: 500; }
.source-prov-chip-detail { color: var(--text-3, #666); font-weight: 400; max-width: 240px; overflow: hidden; text-overflow: ellipsis; }

/* ============================================================
 * Reference UI
 * ============================================================ */
.reference-ui {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 22px 24px 36px;
  min-height: 100%;
  background: var(--bg);
}

.reference-hero {
  display: block;
  gap: 20px;
  padding-bottom: 18px;
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-hero-copy {
  display: grid;
  gap: 8px;
  max-width: 820px;
}

.reference-page-map {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.reference-page-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  min-width: 0;
  background: var(--surface);
  box-shadow: var(--ring-light);
  border-radius: var(--radius-lg);
}

.reference-page-card h4,
.reference-page-card p {
  margin: 0;
}

.reference-page-card h4 {
  font-size: 13px;
  font-weight: 650;
}

.reference-page-card p {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-page-card code {
  display: inline-block;
  margin-top: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  border-radius: var(--radius-sm);
  padding: 3px 5px;
}

.reference-component-links {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.reference-component-links a {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 24px;
  padding: 3px 7px;
  border-radius: var(--radius-pill);
  color: var(--text-2);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  font-size: 11px;
  font-weight: 500;
  text-decoration: none;
}

.reference-component-links a:hover {
  color: var(--text);
  background: var(--surface-3);
}

.reference-hero-copy p,
.reference-section-head p {
  margin: 0;
  color: var(--text-3);
  font-size: 13px;
  max-width: 840px;
}

.reference-anchor-nav {
  position: sticky;
  top: 0;
  z-index: 4;
  display: flex;
  gap: 4px;
  align-items: center;
  overflow-x: auto;
  padding: 8px 0;
  background: color-mix(in srgb, var(--bg) 94%, transparent);
  backdrop-filter: blur(10px);
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-anchor-nav a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  height: 26px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
}

.reference-anchor-nav a:hover {
  color: var(--text);
  background: var(--hover-2);
}

.reference-section {
  display: grid;
  gap: 14px;
  scroll-margin-top: 60px;
}

.reference-section-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
}

.reference-section-head > div {
  display: grid;
  gap: 6px;
}

.reference-anatomy {
  display: grid;
  gap: 16px;
}

.reference-anatomy-card {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  background: var(--surface);
}

.reference-anatomy-card-navCanvas {
  border-style: dashed;
}

.reference-anatomy-card-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 0.42fr);
  gap: 16px;
  align-items: start;
  padding: 12px 14px;
  background: var(--surface-2);
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-anatomy-card-head h4,
.reference-anatomy-card-head p {
  margin: 0;
}

.reference-anatomy-card-head p {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-anatomy-variant-group {
  display: grid;
  gap: 14px;
  margin-top: 4px;
  padding-top: 16px;
  box-shadow: inset 0 1px 0 var(--rule-soft);
}

.reference-anatomy-variant-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.45fr);
  gap: 16px;
  align-items: start;
  padding: 12px 14px;
  border-radius: var(--radius);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}

.reference-anatomy-variant-head h4,
.reference-anatomy-variant-head p {
  margin: 0;
}

.reference-anatomy-variant-head p {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-canvas-audit {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-canvas-audit-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding-bottom: 10px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-canvas-audit-head div {
  display: grid;
  gap: 4px;
}

.reference-canvas-audit-head strong {
  font-size: 13px;
  font-weight: 600;
}

.reference-canvas-audit-head span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-canvas-audit-list {
  display: grid;
  gap: 1px;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-canvas-audit-row {
  display: grid;
  grid-template-columns: minmax(180px, 0.85fr) minmax(180px, 1fr) minmax(170px, 0.85fr) minmax(220px, 1.2fr);
  gap: 10px;
  align-items: start;
  padding: 9px 10px;
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.4;
}

.reference-canvas-audit-row code,
.reference-canvas-audit-row em,
.reference-canvas-audit-row b {
  font-style: normal;
  font-weight: 500;
}

.reference-canvas-audit-row code {
  overflow-wrap: anywhere;
  color: var(--text-2);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-canvas-audit-row b {
  color: var(--text-2);
}

.reference-widget-layer-map {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-radius-proposal {
  display: grid;
  grid-template-columns: minmax(180px, 0.9fr) repeat(5, minmax(130px, auto));
  gap: 8px;
  align-items: center;
  padding: 12px;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-radius-proposal > div {
  display: grid;
  gap: 2px;
  margin-right: 6px;
}

.reference-radius-proposal strong {
  font-size: 12px;
  font-weight: 600;
}

.reference-radius-proposal span {
  color: var(--text-3);
  font-size: 11.5px;
}

.reference-radius-proposal code {
  align-self: stretch;
  padding: 4px 6px;
  color: var(--text-2);
  background: var(--surface-2);
  border-radius: var(--radius-sm);
  box-shadow: var(--ring-light);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-radius-proposal p {
  grid-column: 1 / -1;
  margin: 2px 0 0;
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-radius-proposal p code {
  display: inline;
  padding: 2px 4px;
}

.reference-radius-review {
  display: grid;
  gap: 14px;
}

.reference-radius-review-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.reference-radius-review-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 14px;
  background: var(--surface);
  border-radius: var(--radius-widget);
  box-shadow: var(--widget-shadow);
}

.reference-radius-review-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  padding-bottom: 12px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-radius-review-head h4,
.reference-radius-review-head p {
  margin: 0;
}

.reference-radius-review-head p {
  margin-top: 5px;
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-radius-review-head > code {
  padding: 4px 6px;
  color: var(--text-2);
  background: var(--surface-2);
  border-radius: var(--radius-label);
  box-shadow: var(--ring-light);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-radius-context-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.reference-radius-context-list code {
  padding: 3px 5px;
  color: var(--text-3);
  background: var(--surface-2);
  border-radius: var(--radius-label);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-radius-decision {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  padding: 9px 10px;
  background: var(--surface-2);
  border-radius: var(--radius-control);
  box-shadow: var(--ring-light);
}

.reference-radius-decision strong {
  color: var(--text);
  font-size: 11.5px;
  font-weight: 650;
}

.reference-radius-decision span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.4;
}

.reference-radius-context-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.reference-radius-context-card {
  display: grid;
  gap: 9px;
  min-width: 0;
  padding: 10px;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-radius-context-copy {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: start;
  min-width: 0;
}

.reference-radius-context-copy div {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.reference-radius-context-copy strong,
.reference-radius-context-copy span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-radius-context-copy strong {
  color: var(--text);
  font-size: 12px;
  font-weight: 650;
}

.reference-radius-context-copy span,
.reference-radius-context-card p {
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
}

.reference-radius-context-copy code {
  flex: 0 1 auto;
  max-width: 48%;
  overflow: hidden;
  padding: 2px 4px;
  color: var(--text-3);
  background: var(--surface-2);
  border-radius: var(--radius-label);
  font-family: var(--font-mono);
  font-size: 10px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-radius-context-card p {
  margin: 0;
}

.reference-radius-context-visual {
  display: grid;
  min-height: 64px;
  align-items: center;
  padding: 10px;
  background: var(--bg-deep);
  box-shadow: inset 0 0 0 1px var(--rule-soft);
}

.reference-radius-context-document {
  justify-items: center;
}

.reference-radius-context-portal {
  justify-items: center;
}

.reference-radius-portal-shell {
  position: relative;
  display: grid;
  gap: 7px;
  width: min(100%, 190px);
  min-height: 82px;
  padding: 24px 14px 12px;
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-radius-preview-banner {
  position: absolute;
  top: 7px;
  left: 50%;
  transform: translateX(-50%);
  width: max-content;
  max-width: calc(100% - 18px);
  overflow: hidden;
  padding: 3px 9px;
  background: var(--ink);
  color: var(--ink-fg);
  font-size: 9px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-radius-portal-head {
  width: 54%;
  height: 9px;
  background: var(--text);
}

.reference-radius-portal-line {
  display: block;
  height: 6px;
  background: var(--surface-3);
}

.reference-radius-portal-line.short {
  width: 72%;
}

.reference-radius-page {
  position: relative;
  display: grid;
  gap: 6px;
  width: min(100%, 150px);
  min-height: 72px;
  padding: 18px 12px 10px;
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-radius-doc-marker {
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  padding: 2px 8px;
  background: var(--ink);
  color: var(--ink-fg);
  font-size: 9px;
  font-weight: 700;
}

.reference-radius-doc-line {
  display: block;
  height: 6px;
  background: var(--surface-3);
}

.reference-radius-doc-line.short {
  width: 68%;
}

.reference-radius-micro-tag {
  display: inline-flex;
  width: max-content;
  padding: 3px 9px;
  background: var(--ink);
  color: var(--ink-fg);
  font-size: 10.5px;
  font-weight: 650;
}

.reference-radius-micro-tag.muted {
  margin-left: 6px;
  background: var(--surface-3);
  color: var(--text-2);
}

.reference-claimant-portal-backdrop {
  position: relative;
  min-height: 640px;
  overflow: hidden;
  padding: 34px 24px 28px;
  background: rgba(15, 15, 14, 0.55);
  box-shadow: inset 0 0 0 1px var(--rule-soft);
}

.reference-claimant-portal-underlay {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 42px 52px;
  color: rgba(255, 255, 255, 0.35);
  filter: blur(1px);
  opacity: 0.55;
}

.reference-claimant-portal-underlay strong {
  font-size: 28px;
  font-weight: 650;
}

.reference-claimant-portal-underlay span {
  font-size: 13px;
}

.reference-claimant-portal-window {
  position: relative;
  z-index: 1;
  display: flex;
  max-width: 1080px;
  min-height: 560px;
  margin: 0 auto;
  overflow: hidden;
  flex-direction: column;
  background: var(--surface);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
}

.reference-claimant-browser-chrome {
  display: flex;
  gap: 10px;
  align-items: center;
  min-height: 45px;
  padding: 8px 14px;
  background: var(--surface-3);
  box-shadow: inset 0 -1px 0 var(--rule-firm);
}

.reference-claimant-window-dots {
  display: flex;
  gap: 5px;
}

.reference-claimant-window-dots span {
  width: 11px;
  height: 11px;
  border-radius: 50%;
}

.reference-claimant-window-dots span:nth-child(1) { background: #FF5F57; }
.reference-claimant-window-dots span:nth-child(2) { background: #FEBC2E; }
.reference-claimant-window-dots span:nth-child(3) { background: #28C840; }

.reference-claimant-address-bar {
  display: flex;
  min-width: 0;
  flex: 1;
  align-items: center;
  gap: 8px;
  overflow: hidden;
  padding: 4px 14px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text-3);
  font-size: 12.5px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-claimant-address-bar svg {
  color: #3F6B2C;
  flex: 0 0 auto;
}

.reference-claimant-portal-preview-label {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 12px;
  border-radius: var(--radius-square);
  background: var(--accent);
  color: var(--surface);
  font-size: 12px;
  font-weight: 700;
  pointer-events: none;
}

.reference-claimant-portal-page {
  flex: 1;
  overflow: hidden;
  background: var(--bg);
}

.reference-claimant-portal-topbar,
.reference-claimant-portal-section-head,
.reference-portal-management-head,
.reference-portal-management-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.reference-claimant-portal-topbar {
  min-height: 64px;
  padding: 14px 32px;
  background: var(--surface);
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-claimant-portal-topbar > div {
  display: flex;
  align-items: center;
  gap: 12px;
}

.reference-claimant-portal-topbar > div:first-child,
.reference-portal-management-head div {
  min-width: 0;
}

.reference-claimant-portal-topbar > div:first-child > span:last-child {
  display: grid;
  gap: 1px;
}

.reference-claimant-portal-logo {
  display: grid;
  width: 26px;
  height: 26px;
  place-items: center;
  background: var(--ink);
  color: var(--ink-fg);
  font-size: 14px;
  font-weight: 600;
}

.reference-claimant-portal-topbar strong,
.reference-portal-management-head strong {
  font-size: 13px;
  font-style: normal;
  font-weight: 500;
}

.reference-claimant-portal-topbar span,
.reference-claimant-portal-topbar em,
.reference-portal-management-head span,
.reference-claimant-portal-section-head span,
.reference-claimant-portal-footer,
.reference-portal-mini-stats span {
  color: var(--text-3);
  font-size: 11.5px;
  font-style: normal;
}

.reference-claimant-portal-hero {
  max-width: 880px;
  margin: 0 auto;
  padding: 36px 32px 24px;
}

.reference-claimant-portal-hero h4 {
  margin: 8px 0 0;
  color: var(--text);
  font-size: 32px;
  font-weight: 650;
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.reference-claimant-portal-hero p {
  max-width: 740px;
  margin: 18px 0 0;
  color: var(--text-2);
  font-size: 14px;
  line-height: 1.6;
}

.reference-claimant-portal-eyebrow {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 600;
}

.reference-claimant-portal-claim-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 28px;
  border: 1px solid var(--rule);
  background: var(--surface);
}

.reference-claimant-portal-claim-strip > div {
  display: grid;
  align-content: start;
  gap: 4px;
  min-width: 0;
  padding: 14px 18px;
  border-right: 1px solid var(--rule);
}

.reference-claimant-portal-claim-strip > div:last-child {
  border-right: 0;
}

.reference-claimant-portal-claim-strip span,
.reference-claimant-portal-claim-strip em,
.reference-claimant-portal-date-row em,
.reference-claimant-portal-date-row span,
.reference-claimant-portal-message em {
  color: var(--text-3);
  font-size: 11px;
  font-style: normal;
}

.reference-claimant-portal-claim-strip strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
}

.reference-claimant-portal-claim-strip > div:first-child strong {
  font-family: var(--font-mono);
}

.reference-claimant-portal-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 28px;
  max-width: 880px;
  margin: 0 auto;
  padding: 8px 32px 40px;
}

.reference-claimant-portal-grid section,
.reference-portal-management-card {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.reference-claimant-portal-section-head {
  padding-bottom: 8px;
  box-shadow: inset 0 -1px 0 var(--rule-firm);
}

.reference-claimant-portal-section-head h5 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.reference-claimant-portal-date-row {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr);
  gap: 14px;
  align-items: flex-start;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule-soft);
}

.reference-claimant-portal-date-row div {
  display: grid;
  gap: 2px;
}

.reference-claimant-portal-date-row div strong {
  color: var(--text);
  font-size: 28px;
  font-weight: 600;
  line-height: 1;
}

.reference-claimant-portal-date-row p {
  display: grid;
  gap: 4px;
  margin: 0;
}

.reference-claimant-portal-date-row p strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
}

.reference-claimant-portal-date-row p span,
.reference-claimant-portal-message p,
.reference-claimant-portal-shared p {
  margin: 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.4;
}

.reference-claimant-portal-message {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  padding: 12px 0;
  border-bottom: 1px solid var(--rule-soft);
}

.reference-claimant-portal-message p {
  display: grid;
  gap: 3px;
}

.reference-claimant-portal-message p strong {
  color: var(--text);
  font-size: 12px;
  font-weight: 500;
}

.reference-claimant-portal-message p span {
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}

.reference-claimant-portal-wide-action {
  width: 100%;
  justify-content: center;
}

.reference-claimant-portal-shared {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.reference-claimant-portal-footer {
  max-width: 880px;
  margin: 0 auto;
  padding: 20px 32px;
  border-top: 1px solid var(--rule);
  color: var(--text-3);
  text-align: center;
  font-size: 13px;
  line-height: 1.45;
}

.reference-portal-management-card {
  padding: 14px;
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}

.reference-portal-mini-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.reference-portal-mini-stats div {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 9px;
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-portal-mini-stats strong {
  font-size: 12px;
  font-weight: 650;
}

.reference-portal-toggle-list {
  display: grid;
  gap: 8px;
}

.reference-portal-toggle-list label {
  display: flex;
  gap: 8px;
  align-items: center;
  color: var(--text-2);
  font-size: 12px;
}

.reference-radius-prose {
  align-items: center;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.5;
}

.reference-radius-prose code,
.reference-radius-prose mark {
  padding: 1px 5px;
  color: var(--text);
  background: var(--warn-soft);
  font-family: var(--font-mono);
  font-size: 11px;
}

.reference-radius-prose mark {
  font-family: var(--font-sans);
  font-weight: 600;
}

.reference-radius-text-button {
  width: max-content;
  padding: 2px 4px;
  color: var(--text);
  background: transparent;
  text-decoration: none;
}

.reference-radius-text-button-states {
  grid-template-columns: repeat(3, max-content);
  gap: 10px;
  justify-content: center;
}

.reference-radius-text-button-states::before {
  content: "rest / hover / focus";
  grid-column: 1 / -1;
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 10px;
  text-align: center;
}

.reference-radius-text-button-hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.reference-radius-text-button-focus {
  background: var(--surface);
  box-shadow: 0 0 0 2px var(--focus);
}

.reference-radius-log-row {
  grid-template-columns: auto auto minmax(0, 1fr);
  gap: 8px;
  color: var(--text-2);
  font-size: 11px;
}

.reference-radius-log-icon {
  display: grid;
  width: 22px;
  height: 22px;
  place-items: center;
  background: var(--info-soft);
  color: var(--info);
  font-size: 10px;
  font-weight: 700;
}

.reference-radius-status-button {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  min-height: 32px;
  padding: 6px 9px;
  background: var(--surface);
  box-shadow: var(--ring-light);
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}

.reference-radius-status-button span {
  color: var(--text-3);
  font-weight: 500;
}

.reference-radius-tab-count {
  display: inline-grid;
  min-width: 18px;
  min-height: 18px;
  place-items: center;
  padding: 0 5px;
  background: var(--surface-3);
  color: var(--text-2);
  box-shadow: var(--ring-light);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 650;
}

.reference-radius-admin-tag,
.reference-radius-editable-field,
.reference-radius-calendar-event,
.reference-radius-editor-tool {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  align-items: center;
  padding: 4px 7px;
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--ring-light);
  font-size: 11px;
  font-weight: 600;
}

.reference-radius-editable-field {
  min-height: 24px;
}

.reference-radius-editor-tool {
  min-width: 24px;
  min-height: 24px;
  justify-content: center;
  padding: 0 7px;
  font-weight: 700;
}

.reference-radius-admin-tag {
  background: var(--surface-3);
  color: var(--text-2);
}

.reference-radius-mini-progress {
  display: block;
  width: 112px;
  height: 8px;
  overflow: hidden;
  background: var(--surface);
  box-shadow: inset 0 0 0 1px var(--rule);
}

.reference-radius-mini-progress span {
  display: block;
  width: 62%;
  height: 100%;
  background: var(--ink);
}

.reference-radius-calendar-event {
  background: var(--info-soft);
  color: var(--info);
}

.reference-radius-warning-panel {
  padding: 9px 10px;
  background: var(--warn-soft);
  color: var(--warn);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--warn) 18%, transparent);
  font-size: 12px;
  line-height: 1.35;
}

.reference-radius-rail {
  gap: 5px;
}

.reference-radius-rail-item {
  display: grid;
  gap: 2px;
  width: 100%;
  padding: 7px 8px;
  background: transparent;
  color: var(--text);
  text-align: left;
}

.reference-radius-rail-item.active {
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-radius-rail-item span {
  color: var(--text-3);
  font-size: 11px;
}

.reference-radius-step-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.reference-radius-step,
.reference-radius-candidate {
  background: var(--surface);
  box-shadow: var(--ring-light);
  color: var(--text-2);
}

.reference-radius-step {
  min-height: 32px;
  padding: 0 8px;
  font-size: 11px;
  font-weight: 650;
}

.reference-radius-step.active {
  color: var(--text);
  background: var(--surface-3);
}

.reference-radius-candidate {
  display: grid;
  gap: 3px;
  width: 100%;
  padding: 9px 10px;
  text-align: left;
}

.reference-radius-candidate strong {
  color: var(--text);
  font-size: 12px;
}

.reference-radius-candidate span {
  color: var(--text-3);
  font-size: 11px;
}

.reference-radius-review-fact,
.reference-radius-widget-card,
.reference-radius-table-shell,
.reference-radius-overview-widget,
.reference-radius-menu-popover {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 8px 9px;
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-radius-review-fact span,
.reference-radius-widget-card span,
.reference-radius-overview-widget span,
.reference-radius-menu-popover span {
  color: var(--text-3);
  font-size: 10.5px;
}

.reference-radius-review-fact strong,
.reference-radius-widget-card strong,
.reference-radius-overview-widget strong,
.reference-radius-menu-popover strong {
  color: var(--text);
  font-size: 11.5px;
  font-weight: 650;
}

.reference-radius-assistant-icon {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--ring-light);
  font-size: 12px;
  font-weight: 700;
}

.reference-radius-assistant-error {
  display: inline-flex;
  padding: 6px 8px;
  background: var(--critical-soft);
  color: var(--critical);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--critical) 16%, transparent);
  font-size: 11px;
}

.reference-radius-tweak-field {
  width: 68px;
  height: 26px;
  padding: 0 8px;
  border: 0;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);
  color: var(--text);
  font: inherit;
  font-size: 11px;
}

.reference-radius-table-shell {
  grid-template-columns: 1fr auto;
  gap: 8px;
  width: 100%;
  color: var(--text-2);
  font-size: 11px;
}

.reference-radius-menu-popover {
  width: min(100%, 150px);
  background: var(--chrome-bg);
  box-shadow: var(--shadow-pop);
}

.reference-radius-status-pill,
.reference-radius-search-pill,
.reference-radius-person-chip {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  align-items: center;
  min-height: 22px;
  padding: 3px 9px;
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--ring-light);
  font-size: 11px;
  font-weight: 600;
}

.reference-radius-status-pill {
  background: var(--success-soft);
  color: var(--success);
}

.reference-radius-search-pill {
  min-width: 142px;
  justify-content: flex-start;
  color: var(--text-3);
}

.reference-radius-person-chip {
  background: var(--surface-3);
}

.reference-radius-toggle {
  display: inline-flex;
  width: 38px;
  height: 20px;
  align-items: center;
  padding: 2px;
  background: var(--ink);
}

.reference-radius-toggle span {
  width: 16px;
  height: 16px;
  margin-left: auto;
  border-radius: 50%;
  background: var(--surface);
}

.reference-radius-modal-shell {
  display: grid;
  overflow: hidden;
  background: var(--surface);
  box-shadow: var(--shadow-pop), inset 0 0 0 1px var(--rule);
}

.reference-radius-modal-head {
  padding: 8px 10px;
  box-shadow: inset 0 -1px 0 var(--rule);
  color: var(--text);
  font-size: 12px;
  font-weight: 650;
}

.reference-radius-modal-body {
  display: block;
  height: 38px;
  background: linear-gradient(var(--surface-2), var(--surface));
}

.reference-radius-connected {
  align-items: stretch;
}

.reference-radius-people-selected {
  display: flex;
  gap: 5px;
  padding: 6px;
  background: var(--surface-2);
  box-shadow: inset 0 0 0 1px var(--rule);
}

.reference-radius-people-selected.muted {
  border-radius: var(--radius-connected-top);
  opacity: 0.62;
}

.reference-radius-people-selected span {
  display: grid;
  width: 22px;
  height: 22px;
  place-items: center;
  border-radius: 50%;
  background: var(--surface);
  box-shadow: var(--ring-light);
  color: var(--text);
  font-size: 10px;
}

.reference-radius-people-menu {
  margin-top: -1px;
  padding: 8px;
  color: var(--text-3);
  background: var(--surface);
  box-shadow: inset 0 0 0 1px var(--rule);
  font-size: 12px;
}

.reference-radius-people-menu.active {
  background: var(--surface-2);
}

.reference-radius-segment-row {
  display: grid;
  grid-template-columns: 1fr 1.2fr 0.8fr 1fr;
  gap: 2px;
}

.reference-radius-segment {
  height: 18px;
  background: var(--surface-3);
}

.reference-radius-segment.active {
  background: var(--info-soft);
}

.reference-radius-segment.first {
  background: var(--info-soft);
}

.reference-radius-segment.last {
  background: var(--success-soft);
  border-radius: 0 var(--radius-pill) var(--radius-pill) 0;
}

.reference-radius-comparison {
  display: grid;
  gap: 10px;
}

.reference-radius-current {
  display: grid;
  gap: 6px;
}

.reference-radius-current > span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
}

.reference-radius-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.reference-radius-option {
  display: grid;
  gap: 7px;
  min-width: 0;
  padding: 8px;
  background: var(--surface-2);
  border-radius: var(--radius-control);
  box-shadow: var(--ring-light);
}

.reference-radius-option strong,
.reference-radius-option span {
  display: block;
}

.reference-radius-option strong {
  color: var(--text);
  font-size: 11.5px;
  font-weight: 600;
  line-height: 1.25;
}

.reference-radius-option span {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 10.5px;
  line-height: 1.3;
}

.reference-radius-sample {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  min-height: 38px;
  padding: 8px 9px;
  background: var(--surface);
  box-shadow: var(--ring-light);
  color: var(--text-2);
  font-size: 12px;
}

.reference-radius-current-1 { border-radius: var(--radius-square); }
.reference-radius-current-3 { border-radius: var(--radius-control); }
.reference-radius-current-5 { border-radius: var(--radius-control); }
.reference-radius-current-7 { border-radius: var(--radius); }
.reference-radius-current-top { border-radius: var(--radius-connected-top); }
.reference-radius-current-segment-left { border-radius: var(--radius-segment-start); }
.reference-radius-option-xs { border-radius: var(--radius-xs); }
.reference-radius-option-control { border-radius: var(--radius-control); }
.reference-radius-option-base { border-radius: var(--radius); }
.reference-radius-option-lg { border-radius: var(--radius-lg); }
.reference-radius-option-tab-track { border-radius: var(--radius-tab-track); }
.reference-radius-option-widget { border-radius: var(--radius-widget); }
.reference-radius-option-container { border-radius: var(--radius-container); }
.reference-radius-option-pill { border-radius: var(--radius-pill); }
.reference-radius-option-top-control { border-radius: var(--radius-connected-top); }
.reference-radius-option-top-widget { border-radius: var(--radius-widget) var(--radius-widget) 0 0; }
.reference-radius-option-segment-control { border-radius: var(--radius-control) 0 0 var(--radius-control); }

.reference-radius-sample-icon {
  width: 22px;
  height: 22px;
  border-radius: inherit;
  background: var(--surface-3);
  box-shadow: inset 0 0 0 1px var(--rule);
}

.reference-radius-sample-copy {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-radius-sample-meta {
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

@media (max-width: 1100px) {
  .reference-radius-review-grid,
  .reference-radius-options,
  .reference-radius-context-grid {
    grid-template-columns: 1fr;
  }
}

.reference-widget-layer-head {
  display: grid;
  gap: 4px;
  padding-bottom: 10px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-widget-layer-head strong {
  font-size: 13px;
  font-weight: 600;
}

.reference-widget-layer-head span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-widget-layer-grid {
  display: grid;
  gap: 1px;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-widget-layer-row {
  display: grid;
  grid-template-columns: minmax(130px, 0.75fr) minmax(170px, 0.9fr) minmax(220px, 1.25fr) minmax(200px, 1.05fr) minmax(120px, 0.7fr) minmax(220px, 1.2fr);
  gap: 10px;
  align-items: start;
  padding: 9px 10px;
  background: var(--surface-2);
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.4;
}

.reference-widget-layer-row strong,
.reference-widget-layer-row b {
  color: var(--text-2);
  font-weight: 600;
}

.reference-widget-layer-row code {
  overflow-wrap: anywhere;
  color: var(--text-2);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-widget-layer-row em {
  font-style: normal;
}

.reference-widget-layer-row a {
  color: var(--info);
  font-weight: 500;
}

.reference-divider-comparison {
  --widget-divider: var(--rule);
  --space-rhythm: 18px;
  --widget-padding-y: var(--space-rhythm);
  --widget-padding-x: var(--space-rhythm);
  --widget-padding: var(--widget-padding-y) var(--widget-padding-x);
  display: grid;
  gap: 10px;
  padding: 14px;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-divider-comparison-head {
  display: flex;
  gap: 12px;
  align-items: start;
  justify-content: space-between;
}

.reference-divider-comparison-head > div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.reference-divider-comparison-head strong {
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}

.reference-divider-comparison-head span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-divider-comparison-head code {
  flex-shrink: 0;
  padding: 3px 5px;
  color: var(--text-2);
  background: var(--surface-2);
  border-radius: var(--radius-sm);
  box-shadow: var(--ring-light);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-divider-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.reference-divider-card {
  display: grid;
  min-width: 0;
  overflow: hidden;
  background: var(--widget-bg);
  border-radius: var(--radius-widget, var(--radius));
  box-shadow: var(--widget-shadow);
}

.reference-divider-card-head {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  min-height: 40px;
  color: var(--text);
}

.reference-divider-card-head span {
  font-size: 12px;
  font-weight: 600;
}

.reference-divider-card-head em {
  color: var(--text-3);
  font-size: 10.5px;
  font-style: normal;
}

.reference-divider-card-inset {
  padding: var(--widget-padding);
}

.reference-divider-card-inset .reference-divider-card-head {
  box-shadow: inset 0 -1px 0 var(--widget-divider);
}

.reference-divider-card-full {
  padding: var(--widget-padding);
}

.reference-divider-card-full .reference-divider-card-head {
  margin: calc(var(--widget-padding-y) * -1) calc(var(--widget-padding-x) * -1) 0;
  padding: var(--widget-padding-y) var(--widget-padding-x);
  background: var(--surface-2);
  box-shadow: inset 0 -1px 0 var(--widget-divider);
}

.reference-divider-card-body {
  display: grid;
}

.reference-divider-row {
  min-height: 34px;
  padding: 9px 0;
  color: var(--text-2);
  border-bottom: 1px solid var(--rule-soft);
  font-size: 11.5px;
}

.reference-divider-row:last-child {
  border-bottom: 0;
}

.reference-divider-card p {
  margin: 8px 0 0;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.45;
}

.reference-widget-standard {
  --space-rhythm: 18px;
  --widget-padding-y: var(--space-rhythm);
  --widget-padding-x: var(--space-rhythm);
  --widget-padding: var(--widget-padding-y) var(--widget-padding-x);
  --widget-gap: var(--space-rhythm);
  --widget-gutter: var(--widget-gap);
  --claim-header-tab-gap: var(--space-rhythm);
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(320px, 1fr);
  gap: 14px;
  align-items: start;
}

.reference-widget-standard-demo {
  padding: 18px;
  background: var(--bg-deep);
  border-radius: var(--radius);
}

.reference-widget-standard-surface {
  background: var(--widget-bg);
  box-shadow: var(--widget-shadow);
  padding: var(--widget-padding);
}

.reference-widget-standard-spec {
  display: grid;
  gap: 8px;
}

.reference-widget-standard-spec > div {
  display: grid;
  gap: 4px;
  padding: 9px 10px;
  background: var(--surface-2);
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-widget-standard-spec strong {
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}

.reference-widget-standard-spec span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-widget-standard-spec code {
  color: var(--text-2);
  font-family: var(--font-mono);
  font-size: 10.5px;
}

.reference-anatomy-layout {
  display: grid;
  grid-template-columns: minmax(560px, 1fr) minmax(300px, 0.42fr);
  gap: 14px;
  padding: 14px;
  align-items: start;
}

.reference-anatomy-map-stack {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.reference-anatomy-map-stage {
  display: grid;
  grid-template-columns: minmax(174px, 0.22fr) minmax(0, 1fr);
  gap: 10px;
  min-width: 0;
  align-items: stretch;
}

.reference-decomposition-rail,
.reference-measure-legend {
  min-width: 0;
  background: var(--surface);
  border-radius: var(--radius-widget);
  box-shadow: var(--ring-light);
}

.reference-decomposition-rail {
  align-self: start;
  display: grid;
  gap: 3px;
  padding: 8px;
}

.reference-decomposition-head,
.reference-measure-legend-head {
  display: grid;
  gap: 3px;
  padding: 4px 5px 8px;
}

.reference-decomposition-head strong,
.reference-measure-legend-head strong {
  font-size: 11px;
}

.reference-decomposition-head span,
.reference-measure-legend-head span {
  color: var(--text-3);
  font-size: 10px;
  line-height: 1.35;
}

.reference-decomposition-item {
  display: grid;
  grid-template-columns: 66px minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  padding: 5px 6px;
  color: inherit;
  text-decoration: none;
  border-radius: var(--radius-control);
}

.reference-decomposition-item:hover {
  background: var(--hover);
}

.reference-decomposition-item code {
  justify-self: start;
  padding: 2px 5px;
  color: var(--ink-fg);
  background: var(--ink);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 8.5px;
}

.reference-decomposition-item span {
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-2);
  font-size: 10.5px;
  line-height: 1.25;
  white-space: nowrap;
}

.reference-decomposition-item.level-2 { margin-left: 8px; }
.reference-decomposition-item.level-3 { margin-left: 16px; }
.reference-decomposition-item.level-4 { margin-left: 24px; }
.reference-decomposition-item.level-5 { margin-left: 32px; }

.reference-measure-legend {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
}

.reference-measure-legend-head {
  grid-column: 1 / -1;
  background: var(--surface-2);
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-measure-legend-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 7px;
  align-content: start;
  min-width: 0;
  padding: 8px;
  background: var(--surface);
}

.reference-measure-legend-row.needs-token {
  background: color-mix(in srgb, var(--warn-soft) 42%, var(--surface));
}

.reference-measure-legend-row > b {
  display: grid;
  width: 28px;
  height: 18px;
  place-items: center;
  color: var(--ink-fg);
  background: var(--ink);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 9px;
}

.reference-measure-legend-row > span,
.reference-measure-legend-row code,
.reference-measure-legend-row small,
.reference-measure-legend-row p {
  grid-column: 2;
}

.reference-measure-legend-row > span {
  display: grid;
  gap: 2px;
}

.reference-measure-legend-row strong {
  font-size: 10.5px;
}

.reference-measure-legend-row em,
.reference-measure-legend-row small,
.reference-measure-legend-row p {
  color: var(--text-3);
  font-style: normal;
  line-height: 1.25;
}

.reference-measure-legend-row em,
.reference-measure-legend-row small {
  font-size: 9.5px;
}

.reference-measure-legend-row code {
  width: fit-content;
  max-width: 100%;
  padding: 2px 4px;
  overflow-wrap: anywhere;
  background: var(--surface-2);
  border-radius: var(--radius-control);
  font-size: 9px;
}

.reference-measure-legend-row p {
  margin: 0;
  font-size: 9.5px;
}

.reference-anatomy-viewport {
  position: relative;
  display: grid;
  grid-template-columns: 18% minmax(0, 1fr);
  min-height: 520px;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--bg);
  box-shadow: var(--ring-light);
}

.reference-anatomy-sidebar {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 13px 10px;
  overflow: hidden;
  background: var(--bg-deep);
  box-shadow: inset -1px 0 0 var(--rule);
}

.reference-anatomy-brand {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  font-size: 11px;
}

.reference-anatomy-brand span {
  display: grid;
  width: 22px;
  height: 22px;
  place-items: center;
  border-radius: var(--radius-control);
  color: var(--ink-fg);
  background: var(--ink);
  font-weight: 600;
}

.reference-anatomy-brand strong,
.reference-anatomy-title,
.reference-anatomy-widget strong {
  color: var(--text);
  font-weight: 600;
}

.reference-anatomy-nav-group {
  display: grid;
  gap: 2px;
}

.reference-anatomy-nav-label {
  margin-top: 5px;
  color: var(--text-3);
  font-size: 9px;
  font-weight: 650;
}

.reference-anatomy-nav-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  min-height: 24px;
  padding: 0 7px;
  border-radius: var(--radius-sm);
  color: var(--text-2);
  font-size: 10px;
}

.reference-anatomy-nav-item.active {
  color: var(--text);
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-anatomy-nav-item b {
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 500;
}

.reference-anatomy-sidebar-user {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
  padding-top: 8px;
  box-shadow: inset 0 1px 0 var(--rule);
  color: var(--text-2);
  font-size: 10px;
}

.reference-anatomy-sidebar-user span {
  display: grid;
  width: 22px;
  height: 22px;
  place-items: center;
  border-radius: 50%;
  background: var(--surface);
  box-shadow: var(--ring-light);
  font-size: 9px;
}

.reference-anatomy-canvas {
  display: flex;
  min-width: 0;
  min-height: 0;
  flex-direction: column;
  background: var(--bg);
}

.reference-anatomy-navCanvas .reference-anatomy-canvas,
.reference-anatomy-navCanvas .reference-anatomy-body,
.reference-anatomy-navCanvas .reference-anatomy-tab-scaffold {
  background: var(--bg-deep);
}

.reference-anatomy-navCanvas {
  --space-rhythm: 18px;
  --widget-padding-y: var(--space-rhythm);
  --widget-padding-x: var(--space-rhythm);
  --widget-padding: var(--widget-padding-y) var(--widget-padding-x);
  --widget-gap: var(--space-rhythm);
  --widget-gutter: var(--widget-gap);
  --claim-header-tab-gap: var(--space-rhythm);
  --radius-xs: 2px;
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 9999px;
  --radius: var(--radius-sm);
  --radius-label: var(--radius-xs);
  --radius-control: var(--radius-sm);
  --radius-tab-track: 8px;
  --radius-widget: var(--radius-md);
  --radius-container: var(--radius-lg);
}

.reference-anatomy-navCanvas .reference-anatomy-breadcrumb,
.reference-anatomy-navCanvas .reference-anatomy-tabs,
.reference-anatomy-navCanvas .reference-anatomy-tab-header {
  background: var(--bg-deep);
}

.reference-anatomy-navCanvas .reference-anatomy-tab-header {
  padding: 18px 24px 16px 74px;
}

.reference-anatomy-navCanvas .reference-anatomy-page-header,
.reference-anatomy-navCanvas .reference-anatomy-claim-header {
  background: var(--bg);
}

.reference-anatomy-navCanvas.reference-anatomy-mywork .reference-anatomy-page-header {
  background: var(--bg-deep);
}

.reference-anatomy-navCanvas .reference-anatomy-week-strip,
.reference-anatomy-navCanvas .reference-anatomy-review-card,
.reference-anatomy-navCanvas .reference-anatomy-widget {
  padding: var(--widget-padding);
  border-radius: var(--radius-widget);
  background: var(--widget-bg);
  box-shadow: var(--widget-shadow);
}

.reference-anatomy-navCanvas .reference-anatomy-perspective-card {
  padding: 12px 14px 12px 70px;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.reference-anatomy-navCanvas .reference-anatomy-actions span,
.reference-anatomy-navCanvas .reference-anatomy-nav-item,
.reference-anatomy-navCanvas .reference-anatomy-filter-row span {
  border-radius: var(--radius-control);
}

.reference-anatomy-navCanvas .reference-anatomy-actions span.reference-anatomy-search-pill,
.reference-anatomy-navCanvas .reference-anatomy-status-pill {
  border-radius: var(--radius-pill);
}

.reference-anatomy-navCanvas .reference-anatomy-tabs span.active {
  border-radius: var(--radius-label);
}

.reference-anatomy-navCanvas .reference-anatomy-widget-grid {
  gap: var(--widget-gap);
}

.reference-anatomy-navCanvas .reference-anatomy-body,
.reference-anatomy-navCanvas .reference-anatomy-intro-row {
  gap: var(--widget-gap);
}

.reference-anatomy-navCanvas .reference-anatomy-body {
  padding: var(--widget-gutter);
}

.reference-anatomy-page-header,
.reference-anatomy-claim-header,
.reference-anatomy-tab-header {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 18px 12px 74px;
  background: var(--bg);
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-anatomy-title {
  font-size: 15px;
  line-height: 1.2;
}

.reference-anatomy-subtitle,
.reference-anatomy-widget span,
.reference-anatomy-intro-row span {
  color: var(--text-3);
  font-size: 10px;
  line-height: 1.35;
}

.reference-anatomy-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  margin-top: 5px;
  padding: 2px 7px;
  color: var(--info);
  background: var(--info-soft);
  border-radius: var(--radius-pill);
  box-shadow: var(--ring-light);
  font-size: 9px;
  font-weight: 600;
}

.reference-anatomy-actions {
  position: relative;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.reference-anatomy-actions span {
  min-height: 22px;
  padding: 4px 7px;
  border-radius: var(--radius-sm);
  color: var(--text-2);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  font-size: 10px;
  font-weight: 500;
}

.reference-anatomy-body {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 18px;
  overflow: hidden;
}

.reference-anatomy-perspective-card,
.reference-anatomy-week-strip,
.reference-anatomy-review-card {
  min-width: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.reference-anatomy-perspective-card {
  position: relative;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  min-height: 58px;
  padding: 12px 14px 12px 56px;
}

.reference-anatomy-perspective-card > span:not(.reference-anatomy-pin) {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  color: var(--accent);
  background: var(--accent-bg);
  border-radius: var(--radius-lg);
  box-shadow: none;
  font-size: 10px;
  font-weight: 700;
}

.reference-anatomy-perspective-card div,
.reference-anatomy-review-card div {
  display: grid;
  gap: 2px;
}

.reference-anatomy-perspective-card small,
.reference-anatomy-perspective-card em,
.reference-anatomy-review-card small {
  color: var(--text-3);
  font-size: 10px;
  font-style: normal;
}

.reference-anatomy-week-strip {
  display: grid;
  gap: 6px;
  padding: 0 2px;
}

.reference-anatomy-week-strip > strong,
.reference-anatomy-review-card strong {
  font-size: 11px;
}

.reference-anatomy-week-strip > strong,
.reference-anatomy-review-card > div:first-child {
  padding: 2px 0 8px;
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-anatomy-week-strip > div {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.reference-anatomy-week-strip span {
  min-height: 38px;
  padding: 5px;
  color: var(--text-3);
  background: var(--surface-2);
  border-radius: var(--radius-sm);
  font-size: 9px;
}

.reference-anatomy-review-card {
  display: grid;
  gap: 8px;
  min-height: 92px;
  padding: 0 2px;
}

.reference-anatomy-filter-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.reference-anatomy-filter-row span {
  min-height: 24px;
  padding: 5px 7px;
  color: var(--text-2);
  background: var(--surface-2);
  border-radius: var(--radius-pill);
  box-shadow: var(--ring-light);
  font-size: 9px;
}

.reference-anatomy-intro-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.reference-anatomy-intro-row > div,
.reference-anatomy-widget {
  display: grid;
  align-content: start;
  gap: 6px;
  min-width: 0;
  padding: 0 2px;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.reference-anatomy-widget-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--work-widget-column-gap);
}

.reference-anatomy-widget-grid.claim {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.reference-anatomy-widget {
  position: relative;
  min-height: 134px;
  overflow: hidden;
}

.reference-measure-chip {
  position: absolute;
  z-index: 4;
  display: grid;
  gap: 1px;
  width: max-content;
  max-width: 112px;
  padding: 4px 6px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-pop);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  line-height: 1.15;
  pointer-events: none;
}

.reference-measure-chip strong {
  display: inline-grid;
  width: 26px;
  height: 16px;
  place-items: center;
  color: var(--ink-fg);
  background: var(--ink);
  border-radius: var(--radius-pill);
  font-size: 8.5px;
  font-weight: 650;
}

.reference-measure-chip b {
  color: var(--text);
  font-size: 10px;
  font-weight: 650;
}

.reference-measure-chip em {
  color: var(--text-3);
  font-size: 8.5px;
  font-style: normal;
  font-family: var(--font-sans);
}

.reference-measure-chip code {
  max-width: 86px;
  overflow: hidden;
  color: var(--text-3);
  font-size: 8px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-measure-chip::after {
  content: "";
  position: absolute;
  background: var(--info);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.76);
}

.reference-anatomy-viewport .reference-measure-chip {
  width: 28px;
  height: 18px;
  max-width: 28px;
  padding: 0;
  place-items: center;
  gap: 0;
  border-radius: var(--radius-pill);
  color: var(--ink-fg);
  background: var(--ink);
}

.reference-anatomy-viewport .reference-measure-chip strong {
  width: auto;
  height: auto;
  background: transparent;
  font-size: 8.5px;
}

.reference-anatomy-viewport .reference-measure-chip b,
.reference-anatomy-viewport .reference-measure-chip em,
.reference-anatomy-viewport .reference-measure-chip code {
  display: none;
}

.reference-measure-body-gutter {
  right: 12px;
  top: 10px;
}

.reference-measure-body-gutter::after {
  left: calc(100% + 4px);
  top: 50%;
  width: var(--widget-gutter, 18px);
  height: 2px;
}

.reference-measure-tab-padding {
  right: 250px;
  top: 8px;
}

.reference-measure-tab-padding::after {
  left: 50%;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
  height: 18px;
}

.reference-measure-tab-padding::before {
  content: "";
  position: absolute;
  left: calc(50% - 9px);
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 2px;
  background: var(--info);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.76);
}

.reference-measure-widget-gap {
  left: calc(((100% - (var(--widget-gap, 18px) * 2)) / 3) + (var(--widget-gap, 18px) / 2));
  top: -10px;
  transform: translateX(-50%);
}

.reference-anatomy-widget-grid.claim .reference-measure-widget-gap {
  left: calc(((100% - var(--widget-gap, 18px)) / 2) + (var(--widget-gap, 18px) / 2));
}

.reference-measure-widget-gap::after {
  left: 50%;
  top: 100%;
  width: 2px;
  height: 12px;
}

.reference-measure-widget-padding {
  right: 8px;
  bottom: 8px;
}

.reference-measure-widget-padding::after {
  right: calc(100% + 4px);
  bottom: 8px;
  width: var(--widget-padding-x, 18px);
  height: 2px;
}

.reference-measure-widget-header {
  left: 8px;
  top: 8px;
}

.reference-measure-widget-header::after {
  left: 50%;
  top: 100%;
  width: 2px;
  height: 14px;
}

.reference-measure-row-padding {
  left: 56px;
  bottom: 8px;
}

.reference-measure-row-padding::after {
  left: -18px;
  top: 50%;
  width: 18px;
  height: 2px;
}

.reference-anatomy-widget > div {
  min-height: 38px;
  margin: calc(var(--widget-padding-y, 18px) * -1) calc(var(--widget-padding-x, 18px) * -1) 8px;
  padding: 14px var(--widget-padding-x, 18px) 12px;
  color: var(--text-3);
  background: var(--widget-header-bg);
  box-shadow: inset 0 -1px 0 var(--widget-divider);
  font-size: 11px;
  font-weight: 600;
}

.reference-anatomy-widget-critical {
  box-shadow: none;
}

.reference-anatomy-widget-warn {
  box-shadow: none;
}

.reference-anatomy-widget-critical strong {
  color: var(--critical);
}

.reference-anatomy-widget-warn strong {
  color: var(--warn);
}

.reference-anatomy-breadcrumb {
  position: relative;
  min-height: 34px;
  padding: 10px 18px 10px 74px;
  color: var(--text-3);
  font-size: 10px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-anatomy-claim-header {
  align-items: center;
}

.reference-anatomy-claim-header-with-tabs {
  display: grid;
  align-items: stretch;
  justify-content: stretch;
  gap: 10px;
}

.reference-anatomy-claim-header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-width: 0;
}

.reference-anatomy-claim-header-main > div:nth-child(2) {
  min-width: 0;
  flex: 1 1 auto;
}

.reference-anatomy-header-tabs {
  position: relative;
  display: flex;
  min-width: 0;
  align-items: center;
}

.reference-anatomy-header-tabs .reference-anatomy-pin-tabs {
  left: -62px;
}

.reference-anatomy-header-tabs .reference-segmented-tabs {
  min-width: 0;
}

.reference-anatomy-id-box {
  display: grid;
  grid-template-columns: auto auto;
  gap: 3px 8px;
  width: 128px;
  padding: 8px;
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}

.reference-anatomy-id-box span {
  color: var(--text-3);
  font-size: 9px;
}

.reference-anatomy-id-box strong {
  font-family: var(--font-mono);
  font-size: 9px;
}

.reference-anatomy-staff {
  color: var(--text-2);
  font-size: 10px;
  white-space: nowrap;
}

.reference-anatomy-tabs {
  position: relative;
  display: flex;
  gap: 16px;
  min-height: 36px;
  padding: 0 18px 0 74px;
  align-items: end;
  overflow: hidden;
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-anatomy-tabs span {
  padding-bottom: 10px;
  color: var(--text-3);
  font-size: 10px;
  white-space: nowrap;
}

.reference-anatomy-tabs span.active {
  color: var(--text);
  box-shadow: inset 0 -2px 0 var(--text);
}

.reference-anatomy-tab-scaffold {
  position: relative;
  display: flex;
  min-height: 0;
  flex: 1;
  flex-direction: column;
}

.reference-anatomy-pin {
  position: absolute;
  z-index: 4;
  display: grid;
  min-width: 36px;
  height: 22px;
  padding: 0 6px;
  place-items: center;
  border-radius: var(--radius-pill);
  color: var(--ink-fg);
  background: var(--ink);
  box-shadow: 0 0 0 2px var(--surface), var(--shadow-pop);
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 600;
  white-space: nowrap;
}

.reference-anatomy-pin-anchored {
  z-index: 5;
}

.reference-anatomy-pin-shell {
  left: calc(18% - 18px);
  top: 18px;
}

.reference-anatomy-pin-sidebar {
  left: 50%;
  top: 34%;
  transform: translate(-50%, -50%);
}

.reference-anatomy-pin-page-header,
.reference-anatomy-pin-claim-header,
.reference-anatomy-pin-tab-scaffold,
.reference-anatomy-pin-breadcrumb,
.reference-anatomy-pin-tabs {
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
}

.reference-anatomy-pin-actions {
  right: -10px;
  top: -10px;
}

.reference-anatomy-actions .reference-anatomy-pin {
  display: grid;
  min-width: 36px;
  height: 22px;
  min-height: 0;
  padding: 0 6px;
  place-items: center;
  border-radius: var(--radius-pill);
  color: var(--ink-fg);
  background: var(--ink);
  box-shadow: 0 0 0 2px var(--surface), var(--shadow-pop);
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 600;
}

.reference-anatomy-pin-body {
  left: 12px;
  top: 12px;
}

.reference-anatomy-pin-widget-grid {
  right: 8px;
  top: 8px;
}

.reference-anatomy-pin-context-strip {
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
}

.reference-anatomy-spec-list {
  display: grid;
  gap: 8px;
  min-width: 0;
  align-content: start;
}

.reference-anatomy-spec {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 8px;
  padding: 9px;
  color: inherit;
  text-decoration: none;
  background: var(--surface-2);
  border-radius: var(--radius);
  box-shadow: var(--ring-light);
}

.reference-anatomy-spec:hover {
  background: var(--hover-2);
}

.reference-anatomy-spec-number {
  display: grid;
  min-width: 64px;
  height: 22px;
  padding: 0 5px;
  place-items: center;
  border-radius: var(--radius-pill);
  color: var(--ink-fg);
  background: var(--ink);
  font-family: var(--font-mono);
  font-size: 10px;
}

.reference-anatomy-spec > span:last-child {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.reference-anatomy-spec strong {
  color: var(--text);
  font-size: 12px;
}

.reference-anatomy-spec span span,
.reference-anatomy-spec em {
  color: var(--text-3);
  font-size: 11.5px;
  font-style: normal;
  line-height: 1.4;
}

.reference-anatomy-spec code {
  width: fit-content;
  max-width: 100%;
  padding: 3px 5px;
  overflow-wrap: anywhere;
  color: var(--text-2);
  background: var(--surface);
  border-radius: var(--radius-sm);
  box-shadow: var(--ring-light);
  font-size: 10px;
}

.reference-anatomy-token-row {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.reference-anatomy-token-row b {
  padding: 2px 5px;
  border-radius: var(--radius-sm);
  color: var(--text-2);
  background: var(--surface);
  box-shadow: var(--ring-light);
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 500;
}

.reference-archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}

.reference-archive-grid a {
  display: grid;
  gap: 4px;
  padding: 12px;
  color: inherit;
  text-decoration: none;
  background: var(--surface);
  border-radius: var(--radius-widget);
  box-shadow: var(--ring-light);
}

.reference-archive-grid a:hover {
  background: var(--hover-2);
}

.reference-archive-grid strong {
  font-size: 13px;
}

.reference-archive-grid span {
  color: var(--text-3);
  font-size: 11px;
}

.reference-taxonomy-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 16px;
  background: var(--surface);
  border-radius: var(--radius-container);
  box-shadow: var(--ring-light);
}

.reference-taxonomy-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.7fr);
  gap: 16px;
  align-items: start;
}

.reference-taxonomy-head p {
  margin: 0;
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-taxonomy-layout {
  display: grid;
  grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.reference-taxonomy-tree {
  position: sticky;
  top: 10px;
  display: grid;
  gap: 4px;
  padding: 8px;
  background: var(--surface-2);
  border-radius: var(--radius-widget);
  box-shadow: var(--ring-light);
}

.reference-taxonomy-tree-item {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 6px 7px;
  color: inherit;
  text-decoration: none;
  border-radius: var(--radius-control);
}

.reference-taxonomy-tree-item:hover {
  background: var(--hover);
}

.reference-taxonomy-tree-item code,
.reference-taxonomy-id code {
  width: fit-content;
  padding: 2px 5px;
  color: var(--ink-fg);
  background: var(--ink);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 10px;
}

.reference-taxonomy-tree-item span {
  font-size: 12px;
  line-height: 1.3;
}

.reference-taxonomy-tree .reference-taxonomy-level-2 {
  margin-left: 12px;
}

.reference-taxonomy-tree .reference-taxonomy-level-3 {
  margin-left: 24px;
}

.reference-taxonomy-table .reference-taxonomy-level-2 {
  box-shadow: inset 3px 0 0 var(--rule-soft);
}

.reference-taxonomy-table .reference-taxonomy-level-3 {
  box-shadow: inset 6px 0 0 var(--rule-soft);
}

.reference-taxonomy-table {
  display: grid;
  gap: 1px;
  min-width: 0;
  overflow: hidden;
  border-radius: var(--radius-widget);
  box-shadow: var(--ring-light);
}

.reference-taxonomy-row {
  display: grid;
  grid-template-columns: 90px minmax(180px, 0.9fr) minmax(190px, 1fr) minmax(220px, 1.1fr);
  gap: 12px;
  padding: 10px 12px;
  background: var(--surface);
}

.reference-taxonomy-row:target {
  background: var(--info-soft);
  outline: 2px solid var(--focus);
  outline-offset: -2px;
}

.reference-taxonomy-row-head {
  color: var(--text-3);
  background: var(--surface-2);
  font-size: 11px;
  font-weight: 650;
}

.reference-taxonomy-row:not(.reference-taxonomy-row-head) > span {
  display: grid;
  gap: 5px;
  align-content: start;
  min-width: 0;
}

.reference-taxonomy-row strong {
  color: var(--text);
  font-size: 13px;
}

.reference-taxonomy-row em,
.reference-taxonomy-row a {
  color: var(--text-3);
  font-size: 11.5px;
  font-style: normal;
  line-height: 1.4;
}

.reference-taxonomy-row a {
  color: var(--info);
  text-decoration: none;
  font-weight: 550;
}

.reference-taxonomy-row > span:not(.reference-taxonomy-id) code {
  width: fit-content;
  max-width: 100%;
  padding: 3px 5px;
  overflow-wrap: anywhere;
  color: var(--text-2);
  background: var(--surface-2);
  border-radius: var(--radius-control);
  font-size: 10.5px;
}

.reference-taxonomy-row .reference-tag {
  width: fit-content;
}

@media (max-width: 1100px) {
  .reference-taxonomy-head,
  .reference-taxonomy-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-taxonomy-tree {
    position: static;
  }

  .reference-taxonomy-row,
  .reference-taxonomy-row-head {
    grid-template-columns: minmax(0, 1fr);
  }
}

.reference-screen-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  font-weight: 500;
}

.reference-token-group,
.reference-type-ramp {
  background: var(--surface);
  box-shadow: var(--ring-light);
  border-radius: var(--radius-lg);
  min-width: 0;
}

.reference-spec {
  min-width: 0;
  border: 1px solid var(--rule-soft);
  border-left: 3px solid var(--rule);
  border-radius: var(--radius);
  background: transparent;
}

.reference-spec-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  padding: 12px 14px;
  background: var(--surface-2);
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-spec-head {
  grid-template-columns: minmax(0, 1fr);
}

.reference-spec-head h4,
.reference-token-group h4 {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0;
}

.reference-spec-title-line {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.reference-tag {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  font-size: 10.5px;
  font-weight: 650;
  box-shadow: var(--ring-light);
}

.reference-tag-shared {
  color: var(--text-2);
  background: var(--surface-2);
}

.reference-tag-composite {
  color: var(--info);
  background: var(--info-soft);
}

.reference-tag-unique {
  color: var(--warn);
  background: var(--warn-soft);
}

.reference-tag-deprecated {
  color: var(--critical);
  background: var(--critical-soft);
}

.reference-tag-candidate {
  color: var(--text-2);
  background: var(--surface-3);
}

.reference-spec-head code,
.reference-token code,
.reference-type-row code {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  border-radius: var(--radius-sm);
  padding: 3px 5px;
  white-space: normal;
  text-align: right;
}

.reference-spec-head code {
  justify-self: start;
  text-align: left;
  max-width: 100%;
}

.reference-used {
  margin-top: 3px;
  color: var(--text-3);
  font-size: 12px;
}

.reference-spec-body {
  display: grid;
  gap: 12px;
  padding: 14px;
  min-width: 0;
  background: var(--surface);
}

.reference-spec-candidate {
  border-left-color: var(--rule-firm);
}

.reference-spec-deprecated {
  border-left-color: var(--critical);
}

.reference-spec-unique {
  border-left-color: var(--rule-firm);
}

.reference-spec-composite {
  border-left-color: var(--rule-firm);
}

.reference-mini-toolbar,
.reference-command-row,
.reference-inline,
.reference-inline-tight {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  min-width: 0;
}

.reference-segmented-tabs {
  display: inline-flex;
  max-width: 100%;
  color: var(--text-2);
}

.reference-segmented-tab-track {
  --reference-tab-active-x: 3px;
  --reference-tab-active-width: 0px;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 2px;
  max-width: 100%;
  padding: 3px;
  overflow: hidden;
  border: 1px solid var(--rule);
  border-radius: var(--radius-tab-track);
  background: var(--surface);
}

.reference-segmented-tab-indicator {
  position: absolute;
  z-index: 0;
  top: 3px;
  bottom: 3px;
  left: 0;
  width: var(--reference-tab-active-width);
  min-width: var(--reference-tab-active-width);
  inline-size: var(--reference-tab-active-width);
  border-radius: var(--radius-control);
  background: linear-gradient(180deg, var(--surface-2) 0%, var(--surface-3) 100%);
  transform: translateX(var(--reference-tab-active-x));
  transition:
    transform 360ms cubic-bezier(0.2, 0.82, 0.16, 1),
    width 300ms cubic-bezier(0.22, 0.75, 0.16, 1);
  will-change: transform, width;
}

.reference-segmented-tab {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 12px;
  border: 0;
  border-radius: var(--radius-control);
  color: var(--text-2);
  background: transparent;
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  line-height: 1.15;
  white-space: nowrap;
  transition: color 150ms ease;
}

.reference-segmented-tab:hover,
.reference-segmented-tab:focus-visible,
.reference-segmented-tab[data-state="active"] {
  color: var(--text);
}

.reference-segmented-tab:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.reference-segmented-tab[data-state="active"] {
  font-weight: 500;
}

.reference-segmented-tab-count {
  display: inline-flex;
  align-items: center;
  min-height: 17px;
  padding: 1px 6px;
  border-radius: var(--radius-control);
  color: var(--text-3);
  background: var(--surface-2);
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
}

.reference-segmented-tab[data-state="active"] .reference-segmented-tab-count {
  background: var(--surface);
}

.reference-segmented-tabs-compact .reference-segmented-tab {
  min-height: 23px;
  padding: 4px 8px;
  font-size: 9.5px;
}

.reference-segmented-tabs-compact .reference-segmented-tab-count {
  min-height: 14px;
  padding: 1px 4px;
  font-size: 8.5px;
}

@media (prefers-reduced-motion: reduce) {
  .reference-segmented-tab-indicator {
    transition: none;
  }
}

.reference-breadcrumb-frame {
  padding: 10px 12px;
  border-radius: var(--radius);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}

.reference-claim-facts-sample {
  display: grid;
  gap: 12px;
  align-content: start;
  min-height: 330px;
}

.reference-claim-facts-layout {
  display: grid;
  grid-template-columns: minmax(180px, max-content) minmax(240px, 1fr);
  gap: 18px;
  align-items: start;
}

.reference-claim-facts-state {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.reference-claim-facts-box {
  margin-top: 2px;
}

.reference-claim-facts-popover {
  width: min(360px, calc(100vw - 64px));
  max-height: 250px;
}

.reference-mini-toolbar {
  justify-content: space-between;
}

.reference-inline-tight {
  gap: 6px;
}

.reference-spec-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
}

#reference-documents .reference-spec-grid {
  grid-template-columns: minmax(0, 1fr);
}

#reference-claim .reference-spec-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.reference-spec {
  overflow: hidden;
}

.reference-spec-wide {
  grid-column: 1 / -1;
}

.reference-token-layout {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.reference-token-group {
  padding: 12px;
  display: grid;
  gap: 10px;
}

.reference-token-list {
  display: grid;
  gap: 6px;
}

.reference-token {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  min-height: 28px;
  font-size: 12px;
  color: var(--text-2);
}

.reference-token-swatch {
  width: 22px;
  height: 22px;
  border-radius: var(--radius-sm);
  box-shadow: var(--ring-light);
}

.reference-token-radius-swatch {
  display: grid;
  width: 46px;
  min-width: 46px;
  border-radius: var(--reference-token-radius);
  place-items: center;
  background: var(--surface);
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 8.5px;
  line-height: 1.05;
  text-align: center;
}

.reference-token-shape {
  grid-template-columns: 46px minmax(0, 1fr) auto;
}

.reference-radius-matrix {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 14px;
  background: var(--surface);
  box-shadow: var(--ring-light);
}

.reference-radius-matrix-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 10px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-radius-matrix-head > div {
  display: grid;
  gap: 4px;
}

.reference-radius-matrix-head strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 650;
}

.reference-radius-matrix-head span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-radius-matrix-table {
  display: grid;
  gap: 1px;
  min-width: 0;
  overflow: hidden;
  box-shadow: var(--ring-light);
}

.reference-radius-matrix-row {
  display: grid;
  grid-template-columns:
    minmax(160px, 0.52fr)
    minmax(190px, 0.78fr)
    minmax(180px, 0.68fr)
    minmax(190px, 0.78fr)
    minmax(240px, 1fr);
  gap: 10px;
  align-items: start;
  padding: 9px 10px;
  background: var(--surface);
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.4;
}

.reference-radius-matrix-header {
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 10.5px;
  font-weight: 650;
  text-transform: uppercase;
}

.reference-radius-matrix-standard {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
}

.reference-radius-matrix-standard div,
.reference-radius-matrix-instances {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  min-width: 0;
}

.reference-radius-matrix-standard div {
  flex-direction: column;
  align-items: flex-start;
}

.reference-radius-matrix-standard strong {
  color: var(--text);
  font-size: 11.5px;
  font-weight: 650;
}

.reference-radius-matrix-repeat {
  width: 30px;
  height: 1px;
  background: var(--rule);
}

.reference-radius-matrix-sample {
  width: 30px;
  height: 22px;
  background: var(--surface-3);
  box-shadow: inset 0 0 0 1px var(--rule);
}

.reference-radius-matrix-preview {
  min-width: 0;
}

.reference-radius-matrix-preview .reference-radius-context-visual {
  min-height: 48px;
  padding: 7px;
}

.reference-radius-matrix code,
.reference-radius-matrix-head code {
  width: fit-content;
  max-width: 100%;
  padding: 2px 4px;
  overflow-wrap: anywhere;
  background: var(--surface-2);
  color: var(--text-2);
  box-shadow: var(--ring-light);
  font-size: 10px;
}

.reference-type-ramp {
  overflow: hidden;
}

.reference-type-row {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 12px 14px;
  box-shadow: inset 0 -1px 0 var(--rule);
}

.reference-type-row:last-child {
  box-shadow: none;
}

.reference-type-label {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 500;
}

.reference-source-grid,
.reference-form-grid,
.reference-empty-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.reference-source-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
  padding: 8px;
  border-radius: var(--radius);
  background: var(--surface-2);
}

.reference-stack {
  display: grid;
  gap: 10px;
}

.reference-work-row-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
}

.reference-work-row-summary > div,
.reference-work-row-card {
  min-width: 0;
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  border-radius: var(--radius);
}

.reference-work-row-summary > div {
  display: grid;
  gap: 4px;
  align-content: start;
  padding: 10px 12px;
}

.reference-work-row-summary strong,
.reference-work-row-card-head {
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}

.reference-work-row-summary span {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-work-row-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.reference-work-row-card {
  overflow: hidden;
}

.reference-work-row-item {
  background: var(--surface);
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-work-row-item .reference-work-row-example {
  box-shadow: none;
}

.reference-work-row-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-work-row-example {
  background: var(--surface);
}

.reference-work-row-example .work-row-lead {
  align-self: stretch;
  align-items: stretch;
  flex: 0 0 96px;
  width: 96px;
}

.reference-activity-compact-row {
  display: grid;
  grid-template-columns: 78px 26px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  background: var(--surface);
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-activity-compact-row .activity-time {
  color: var(--text-3);
}

.reference-activity-compact-text {
  min-width: 0;
  overflow: hidden;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 400;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reference-work-row-field-list {
  display: grid;
  gap: 0;
  padding: 0 12px 10px 126px;
}

.reference-activity-compact-fields {
  padding: 2px 12px 10px;
  background: var(--surface);
}

.reference-work-row-field-row {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 10px;
  padding: 5px 0;
  border-top: 1px solid var(--rule-soft);
  font-size: 11.5px;
  line-height: 1.35;
}

.reference-work-row-field-row span {
  color: var(--text-3);
  font-weight: 500;
}

.reference-work-row-field-row strong {
  color: var(--text-2);
  font-weight: 400;
}

.reference-claim-tab-sample {
  min-height: 0;
}

.reference-mini-claim-tab {
  min-height: 0;
  box-shadow: var(--ring-light);
}

.reference-mini-claim-tab .claim-tab-header {
  padding: 12px;
  gap: 10px;
}

.reference-mini-claim-tab .claim-tab-title {
  font-size: 14px;
}

.reference-mini-claim-tab .claim-tab-subtitle {
  font-size: 11.5px;
}

.reference-mini-claim-tab .claim-tab-body {
  padding: 0;
}

.reference-overview-dashboard {
  gap: 12px;
}

.reference-sticky-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.reference-sticky-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.reference-sticky-grid .textarea {
  min-height: 88px;
}

.reference-issue-workspace .issue-workspace-shell {
  min-height: 320px;
}

.reference-cac-workspace {
  padding: 0;
}

.reference-economics-workspace {
  padding: 0;
}

.reference-economics-workspace .economics-workpaper {
  margin: 0;
}

.reference-ui .claim-update-queue-summary {
  margin: 0;
}

.reference-ui .claim-update-row {
  background: var(--surface);
}

.reference-ui .activity-row {
  grid-template-columns: 64px minmax(0, 1fr);
}

.reference-ui .notes-thread-surface {
  min-height: 0;
}

.reference-ui .notes-toolbar {
  position: static;
}

.reference-ui .new-document-chooser {
  grid-template-columns: minmax(0, 1fr);
}

.reference-all-claim-actions {
  display: grid;
  gap: 12px;
  align-content: start;
}

.reference-all-claim-actions.is-menu-open {
  min-height: 760px;
}

.reference-all-claim-actions .claim-actions-dropdown {
  position: relative;
}

.reference-all-claim-actions .claim-actions-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  max-height: min(70vh, 720px);
  z-index: 30;
}

.reference-document-view-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}

.reference-document-view-panel {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.reference-document-tables-view {
  padding: 0;
}

.reference-document-tables-view .dynamic-fact-toolbar,
.reference-document-tables-view .dynamic-fact-controls,
.reference-document-tables-view .dynamic-fact-formula-bar {
  padding-left: 0;
  padding-right: 0;
}

.reference-document-tables-view .dynamic-fact-table-shell {
  margin: 0;
}

.reference-summary-action-example {
  display: grid;
  gap: 6px;
}

.reference-pattern-meta,
.reference-pattern-note {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-pattern-note {
  padding: 10px 12px;
  border-radius: var(--radius);
  background: var(--surface-2);
  box-shadow: var(--ring-light);
}

.reference-empty-grid .empty-state {
  min-height: 150px;
}

.reference-skeleton {
  min-height: 150px;
  box-shadow: var(--ring-light);
  border-radius: var(--radius);
  padding: 8px;
}

.reference-document-review-frame {
  height: min(640px, 72vh);
  min-height: 520px;
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--ring-light);
  background: var(--surface);
}

.reference-document-review-workspace {
  height: 100%;
  grid-template-columns: minmax(320px, 0.95fr) minmax(360px, 1.05fr);
}

.reference-dynamic-fact-workspace {
  padding: 0;
}

.reference-source-preview-grid {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(260px, 1fr);
  gap: 12px;
  align-items: start;
}

.reference-source-preview-grid .doc-page {
  min-height: 360px;
}

.reference-tab-filter-comparison {
  display: grid;
  gap: 12px;
}

.reference-tab-filter-canonical {
  display: grid;
  gap: 6px;
  padding: 10px;
  background: var(--surface-2);
  box-shadow: var(--ring-light);
  border-radius: var(--radius);
}

.reference-tab-filter-canonical .tab-filter-bar {
  padding-bottom: 0;
}

.reference-tab-filter-variants {
  display: grid;
  gap: 10px;
}

.reference-tab-filter-variant {
  display: grid;
  gap: 8px;
  padding: 10px;
  background: var(--surface);
  box-shadow: var(--ring-light);
  border-radius: var(--radius);
  min-width: 0;
}

.reference-tab-filter-variant-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

.reference-tab-filter-title {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 600;
}

.reference-tab-filter-demo {
  min-width: 0;
}

.reference-tab-filter-demo .tabs,
.reference-tab-filter-demo .filter-bar {
  padding-inline: 0;
}

.reference-tab-filter-demo .filter-bar {
  padding-block: 8px;
}

.reference-legacy-filter-row {
  margin-bottom: 0;
}

.reference-deadline-head {
  min-height: 34px;
}

.reference-pdf-shell {
  min-height: 180px;
}

.reference-modal-wire,
.reference-drawer-wire {
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  background: var(--surface);
}

.reference-modal-wire {
  max-width: 520px;
}

.reference-drawer-wire {
  max-width: 360px;
  margin-left: auto;
}

.reference-ui .filter-bar {
  min-width: 0;
}

.reference-ui .table-shell {
  min-width: 0;
}

.reference-pr7-board {
  display: grid;
  gap: 18px;
}

.reference-pr7-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.reference-pr7-summary > div,
.reference-pr7-decision-table,
.reference-pr7-slice {
  min-width: 0;
  background: var(--surface);
  border-radius: var(--radius-widget);
  box-shadow: var(--widget-shadow);
  overflow: hidden;
}

.reference-pr7-summary > div {
  display: grid;
  gap: 4px;
  padding: var(--widget-padding);
}

.reference-pr7-summary strong,
.reference-pr7-slice-copy span {
  color: var(--text);
  font-size: 12px;
  font-weight: 650;
}

.reference-pr7-summary span,
.reference-pr7-slice-copy p,
.reference-pr7-decision-row em {
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
}

.reference-pr7-decision-table {
  display: grid;
}

.reference-pr7-decision-head,
.reference-pr7-decision-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1.7fr;
  gap: 12px;
  align-items: start;
  padding: 10px 14px;
}

.reference-pr7-decision-head {
  background: var(--widget-header-bg);
  box-shadow: inset 0 -1px 0 var(--widget-divider);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 650;
}

.reference-pr7-decision-row {
  color: inherit;
  text-decoration: none;
  box-shadow: inset 0 -1px 0 var(--rule-soft);
}

.reference-pr7-decision-row:hover,
.reference-pr7-decision-row:focus-visible {
  background: var(--hover);
  outline: none;
}

.reference-pr7-decision-row span {
  min-width: 0;
}

.reference-pr7-decision-row strong,
.reference-pr7-decision-row em {
  display: block;
}

.reference-pr7-slice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.reference-pr7-slice {
  display: grid;
  align-content: start;
}

.reference-pr7-slice-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  padding: 14px var(--widget-padding-x) 12px;
  background: var(--widget-header-bg);
  box-shadow: inset 0 -1px 0 var(--widget-divider);
}

.reference-pr7-slice-head code {
  max-width: 360px;
  white-space: normal;
  text-align: right;
}

.reference-pr7-slice-copy {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: var(--rule-soft);
}

.reference-pr7-slice-copy > div {
  display: grid;
  gap: 4px;
  padding: 12px var(--widget-padding-x);
  background: var(--surface);
}

.reference-pr7-slice-copy p {
  margin: 0;
}

.reference-pr7-visual {
  padding: var(--widget-padding);
}

.reference-pr7-mini-page {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.reference-pr7-mini-page .data-list-card,
.reference-pr7-mini-page .table-shell,
.reference-pr7-mini-page .row-list,
.reference-pr7-mini-page .review-needed-list,
.reference-pr7-mini-page .filter-bar,
.reference-pr7-mini-page .tab-filter-bar {
  min-width: 0;
}

.reference-pr7-mini-page .table-shell {
  max-height: 260px;
}

.reference-pr7-mini-page .table td .work-row {
  min-width: 420px;
}

.reference-pr7-contained-filter {
  background: var(--surface-2);
  border-radius: var(--radius-control);
  padding: 8px;
}

.reference-pr7-slice > .reference-component-links {
  padding: 0 var(--widget-padding-x) var(--widget-padding-y);
}

@media (max-width: 1180px) {
  .reference-anatomy-layout,
  .reference-page-map,
  .reference-token-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .reference-anatomy-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-anatomy-map-stage,
  .reference-measure-legend {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-decomposition-rail {
    position: static;
  }
}

@media (max-width: 860px) {
  .reference-ui {
    padding: 16px 14px 28px;
  }

  .reference-anatomy-variant-head,
  .reference-anatomy-card-head,
  .reference-anatomy-layout,
  .reference-anatomy-map-stage,
  .reference-measure-legend,
  .reference-hero,
  .reference-spec-grid,
  #reference-claim .reference-spec-grid,
  .reference-page-map,
  .reference-work-row-grid,
  .reference-work-row-summary,
  .reference-token-layout,
  .reference-source-grid,
  .reference-source-preview-grid,
  .reference-document-view-grid,
  .reference-form-grid,
  .reference-empty-grid,
  .reference-sticky-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-anatomy-viewport {
    grid-template-columns: 86px minmax(0, 1fr);
    min-height: 520px;
  }

  .reference-anatomy-sidebar {
    padding-inline: 8px;
  }

  .reference-anatomy-brand strong,
  .reference-anatomy-nav-label,
  .reference-anatomy-nav-item b,
  .reference-anatomy-sidebar-user strong {
    display: none;
  }

  .reference-anatomy-widget-grid,
  .reference-anatomy-widget-grid.claim,
  .reference-anatomy-intro-row,
  .reference-canvas-audit-row,
  .reference-widget-layer-row,
  .reference-widget-standard,
  .reference-pr7-summary,
  .reference-pr7-slice-grid,
  .reference-pr7-slice-copy,
  .reference-pr7-decision-head,
  .reference-pr7-decision-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-pr7-slice-head {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-pr7-slice-head code {
    max-width: none;
    text-align: left;
  }

  .reference-document-review-frame {
    height: auto;
  }

  .reference-document-review-workspace {
    grid-template-columns: minmax(0, 1fr);
  }

  .reference-type-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
  }

  .reference-work-row-field-list {
    padding-left: 12px;
  }

  .reference-work-row-field-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 2px;
  }
}

/* ============================================================
 * LIVE SURFACE STANDARDIZATION — PR 4-6 implementation
 * ============================================================ */
.content,
.app-page-scaffold,
.app-page-body,
.claim-tab-scaffold,
.claim-tab-body {
  background: var(--canvas-bg);
}

.header,
.lx-8hg7bi {
  background: var(--chrome-bg);
}

.page-header-surface,
.app-page-header,
.claim-identity-header {
  background: var(--page-header-bg);
}

.claim-tab-header {
  background: var(--canvas-bg);
}

.data-list-card,
.my-week-strip-card,
.overview-row-section,
.table-shell {
  background: var(--widget-bg);
  border-radius: var(--radius-widget);
  box-shadow: var(--widget-shadow);
  overflow: hidden;
}

.app-page-body > .canvas-table-shell,
.canvas-table-page > .canvas-table-shell {
  margin: var(--canvas-gutter-top) var(--canvas-gutter-side);
  padding: 0;
}

.data-list-card > .card-head,
.my-week-strip-card > .card-head,
.overview-row-section > .card-head {
  padding: 14px var(--widget-padding-x) 12px;
  margin: 0;
  background: var(--widget-header-bg);
  box-shadow: inset 0 -1px 0 var(--widget-divider);
}

.data-list-card > .card-body,
.data-list-card > .card-body.tight,
.my-week-strip-card > .card-body,
.my-week-strip-card > .card-body.tight,
.overview-row-section > .card-body,
.overview-row-section > .card-body.tight {
  padding: var(--widget-padding);
}

.data-list-card > .card-body.tight,
.overview-row-section > .card-body.tight {
  gap: 0;
}

.table-shell > .table-wrap,
.table-shell-with-rail > .table-wrap,
.app-page-body .table-shell > .table-wrap,
.claim-tab-body .table-shell > .table-wrap {
  padding: 0 var(--table-shell-padding-x);
  background: var(--widget-bg);
  overflow: auto;
  border-radius: 0;
}

.table-shell > .data-view-rail,
.data-list-card .data-view-rail,
.overview-row-section .data-view-rail {
  padding-inline: var(--widget-padding-x);
  background: var(--widget-bg);
}

.table-shell .table thead th,
.table-shell .tbl thead th {
  background: var(--widget-header-bg);
}

.work-widget-grid,
.my-work-root .work-widget-grid,
.overview-work-grid {
  column-gap: var(--widget-gap);
  row-gap: var(--widget-gap);
  margin-top: 0;
}

.my-work-root,
.claim-tab-body > .hub,
.claim-tab-body > .lx-28v4rf,
.claim-tab-body > .lx-v3wu3v {
  gap: var(--widget-gap);
}

.my-work-root > .my-week-strip-card,
.my-work-root > .awaiting-review-card,
.my-work-root > .work-widget-grid {
  margin-block: 0;
}

.work-row,
.overview-row-section .list-row,
.overview-activity-compact-row {
  border-bottom-color: var(--widget-divider);
}

.claim-tab-body .card:is(.data-list-card, .overview-row-section),
.app-page-body .card:is(.data-list-card, .my-week-strip-card, .overview-row-section),
.claim-tab-scaffold-list .claim-tab-body > .lx-28v4rf > .card.data-list-card,
.claim-tab-scaffold-timeline .claim-tab-body > .lx-28v4rf > .card.data-list-card {
  border-radius: var(--radius-widget);
}

/* Preserved hashed classes (still in use outside Slice C scope) */
.lx-pydrhg { font-size: 12.5px; color: var(--text); }
.lx-mn1hhg { font-size: 12px; }
