[data-theme="rev"] {
  --theme-font-mono: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, 'Liberation Mono', monospace;
  --theme-font-display: 'Space Grotesk', system-ui, sans-serif;
  --theme-font-serif: 'Source Serif 4', Georgia, 'Times New Roman', serif;
  --theme-fs-xs: 11px;
  --theme-fs-sm: 12px;
  --theme-fs-base: 13px;
  --theme-fs-md: 16px;
  --theme-fs-lg: 17px;
  --theme-fs-xl: 20px;
  --theme-lh-tight: 1.35;
  --theme-lh-normal: 1.55;
  --theme-lh-relaxed: 1.6;
  --theme-ls-tight: -0.012em;
  --theme-ls-normal: 0.02em;
  --theme-ls-caps: 0.14em;
  --theme-radius-sm: 0px;
  --theme-radius-md: 0px;
  --theme-radius-lg: 0px;
  --theme-radius-full: 0px;
  --theme-sp-1: 2px;
  --theme-sp-2: 4px;
  --theme-sp-3: 6px;
  --theme-sp-4: 8px;
  --theme-sp-5: 10px;
  --theme-sp-6: 12px;
  --theme-sp-7: 14px;
  --theme-sp-8: 16px;
  --theme-sp-9: 20px;
  --theme-sp-10: 24px;
  --theme-bg: #f6f5f1;
  --theme-bg-2: #eeece4;
  --theme-bg-3: #e3e0d3;
  --theme-ink: #0a0a0a;
  --theme-ink-2: #2a2a2a;
  --theme-ink-3: #5a5a55;
  --theme-ink-4: #8a877d;
  --theme-rule: #0a0a0a;
  --theme-rule-soft: #cfccc0;
  --theme-hazard: #f5d300;
  --theme-hazard-2: #ffe44a;
  --theme-add-strong: #0e7a2c;
  --theme-del-strong: #a01818;
  --theme-review: #b87a00;
  --theme-review-stage: #d33aa6;
  --theme-merged: #5b3aa6;
  --theme-mod: #036b78;
  --theme-link: #1f3fbf;
  --theme-surface-bg: #f6f5f1;
  --theme-surface-raised: #eeece4;
  --theme-surface-hover: #e3e0d3;
  --theme-surface-active: #e3e0d3;
  --theme-surface-code: #eeece4;
  --theme-surface-invert: #0a0a0a;
  --theme-border: #0a0a0a;
  --theme-border-light: #cfccc0;
  --theme-text: #0a0a0a;
  --theme-text-secondary: #2a2a2a;
  --theme-text-tertiary: #5a5a55;
  --theme-text-invert: #f6f5f1;
  --theme-text-muted: #8a877d;
  --theme-accent: #1f3fbf;
  --theme-accent-hover: #162e96;
  --theme-accent-light: #dbeafe;
  --theme-avatar: #a0785a;
  --theme-add: #0e7a2c;
  --theme-add-bg: #d4ebd6;
  --theme-add-bg-line: #e8f4e5;
  --theme-del: #a01818;
  --theme-del-bg: #f3cdc7;
  --theme-del-bg-line: #f8e3df;
  --theme-draft-fg: #f5d300;
  --theme-draft-bg: #fef9c3;
  --theme-review-fg: #d33aa6;
  --theme-review-bg: #fae8ff;
  --theme-approved-fg: #0e7a2c;
  --theme-approved-bg: #dcfce7;
  --theme-revised-fg: #036b78;
  --theme-revised-bg: #cffafe;
  --theme-merged-fg: #5b3aa6;
  --theme-merged-bg: #f3f4f6;
  --theme-danger-fg: #a01818;
  --theme-danger-bg: #f3cdc7;
  --theme-heat-0: transparent;
  --theme-heat-1: #e8dfd0;
  --theme-heat-2: #dbc4a0;
  --theme-heat-3: #c9a46e;
  --theme-heat-4: #b07d3a;
  --theme-heat-5: #8b5e1a;
}

[data-theme="rev-dark"] {
  --theme-font-mono: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, 'Liberation Mono', monospace;
  --theme-font-display: 'Space Grotesk', system-ui, sans-serif;
  --theme-font-serif: 'Source Serif 4', Georgia, 'Times New Roman', serif;
  --theme-fs-xs: 11px;
  --theme-fs-sm: 12px;
  --theme-fs-base: 13px;
  --theme-fs-md: 16px;
  --theme-fs-lg: 17px;
  --theme-fs-xl: 20px;
  --theme-lh-tight: 1.35;
  --theme-lh-normal: 1.55;
  --theme-lh-relaxed: 1.6;
  --theme-ls-tight: -0.012em;
  --theme-ls-normal: 0.02em;
  --theme-ls-caps: 0.14em;
  --theme-radius-sm: 0px;
  --theme-radius-md: 0px;
  --theme-radius-lg: 0px;
  --theme-radius-full: 0px;
  --theme-sp-1: 2px;
  --theme-sp-2: 4px;
  --theme-sp-3: 6px;
  --theme-sp-4: 8px;
  --theme-sp-5: 10px;
  --theme-sp-6: 12px;
  --theme-sp-7: 14px;
  --theme-sp-8: 16px;
  --theme-sp-9: 20px;
  --theme-sp-10: 24px;
  --theme-bg: #111111;
  --theme-bg-2: #191919;
  --theme-bg-3: #232323;
  --theme-ink: #e0e0e0;
  --theme-ink-2: #b0b0b0;
  --theme-ink-3: #707070;
  --theme-ink-4: #4a4a4a;
  --theme-rule: #5a5a5a;
  --theme-rule-soft: #2a2a2a;
  --theme-hazard: #e8b41a;
  --theme-hazard-2: #ffd84a;
  --theme-add-strong: #5cd47a;
  --theme-del-strong: #ff857c;
  --theme-review: #ffc564;
  --theme-review-stage: #f06bc6;
  --theme-merged: #b39bff;
  --theme-mod: #4ad7e6;
  --theme-link: #92aaff;
  --theme-surface-bg: #111111;
  --theme-surface-raised: #191919;
  --theme-surface-hover: #232323;
  --theme-surface-active: #232323;
  --theme-surface-code: #191919;
  --theme-surface-invert: #e0e0e0;
  --theme-border: #5a5a5a;
  --theme-border-light: #2a2a2a;
  --theme-text: #e0e0e0;
  --theme-text-secondary: #b0b0b0;
  --theme-text-tertiary: #707070;
  --theme-text-invert: #111111;
  --theme-text-muted: #4a4a4a;
  --theme-accent: #92aaff;
  --theme-accent-hover: #a8baff;
  --theme-accent-light: #1a2240;
  --theme-avatar: #a0785a;
  --theme-add: #5cd47a;
  --theme-add-bg: #0f2a16;
  --theme-add-bg-line: #142e1a;
  --theme-del: #ff857c;
  --theme-del-bg: #2e1212;
  --theme-del-bg-line: #361616;
  --theme-draft-fg: #e8b41a;
  --theme-draft-bg: #2a2410;
  --theme-review-fg: #f06bc6;
  --theme-review-bg: #2a1428;
  --theme-approved-fg: #5cd47a;
  --theme-approved-bg: #142a14;
  --theme-revised-fg: #4ad7e6;
  --theme-revised-bg: #122428;
  --theme-merged-fg: #b39bff;
  --theme-merged-bg: #1a1a2a;
  --theme-danger-fg: #ff857c;
  --theme-danger-bg: #2e1212;
  --theme-heat-0: transparent;
  --theme-heat-1: #2a2a2a;
  --theme-heat-2: #3a3a3a;
  --theme-heat-3: #4a4a4a;
  --theme-heat-4: #5a5a5a;
  --theme-heat-5: #6a6a6a;
}



*, *::before, *::after { 
  box-sizing: border-box;
  margin: 0px;
  padding: 0px;
}

body { 
  background: var(--theme-bg);
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
  line-height: var(--theme-lh-normal);
}

#app { 
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

#app > main { 
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0px;
}

[data-collapsed] > :not(:first-child) { 
  display: none;
}

[data-collapsed] [data-chevron] { 
  transform: rotate(-90deg);
}

a { 
  color: var(--theme-link);
  text-decoration: none;
}

a:hover { 
  text-decoration: underline;
}

code { 
  background: var(--theme-bg-2);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
  padding: 1px 4px;
}

::-webkit-scrollbar { 
  height: 6px;
  width: 6px;
}

::-webkit-scrollbar-track { 
  background: transparent;
}

::-webkit-scrollbar-thumb { 
  background: var(--theme-rule-soft);
}

::-webkit-scrollbar-thumb:hover { 
  background: var(--theme-ink-3);
}

.Label { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  letter-spacing: var(--theme-ls-caps);
  text-transform: uppercase;
}

.Prose { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-md);
  line-height: var(--theme-lh-relaxed);
}

.Prose.sm { 
  color: var(--theme-text-secondary);
  font-size: var(--theme-fs-base);
  line-height: 1.5;
}

.Title { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-xl);
  font-weight: 600;
  letter-spacing: var(--theme-ls-tight);
}

.Num { 
  color: var(--theme-accent);
  font-family: var(--theme-font-mono);
  font-weight: 600;
}

.Meta { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.Meta.block { 
  display: block;
}

.Meta.autoLeft { 
  margin-left: auto;
  padding-left: 12px;
}

.Meta.hidden { 
  visibility: hidden;
}

.Meta.nowrap { 
  white-space: nowrap;
}

.Avatar { 
  border-radius: 0;
  display: inline-flex;
  flex-shrink: 0;
  overflow: hidden;
  vertical-align: middle;
}

.Avatar.size-sm { 
  height: 20px;
  width: 20px;
}

.Avatar.size-md { 
  height: 24px;
  width: 24px;
}

.Avatar.size-lg { 
  height: 28px;
  width: 28px;
}

.Avatar.inline { 
  margin-right: 4px;
}

.Badge { 
  align-items: center;
  border-radius: var(--theme-radius-sm);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.4;
  padding: 2px 6px;
  text-transform: uppercase;
}

.Badge.state-draft { 
  background: var(--theme-draft-bg);
  color: var(--theme-draft-fg);
}

.Badge.state-review { 
  background: var(--theme-review-bg);
  color: var(--theme-review-fg);
}

.Badge.state-approved { 
  background: var(--theme-approved-bg);
  color: var(--theme-approved-fg);
}

.Badge.state-merged { 
  background: var(--theme-merged-bg);
  color: var(--theme-merged-fg);
}

.Badge.size-lg { 
  font-size: var(--theme-fs-sm);
  padding: 3px 8px;
}

.Button { 
  align-items: center;
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border);
  border-radius: var(--theme-radius-md);
  color: var(--theme-text);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 13px;
  font-weight: 500;
  gap: 4px;
  line-height: 1;
  padding: 5px 10px;
  transition: background 0.1s;
}

.Button:hover { 
  background: var(--theme-surface-raised);
}

.Button.intent-primary { 
  background: var(--theme-accent);
  border-color: var(--theme-accent);
  color: var(--theme-text-invert);
}

.Button.intent-primary:hover { 
  background: var(--theme-accent-hover);
}

.Button.intent-review { 
  background: var(--theme-review-bg);
  border-color: var(--theme-review-fg);
  color: var(--theme-review-fg);
}

.Button.intent-review:hover { 
  opacity: 0.85;
}

.Button.intent-success { 
  background: var(--theme-surface-bg);
  border-color: var(--theme-add);
  color: var(--theme-add);
}

.Button.intent-success:hover { 
  background: var(--theme-add-bg-line);
}

.Button.intent-danger { 
  background: var(--theme-surface-bg);
  border-color: var(--theme-del);
  color: var(--theme-del);
}

.Button.intent-danger:hover { 
  background: var(--theme-del-bg-line);
}

.Button.intent-ghost { 
  background: none;
  border-color: transparent;
}

.Button.intent-ghost:hover { 
  background: var(--theme-surface-raised);
}

.Button.size-sm { 
  font-size: var(--theme-fs-sm);
  padding: 3px 7px;
}

.Input { 
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border);
  border-radius: var(--theme-radius-md);
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: 13px;
  outline: none;
  padding: 4px 8px;
  transition: border-color 0.15s;
}

.Input::placeholder { 
  color: var(--theme-text-tertiary);
}

.Input:focus { 
  border-color: var(--theme-accent);
}

.Input.width-xs { 
  width: 90px;
}

.Input.width-sm { 
  width: 180px;
}

.Input.width-md { 
  width: 240px;
}

.Input.width-lg { 
  width: 320px;
}

.Input.width-full { 
  max-width: 480px;
  width: 100%;
}

.Input.size-sm { 
  font-size: var(--theme-fs-sm);
  padding: 3px 6px;
}

.Input.flex { 
  flex: 1;
}

.Select { 
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border);
  border-radius: var(--theme-radius-md);
  color: var(--theme-text);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  font-size: 13px;
  padding: 3px 8px;
}

.DiffStat { 
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  gap: 6px;
}

.DiffStat_Add { 
  color: var(--theme-add);
}

.DiffStat_Del { 
  color: var(--theme-del);
}

.FilePill { 
  background: var(--theme-surface-raised);
  border-radius: var(--theme-radius-sm);
  color: var(--theme-text-tertiary);
  display: inline-block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: 2px 6px;
}

.Comment { 
  background: var(--theme-surface-raised);
  border-left: 2px solid var(--theme-border);
  border-radius: 0 var(--theme-radius-md) var(--theme-radius-md) 0;
  padding: 6px 10px;
}

.Comment_Author { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
  font-weight: 600;
}

.Comment_Time { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-left: 6px;
}

.Comment_Body { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-md);
  line-height: var(--theme-lh-relaxed);
  margin-top: 3px;
}

.UnreadDot { 
  background: var(--theme-accent);
  border-radius: var(--theme-radius-full);
  display: inline-block;
  flex-shrink: 0;
  height: 6px;
  width: 6px;
}

.HeatBar { 
  border-radius: 1px 1px 0 0;
  display: inline-block;
  min-height: 18px;
  width: 3px;
}

.HeatBar.level-0 { 
  background: var(--theme-heat-0);
}

.HeatBar.level-1 { 
  background: var(--theme-heat-1);
}

.HeatBar.level-2 { 
  background: var(--theme-heat-2);
}

.HeatBar.level-3 { 
  background: var(--theme-heat-3);
}

.HeatBar.level-4 { 
  background: var(--theme-heat-4);
}

.HeatBar.level-5 { 
  background: var(--theme-heat-5);
}

.KindBadge { 
  align-items: center;
  border-radius: var(--theme-radius-sm);
  display: inline-flex;
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 700;
  height: 24px;
  justify-content: center;
  width: 24px;
}

.KindBadge.kind-modified { 
  background: #e0f7fa;
  color: #00838f;
}

.KindBadge.kind-added { 
  background: #e8f5e9;
  color: #43a047;
}

.KindBadge.kind-deleted { 
  background: #ffebee;
  color: #e53935;
}

.KindBadge.kind-renamed { 
  background: #fff8e1;
  color: #f9a825;
}

[data-theme="rev-dark"] .KindBadge[class*="modified"] { 
  background: #0a2628;
  color: #4dd0e1;
}

[data-theme="rev-dark"] .KindBadge[class*="added"] { 
  background: #0d2818;
  color: #66bb6a;
}

[data-theme="rev-dark"] .KindBadge[class*="deleted"] { 
  background: #2c0b0e;
  color: #ef5350;
}

[data-theme="rev-dark"] .KindBadge[class*="renamed"] { 
  background: #2c2200;
  color: #fdd835;
}

.TopBar { 
  align-items: center;
  background: var(--theme-bg);
  border-bottom: 1.5px solid var(--theme-rule);
  color: var(--theme-ink);
  display: flex;
  font-size: 13px;
  justify-content: space-between;
  letter-spacing: var(--theme-ls-normal);
  padding: 12px max(36px, calc(50% - 684px));
  position: sticky;
  top: 0px;
  z-index: 10;
}

.TopBarLogo { 
  align-items: baseline;
  color: var(--theme-ink);
  display: inline-flex;
  font-family: var(--theme-font-display);
  font-size: 22px;
  font-weight: 700;
  gap: 10px;
  letter-spacing: -0.04em;
}

.TopBarNav { 
  align-items: center;
  display: flex;
  gap: 16px;
}

.TopBarLink { 
  color: var(--theme-ink-3);
  font-family: var(--theme-font-mono);
  font-size: 13px;
  text-decoration: none;
}

.TopBarLink:hover { 
  color: var(--theme-ink);
  text-decoration: none;
}

.TopBarLink.active { 
  color: var(--theme-ink);
  font-weight: 600;
}

.TopBarAvatar { 
  align-items: center;
  background: var(--theme-avatar);
  color: var(--theme-text-invert);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 600;
  height: 22px;
  justify-content: center;
  margin-left: var(--theme-sp-3);
  text-decoration: none;
  width: 22px;
}

.TopBarAvatar:hover { 
  opacity: 0.8;
  text-decoration: none;
}

.SectionHeader { 
  border-bottom: 1px solid var(--theme-border-light);
  color: var(--theme-text-tertiary);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  letter-spacing: var(--theme-ls-caps);
  margin-bottom: 6px;
  padding-bottom: 4px;
  text-transform: uppercase;
}

.SectionHeader.clickable { 
  align-items: baseline;
  cursor: pointer;
  display: flex;
}

.SectionHeader.danger { 
  color: var(--theme-del);
}

.KBar { 
  background: var(--theme-bg-2);
  color: var(--theme-text-tertiary);
  display: flex;
  font-size: var(--theme-fs-sm);
  gap: 16px;
  margin-top: auto;
  padding: 5px 16px;
  z-index: 20;
}

.KBarKbd { 
  background: #444;
  border-radius: var(--theme-radius-sm);
  color: #ccc;
  display: inline-block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-right: 3px;
  padding: 1px 4px;
}

.Pipeline { 
  align-items: center;
  display: flex;
}

.Pipeline_Step { 
  align-items: center;
  color: var(--theme-text-tertiary);
  display: flex;
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  gap: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.Pipeline_Arrow { 
  color: var(--theme-border);
  font-size: var(--theme-fs-sm);
  margin: 0 6px;
}

.Pipeline_Step.state-draft { 
  color: var(--theme-draft-fg);
}

.Pipeline.state-draft .Pipeline_Step { 
  color: var(--theme-draft-fg);
}

.Pipeline_Step.state-review { 
  color: var(--theme-review-fg);
}

.Pipeline.state-review .Pipeline_Step { 
  color: var(--theme-review-fg);
}

.Pipeline_Step.state-approved { 
  color: var(--theme-approved-fg);
}

.Pipeline.state-approved .Pipeline_Step { 
  color: var(--theme-approved-fg);
}

.Pipeline_Step.state-merged { 
  color: var(--theme-merged-fg);
}

.Pipeline.state-merged .Pipeline_Step { 
  color: var(--theme-merged-fg);
}

.Page { 
  margin: 0 auto;
  max-width: 960px;
  padding: var(--theme-sp-8) var(--theme-sp-8) 60px;
  width: 100%;
}

.sf { 
  padding: 4px 0 2px;
  position: relative;
  width: 100%;
}

.sf-svg { 
  height: 100%;
  inset: 0;
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: 0;
}

.sf-row { 
  align-items: start;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  position: relative;
  z-index: 1;
}

.sf-node { 
  align-items: center;
  background: transparent;
  border: 0;
  color: var(--theme-ink-3);
  cursor: default;
  display: flex;
  flex-direction: column;
  font: inherit;
  gap: 6px;
  padding: 0;
}

.sf-disc { 
  align-items: center;
  background: var(--theme-bg);
  border-radius: 50%;
  display: flex;
  height: 36px;
  justify-content: center;
  transition: transform 0.12s;
  width: 36px;
}

.sf-label { 
  color: var(--theme-ink-3);
  font-family: var(--theme-font-mono);
  font-size: 9.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.sf-node.done { 
  color: var(--theme-ink);
}

.sf-node.done .sf-label { 
  color: var(--theme-ink-2);
}

.sf-node.cur .sf-label { 
  color: var(--theme-ink);
  font-weight: 700;
}

.sf-node.next { 
  color: var(--theme-ink-4);
}

.sf-node.next .sf-label { 
  color: var(--theme-ink-3);
}

.sf-node.future { 
  color: var(--theme-ink-4);
}

.sf-node.future .sf-label { 
  color: var(--theme-ink-4);
}

.sf-node.interactive { 
  cursor: pointer;
}

.sf-node.interactive:hover:not(.cur) .sf-disc { 
  transform: translateY(-1px);
}

.hero { 
  align-items: end;
  display: grid;
  gap: 40px;
  grid-template-columns: 1fr auto;
  padding: 8px 0 24px;
}

.hero h1 { 
  color: var(--theme-ink);
  font-family: var(--theme-font-display);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.028em;
  line-height: 1.06;
  margin: 0;
  max-width: 880px;
}

.hero-meta { 
  color: var(--theme-ink-3);
  display: flex;
  flex-wrap: wrap;
  font-size: 11px;
  gap: 16px;
  letter-spacing: 0.14em;
  margin-top: 14px;
  text-transform: uppercase;
}

.hero-meta b { 
  color: var(--theme-ink);
}

.hero-flow { 
  padding-top: 6px;
  width: 320px;
}

hr.rule-thick { 
  border: 0;
  border-top: 3px solid var(--theme-rule);
  margin: 0;
}

.hero-title-edit { 
  cursor: text;
  display: inline;
  margin: 0 -2px;
  outline: none;
  padding: 0 2px;
}

.hero-title-edit:hover { 
  background: var(--theme-bg-3);
}

.hero-title-edit:focus { 
  background: var(--theme-bg-3);
}

.hero-title-edit[data-edit-status="saving"] { 
  opacity: 0.6;
}

.hero-title-edit[data-edit-status="error"] { 
  box-shadow: 0 0 0 1px var(--theme-hazard);
}

.lede { 
  color: var(--theme-ink-2);
  font-family: var(--theme-font-display);
  font-size: 19px;
  font-weight: 400;
  letter-spacing: -0.005em;
  line-height: 1.5;
  margin: 0;
  max-width: 100%;
  padding: 18px 0 28px;
}

.lede + .lede { 
  padding-top: 0;
}

.lede .drop { 
  color: var(--theme-ink);
  font-weight: 600;
}

.desc-wrap { 
  padding: 18px 0 28px;
  position: relative;
}

.desc-edit-btn { 
  align-items: center;
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  color: var(--theme-ink-3);
  cursor: pointer;
  display: none;
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 700;
  gap: 6px;
  letter-spacing: 0.14em;
  padding: 4px 10px;
  position: absolute;
  right: 0;
  text-transform: uppercase;
  top: 2px;
  transition: color 0.12s, background 0.12s, border-color 0.12s;
}

.desc-wrap:hover .desc-edit-btn { 
  display: inline-flex;
}

.desc-edit-btn:hover { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.lede-edit { 
  color: var(--theme-ink-2);
  font-family: var(--theme-font-display);
  font-size: 19px;
  font-weight: 400;
  letter-spacing: -0.005em;
  line-height: 1.5;
  margin: 0;
  max-width: 100%;
  min-height: 1.5em;
  outline: none;
  padding: 0;
}

.lede-edit:focus { 
  background: var(--theme-bg-3);
  margin: 0 -8px;
  padding: 4px 8px;
}

.lede-edit:empty:not(:focus)::before { 
  color: var(--theme-ink-3);
  content: attr(data-placeholder);
  font-style: italic;
}

.lede-edit[data-edit-status="saving"] { 
  opacity: 0.6;
}

.lede-edit:not([data-editing]) p { 
  margin: 0 0 20px 0;
}

.lede-edit:not([data-editing]) p:first-child { 
  margin-top: 0;
}

.lede-edit:not([data-editing]) code { 
  background: var(--theme-bg-3);
  font-family: var(--theme-font-mono);
  font-size: 0.9em;
  padding: 1px 4px;
}

.lede-edit ul, .lede-edit ol { 
  margin: 6px 0;
  padding-left: 1.5em;
}

.lede-edit li { 
  margin: 2px 0;
}

.FlexRow { 
  align-items: center;
  display: flex;
  gap: var(--theme-sp-4);
}

.FlexRow.gap-none { 
  gap: 0px;
}

.FlexRow.gap-xs { 
  gap: var(--theme-sp-2);
}

.FlexRow.gap-sm { 
  gap: var(--theme-sp-3);
}

.FlexRow.gap-md { 
  gap: var(--theme-sp-4);
}

.FlexRow.gap-lg { 
  gap: var(--theme-sp-6);
}

.FlexRow.justify-start { 
  justify-content: flex-start;
}

.FlexRow.justify-center { 
  justify-content: center;
}

.FlexRow.justify-end { 
  justify-content: flex-end;
}

.FlexRow.justify-between { 
  justify-content: space-between;
}

.FlexRow.align-start { 
  align-items: flex-start;
}

.FlexRow.align-center { 
  align-items: center;
}

.FlexRow.align-end { 
  align-items: flex-end;
}

.FlexRow.align-baseline { 
  align-items: baseline;
}

.FlexRow.wrap { 
  flex-wrap: wrap;
}

.FlexRow.inline { 
  display: inline-flex;
}

.Spacer { 
  flex-shrink: 0;
}

.Spacer.size-sm { 
  width: 12px;
}

.Spacer.size-md { 
  width: 20px;
}

.Spacer.size-lg { 
  width: 32px;
}

.DiffContent { 
  flex: 1;
  min-width: 0px;
}

.VersionBadge { 
  bottom: 0px;
  color: var(--theme-text-muted);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: 5px 16px;
  pointer-events: none;
  position: fixed;
  right: 0px;
  z-index: 20;
}

.InlineForm { 
  align-items: center;
  display: inline-flex;
  gap: var(--theme-sp-2);
}

.InlineForm.block { 
  display: flex;
}

.WsBarCard { 
  background: #fff;
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--theme-sp-5);
  margin-bottom: var(--theme-sp-6);
  padding: var(--theme-sp-6);
}

[data-theme="rev-dark"] .WsBarCard { 
  background: var(--theme-surface-raised);
}

.WsBarSaveBar { 
  align-items: center;
  display: flex;
  gap: var(--theme-sp-4);
}

.WsBarAutosaveToggle { 
  align-items: center;
  display: flex;
  flex-shrink: 0;
  gap: var(--theme-sp-3);
}

.WsBarToggleLabel { 
  color: var(--theme-text-secondary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
}

.WsBarToggleTrack { 
  background: var(--theme-surface-raised);
  border: 1px solid var(--theme-border);
  border-radius: 11px;
  cursor: pointer;
  flex-shrink: 0;
  height: 22px;
  padding: 0px;
  position: relative;
  transition: background 0.15s;
  width: 40px;
}

.WsBarToggleTrack::after { 
  background: #fff;
  border: 1px solid var(--theme-border);
  border-radius: 50%;
  content: "";
  height: 16px;
  left: 2px;
  position: absolute;
  top: 2px;
  transition: transform 0.15s;
  width: 16px;
}

.WsBarToggleTrack[data-on] { 
  background: var(--theme-accent);
  border-color: var(--theme-accent);
}

.WsBarToggleTrack[data-on]::after { 
  border-color: var(--theme-accent);
  transform: translateX(18px);
}

.WsBarSyncBanner { 
  align-items: center;
  background: #fef9e7;
  border: 1px solid #f5e6a3;
  border-radius: var(--theme-radius-md);
  display: flex;
  justify-content: space-between;
  padding: var(--theme-sp-3) var(--theme-sp-4);
}

[data-theme="rev-dark"] .WsBarSyncBanner { 
  background: #332b00;
  border-color: #554a1a;
}

.WsBarSyncText { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
}

.WsBarSyncDetail { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.WsBarFooter { 
  display: flex;
  justify-content: flex-end;
}

.TabBar { 
  border-bottom: 1px solid var(--theme-border-light);
  display: flex;
  gap: var(--theme-sp-6);
  margin-bottom: var(--theme-sp-4);
}

.Tab { 
  border-bottom: 2px solid transparent;
  color: var(--theme-text-tertiary);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 500;
  margin-bottom: -1px;
  padding-bottom: var(--theme-sp-3);
  text-decoration: none;
}

.Tab[data-active] { 
  border-bottom-color: var(--theme-text);
  color: var(--theme-text);
  font-weight: 600;
}

.Tab:hover { 
  color: var(--theme-text-secondary);
}

.TabCount { 
  align-items: center;
  background: var(--theme-surface-raised);
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-full);
  color: var(--theme-text-secondary);
  display: inline-flex;
  font-size: var(--theme-fs-xs);
  font-weight: 600;
  height: 20px;
  justify-content: center;
  line-height: 1;
  margin-left: var(--theme-sp-2);
  min-width: 20px;
  padding: 0 var(--theme-sp-2);
}

.fh { 
  align-items: center;
  background: var(--theme-bg-2);
  border-bottom: 1.5px solid var(--theme-rule);
  cursor: pointer;
  display: grid;
  gap: 12px;
  grid-template-columns: 14px auto 1fr auto;
  padding: 10px 14px;
  user-select: none;
}

.fh:hover { 
  background: var(--theme-bg-3);
}

.fh.collapsed { 
  border-bottom: 0;
}

.fh.tone-conflict { 
  background: #0a0a0a;
  border-bottom-color: #0a0a0a;
}

.fh.tone-conflict:hover { 
  background: #1a1a1a;
}

.fh.tone-conflict .fh-disclose { 
  color: var(--theme-hazard);
}

.fh.tone-conflict .fh-kind { 
  color: var(--theme-hazard);
}

.fh.tone-conflict .fh-path .name { 
  color: var(--theme-hazard);
}

.fh.tone-conflict .fh-path .dir { 
  color: rgba(245,211,0,0.6);
}

.fh.tone-conflict .fh-stat.note { 
  color: rgba(245,211,0,0.7);
}

.fh-disclose { 
  color: var(--theme-ink-3);
  font-size: 11px;
  line-height: 1;
  text-align: center;
  transition: transform 0.12s;
  width: 14px;
}

.fh-kind { 
  color: var(--theme-ink-4);
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  width: 1ch;
}

.fh-kind.add { 
  color: var(--theme-add-strong);
}

.fh-kind.del { 
  color: var(--theme-del-strong);
}

.fh-kind.mod { 
  color: var(--theme-ink-3);
}

.fh-path { 
  align-items: baseline;
  color: var(--theme-ink);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 13px;
  font-weight: 700;
  gap: 0;
  min-width: 0px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fh-path .dir { 
  color: var(--theme-ink-3);
  font-weight: 500;
}

.fh-path .name { 
  color: var(--theme-ink);
  font-weight: 700;
}

.fh-meta { 
  align-items: center;
  color: var(--theme-ink-3);
  display: inline-flex;
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  gap: 18px;
  white-space: nowrap;
}

.fh-stat .add { 
  color: var(--theme-add-strong);
  font-weight: 700;
}

.fh-stat .del { 
  color: var(--theme-del-strong);
  font-weight: 700;
}

.fh-stat .sl { 
  color: var(--theme-ink-4);
  padding: 0 2px;
}

.fh-stat.note { 
  color: var(--theme-ink-3);
  font-size: 11px;
}

.fh-comments { 
  color: var(--theme-ink-3);
}

.fh-comments b { 
  color: var(--theme-ink);
  font-weight: 700;
}

.fh-comments.unresolved { 
  color: var(--theme-del-strong);
  font-weight: 700;
}

.fh-status { 
  align-items: center;
  color: var(--theme-ink-4);
  display: inline-flex;
  font-size: 10px;
  font-weight: 700;
  gap: 5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.fh-status .glyph { 
  font-size: 12px;
  line-height: 1;
}

.fh-status.approved { 
  color: var(--theme-add-strong);
}

.fh-status.unresolved { 
  color: var(--theme-del-strong);
}

.fh-status.pending { 
  color: var(--theme-review);
}

.fh-status.unreviewed { 
  color: var(--theme-ink-4);
}

.fh-status.merged { 
  color: var(--theme-merged);
}

.fh-status.conflict { 
  color: var(--theme-hazard);
}

.FdDiffSection { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  margin-bottom: 18px;
  scroll-margin-top: 58px;
}

.FdDiffPlaceholder { 
  border: 1px solid var(--theme-rule-soft);
  border-radius: 0;
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-4);
}

.FdMediaWrap { 
  align-items: center;
  background: var(--theme-bg-2);
  display: flex;
  flex-direction: column;
  gap: var(--theme-sp-2);
  padding: var(--theme-sp-4);
}

.fd-media-img, .fd-media-vid { 
  background: repeating-conic-gradient(rgba(0,0,0,0.06) 0 25%, transparent 0 50%) 0 0 / 16px 16px, #fff;
  border: 1px solid var(--theme-rule-soft);
  height: auto;
  max-height: 600px;
  max-width: 100%;
}

.fd-media-cap { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.FdDownloadBox { 
  align-items: center;
  background: var(--theme-bg-2);
  display: flex;
  gap: var(--theme-sp-4);
  justify-content: space-between;
  padding: var(--theme-sp-4);
}

.FdDownloadInfo { 
  color: var(--theme-text-secondary);
  display: flex;
  flex-direction: column;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  gap: 2px;
}

.FdDownloadBtn { 
  align-items: center;
  background: var(--theme-ink);
  border: 1.5px solid var(--theme-ink);
  border-radius: 0;
  color: var(--theme-bg);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  gap: var(--theme-sp-2);
  padding: var(--theme-sp-2) var(--theme-sp-4);
  text-decoration: none;
  white-space: nowrap;
}

.FdDownloadBtn:hover { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.FdViewToggle { 
  display: flex;
  gap: var(--theme-sp-2);
  justify-content: flex-end;
  margin-bottom: 12px;
}

.FdToggleBtn { 
  background: none;
  border: 1.5px solid var(--theme-rule);
  border-radius: 0;
  color: var(--theme-text-secondary);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-2) var(--theme-sp-4);
}

.FdToggleBtn[data-active] { 
  background: var(--theme-ink);
  border-color: var(--theme-ink);
  color: var(--theme-bg);
  font-weight: 600;
}

.FdToggleBtn[data-active]:hover { 
  color: var(--theme-bg);
}

.FdToggleBtn:hover { 
  color: var(--theme-text);
}

.fd-wide .Page { 
  max-width: 100%;
}

[data-collapsed] [data-diff] { 
  display: none;
}

.Sidebar { 
  border-right: 1px solid var(--theme-border-light);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  width: 300px;
}

.SidebarRepo { 
  border-bottom: 1px solid var(--theme-border-light);
  padding: var(--theme-sp-6) var(--theme-sp-8);
}

.SidebarRepoName { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
  font-weight: 600;
  margin-bottom: var(--theme-sp-4);
}

.SidebarStats { 
  display: grid;
  gap: var(--theme-sp-2) var(--theme-sp-6);
  grid-template-columns: auto 1fr auto 1fr;
}

.SidebarStatLabel { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.SidebarStatVal { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  text-align: right;
}

.SidebarNav { 
  border-bottom: 1px solid var(--theme-border-light);
  padding: var(--theme-sp-5) var(--theme-sp-8);
}

.SidebarNavLink { 
  color: var(--theme-text-secondary);
  display: block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
  padding: var(--theme-sp-2) 0;
  text-decoration: none;
}

.SidebarNavLink:hover { 
  color: var(--theme-text);
}

.SidebarNavLink.active { 
  color: var(--theme-text);
  font-weight: 600;
}

.SidebarGroup { 
  border-bottom: 1px solid var(--theme-border-light);
  border-left: 3px solid transparent;
}

.SidebarGroup.current { 
  background: var(--theme-surface-hover);
  border-left-color: var(--theme-accent);
}

.SidebarGroupHeader { 
  align-items: center;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  padding: var(--theme-sp-4) var(--theme-sp-8);
  user-select: none;
}

.SidebarChevron { 
  color: inherit;
  display: inline-block;
  font-size: 8px;
  margin-right: var(--theme-sp-3);
  transition: transform 150ms ease;
}

.SidebarGroupLabel { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  letter-spacing: var(--theme-ls-caps);
  text-transform: uppercase;
}

.SidebarGroupLabel.state-draft { 
  color: var(--theme-draft-fg);
}

.SidebarGroupLabel.state-review { 
  color: var(--theme-review-fg);
}

.SidebarGroupLabel.state-approved { 
  color: var(--theme-approved-fg);
}

.SidebarGroupLabel.state-merged { 
  color: var(--theme-merged-fg);
}

.SidebarCount { 
  background: var(--theme-surface-raised);
  border-radius: var(--theme-radius-full);
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  font-weight: 600;
  min-width: 20px;
  padding: 2px 7px;
  text-align: center;
}

.SidebarCard { 
  border-bottom: 1px solid var(--theme-border-light);
  display: block;
  padding: var(--theme-sp-4) var(--theme-sp-8);
  text-decoration: none;
}

.SidebarCard:hover { 
  background: var(--theme-surface-hover);
  text-decoration: none;
}

.SidebarCard:last-child { 
  border-bottom: none;
}

.SidebarCardTop { 
  align-items: baseline;
  display: flex;
  gap: var(--theme-sp-3);
  justify-content: space-between;
  margin-bottom: var(--theme-sp-2);
}

.SidebarCardTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-base);
  line-height: var(--theme-lh-tight);
}

.SidebarCardMeta { 
  align-items: baseline;
  display: flex;
  gap: var(--theme-sp-3);
}

.SidebarStateHeader { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  display: flex;
  justify-content: space-between;
  padding: var(--theme-sp-3) var(--theme-sp-8);
}

.SidebarRepoGroupLabel { 
  align-items: center;
  color: var(--theme-text);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
}

.SidebarRepoGroupLabel.active { 
  color: var(--theme-accent);
}

.SidebarRepoGroupLabel.muted { 
  color: var(--theme-text-tertiary);
  font-weight: 500;
}

.SidebarCurrentDot { 
  background: var(--theme-accent);
  border-radius: var(--theme-radius-full);
  display: inline-block;
  flex-shrink: 0;
  height: 6px;
  margin-right: var(--theme-sp-2);
  width: 6px;
}

.SidebarRepoGroupLink { 
  color: inherit;
  text-decoration: none;
}

.SidebarRepoGroupLink:hover { 
  color: var(--theme-text);
  text-decoration: none;
}

.SidebarEmpty { 
  padding: var(--theme-sp-8) var(--theme-sp-8);
}

.SidebarEmptyText { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-bottom: var(--theme-sp-4);
}

.ActionsBadge { 
  align-items: center;
  background: none;
  border: none;
  border-radius: var(--theme-radius-sm);
  color: var(--theme-text-muted);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  gap: 4px;
  padding: 2px 6px;
}

.ActionsBadge:hover { 
  background: rgba(255,255,255,0.08);
  color: var(--theme-text-invert);
}

.ActionsDot { 
  background: var(--theme-add);
  border-radius: 50%;
  cursor: pointer;
  display: inline-block;
  height: 7px;
  width: 7px;
}

.ActionsDot.status-pass { 
  background: var(--theme-add);
}

.ActionsDot.status-fail { 
  background: var(--theme-del);
}

.ActionsDot.status-running { 
  background: var(--theme-draft-fg);
}

.ActionsPanel { 
  display: none;
  justify-content: center;
  left: 0px;
  position: fixed;
  right: 0px;
  top: 34px;
  z-index: 20;
}

.ActionsPanel[data-open] { 
  display: flex;
}

.ActionsPanelInner { 
  background: var(--theme-surface-raised);
  border: 1px solid var(--theme-border);
  border-radius: var(--theme-radius-md);
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
  max-height: 320px;
  overflow-y: auto;
  padding: var(--theme-sp-5);
  width: 480px;
}

.ActionsPanelHeader { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  letter-spacing: var(--theme-ls-caps);
  margin-bottom: var(--theme-sp-4);
  text-transform: uppercase;
}

.ActionsRow { 
  align-items: center;
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  gap: var(--theme-sp-3);
  padding: var(--theme-sp-2) 0;
}

.ActionsName { 
  color: var(--theme-text);
  font-weight: 500;
  width: 60px;
}

.ActionsChange { 
  color: var(--theme-text-secondary);
  flex: 1;
  overflow: hidden;
  text-decoration: none;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ActionsChange:hover { 
  color: var(--theme-accent);
  text-decoration: none;
}

.ActionsDuration { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  text-align: right;
  width: 40px;
}

.ChangeGroup { 
  margin-bottom: var(--theme-sp-8);
}

.ChangeGroupHeader { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border);
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-1);
  padding: var(--theme-sp-4) 0;
  text-decoration: none;
}

.ChangeGroupHeader:hover { 
  opacity: 0.8;
  text-decoration: none;
}

.ChangeGroupLabel { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  letter-spacing: var(--theme-ls-caps);
  text-transform: uppercase;
}

.ChangeGroupLabel.state-approved { 
  color: var(--theme-approved-fg);
}

.ChangeGroupLabel.state-review { 
  color: var(--theme-review-fg);
}

.ChangeGroupLabel.state-draft { 
  color: var(--theme-draft-fg);
}

.ChangeGroupLabel.state-merged { 
  color: var(--theme-merged-fg);
}

.ChangeCountBadge { 
  background: var(--theme-surface-raised);
  border-radius: var(--theme-radius-full);
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  font-weight: 600;
  padding: 2px 7px;
}

.ChangeRow { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  display: flex;
  gap: var(--theme-sp-5);
  padding: var(--theme-sp-4) 0;
  text-decoration: none;
}

.ChangeRow:hover { 
  background: var(--theme-surface-hover);
  text-decoration: none;
}

.ChangeNum { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  text-align: right;
  width: 36px;
}

.ChangeTitleWrap { 
  align-items: baseline;
  display: flex;
  flex: 1;
  gap: var(--theme-sp-3);
  min-width: 0px;
}

.ChangeTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-md);
  line-height: var(--theme-lh-tight);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ChangeAuthor { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  width: 48px;
}

.ChangeTime { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  text-align: right;
  width: 32px;
}

.ChangeDiff { 
  flex-shrink: 0;
  text-align: right;
  width: 90px;
}

.CommentCount { 
  align-items: center;
  color: var(--theme-text-tertiary);
  display: inline-flex;
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  gap: 3px;
}

.ErrorContainer { 
  margin: 0 auto;
  max-width: 960px;
  padding: 80px 16px;
  text-align: center;
  width: 100%;
}

.ErrorStatus { 
  color: var(--theme-border);
  font-family: var(--theme-font-mono);
  font-size: 48px;
  font-weight: 600;
  margin-bottom: 12px;
}

.ErrorTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-xl);
  margin-bottom: 8px;
}

.ErrorHint { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  line-height: var(--theme-lh-relaxed);
  margin: 0 auto;
  max-width: 420px;
}

.DesktopBtn { 
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border);
  border-radius: var(--theme-radius-sm);
  color: var(--theme-text-secondary);
  cursor: pointer;
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: 3px 8px;
}

.DesktopBtn:hover { 
  background: var(--theme-surface-hover);
}

.DesktopBtn:disabled { 
  cursor: wait;
  opacity: 0.7;
}

.DesktopBtn.downloaded { 
  background: var(--theme-add-bg-line);
  border-color: var(--theme-add);
  color: var(--theme-add);
}

.DesktopBtn.downloaded:hover { 
  background: var(--theme-add-bg);
}

.StateDot { 
  border-radius: var(--theme-radius-full);
  display: inline-block;
  flex-shrink: 0;
  height: 8px;
  width: 8px;
}

.StateDot.state-draft { 
  background: var(--theme-draft-fg);
}

.StateDot.state-review { 
  background: var(--theme-review-fg);
}

.StateDot.state-approved { 
  background: var(--theme-approved-fg);
}

.StateDot.state-merged { 
  background: var(--theme-merged-fg);
}

.changelevel { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  margin-bottom: 18px;
  position: relative;
}

.changelevel-teaser { 
  align-items: center;
  background: transparent;
  border: 1.5px dashed var(--theme-rule);
  color: var(--theme-ink-3);
  cursor: pointer;
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  gap: 10px;
  margin-bottom: 18px;
  padding: 10px 14px;
  text-align: left;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
  width: 100%;
}

.changelevel-teaser:hover { 
  background: var(--theme-bg-2);
  border-color: var(--theme-ink-3);
  color: var(--theme-ink-2);
}

.changelevel-teaser .glyph { 
  color: var(--theme-ink-4);
}

.changelevel-teaser .chevron { 
  color: var(--theme-ink-4);
  margin-left: auto;
}

.changelevel-head { 
  align-items: center;
  background: var(--theme-bg-2);
  border-bottom: 1.5px solid var(--theme-rule);
  cursor: pointer;
  display: grid;
  gap: 10px;
  grid-template-columns: auto 1fr auto;
  padding: 10px 14px;
  user-select: none;
}

.changelevel-head:hover { 
  background: var(--theme-bg-3);
}

.changelevel-head .glyph { 
  color: var(--theme-ink-3);
  font-family: var(--theme-font-mono);
  font-size: 12px;
}

.changelevel-head .ttl { 
  color: var(--theme-ink);
  font-family: var(--theme-font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.changelevel-head .meta { 
  color: var(--theme-ink-3);
  font-family: var(--theme-font-mono);
  font-size: 11px;
  white-space: nowrap;
}

.changelevel-body { 
  padding: 14px 14px 14px 64px;
  position: relative;
}

.changelevel-body::before { 
  background: var(--theme-ink);
  bottom: 14px;
  content: "";
  left: 24px;
  position: absolute;
  top: 14px;
  width: 2px;
}

.comment { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  margin-bottom: 10px;
  padding: 10px 12px;
  position: relative;
}

.comment.indent { 
  margin-left: 24px;
}

.comment-reply-btn { 
  align-items: center;
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  color: var(--theme-ink-3);
  cursor: pointer;
  display: none;
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 700;
  gap: 6px;
  letter-spacing: 0.14em;
  padding: 4px 10px;
  position: absolute;
  right: 6px;
  text-transform: uppercase;
  top: 6px;
  transition: color 0.12s, background 0.12s, border-color 0.12s;
}

.comment:hover .comment-reply-btn { 
  display: inline-flex;
}

.comment-reply-btn:hover { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.comment-thread { 
  margin-bottom: 10px;
}

.comment-thread > .comment { 
  margin-bottom: 0;
}

.comment-thread > .comment.indent { 
  border-top: 0;
  margin-bottom: 0;
}

.comment-thread .thread-reply { 
  border-top: 0;
  margin-left: 24px;
  overflow: hidden;
}

.comment-thread .thread-reply .reply { 
  margin-top: 0;
  padding: 8px 0 4px;
}

.comment .who-row { 
  align-items: center;
  color: var(--theme-ink-3);
  display: flex;
  font-size: 10px;
  gap: 10px;
  letter-spacing: 0.14em;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.comment .who-row b { 
  color: var(--theme-ink);
  font-weight: 700;
}

.comment .body { 
  color: var(--theme-ink-2);
  font-size: 13px;
  line-height: 1.5;
}

.comment .body code { 
  background: var(--theme-bg-3);
  font-family: var(--theme-font-mono);
  font-size: 12px;
  padding: 0 4px;
}

.reply { 
  align-items: flex-end;
  display: flex;
  gap: 8px;
  margin-top: 4px;
}

.reply .dot { 
  line-height: 36px;
}

.reply textarea { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  border-radius: 0;
  color: var(--theme-ink);
  flex: 1;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  line-height: 1.5;
  max-height: 200px;
  min-height: 36px;
  outline: none;
  overflow: hidden;
  padding: 9px 12px;
  resize: none;
}

.reply textarea::placeholder { 
  color: var(--theme-ink-4);
}

.reply .btn { 
  align-items: center;
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  border-radius: 0;
  color: var(--theme-ink);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  font-weight: 600;
  gap: 8px;
  height: 36px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 8px 14px;
  text-transform: uppercase;
}

.reply .btn:hover { 
  background: var(--theme-bg-2);
}

.reply .btn.hazard { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.reply .btn.hazard:hover { 
  background: var(--theme-hazard-2);
}

.thread { 
  background: var(--theme-bg-2);
  border-top: 1.5px solid var(--theme-rule);
  padding: 14px 14px 14px 68px;
  position: relative;
}

.thread::before { 
  background: var(--theme-ink);
  bottom: 14px;
  content: "";
  left: 24px;
  position: absolute;
  top: 14px;
  width: 2px;
}

.thread .anchor { 
  color: var(--theme-ink-3);
  font-size: 10px;
  letter-spacing: 0.14em;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.thread .anchor b { 
  color: var(--theme-ink);
}

.thread.inline { 
  border-bottom: 1.5px solid var(--theme-rule);
  padding: 14px 14px 14px 20px;
}

.thread.inline::before { 
  left: 0;
}

.thread-marker { 
  align-items: center;
  background: var(--theme-bg-2);
  border-bottom: 1.5px solid var(--theme-rule-soft);
  border-top: 1.5px solid var(--theme-rule-soft);
  color: var(--theme-ink-3);
  cursor: pointer;
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  gap: 14px;
  grid-template-columns: auto 1fr auto;
  padding: 8px 14px 8px 64px;
  user-select: none;
}

.thread-marker:hover { 
  background: var(--theme-bg-3);
}

.thread-marker .glyph { 
  color: var(--theme-add-strong);
  font-size: 11px;
  line-height: 1;
}

.thread-marker.unresolved .glyph { 
  color: var(--theme-del-strong);
}

.thread-marker .body { 
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.thread-marker .body b { 
  color: var(--theme-ink-2);
  font-weight: 700;
}

.thread-marker .who { 
  color: var(--theme-ink-4);
}

.thread-marker .expand { 
  color: var(--theme-ink-4);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.rail { 
  border-left: 1.5px solid var(--theme-rule);
  overflow: visible;
  padding: 0;
}

.rail-tabs { 
  border-bottom: 1.5px solid var(--theme-rule);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.rail-tab { 
  align-items: flex-start;
  background: transparent;
  border: 0;
  border-radius: 0;
  border-right: 1.5px solid var(--theme-rule);
  color: var(--theme-ink-3);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  gap: 4px;
  letter-spacing: 0.16em;
  padding: 14px 14px 12px;
  text-align: left;
  text-transform: uppercase;
  transition: background 0.12s, color 0.12s;
}

.rail-tab:last-child { 
  border-right: 0;
}

.rail-tab:hover:not(.on) { 
  background: rgba(245, 211, 0, 0.10);
  color: var(--theme-ink-2);
}

.rail-tab.on { 
  box-shadow: inset 0 -3px 0 var(--theme-hazard);
  color: var(--theme-ink);
  font-weight: 700;
}

.rail-tab-count { 
  color: var(--theme-ink);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-transform: none;
}

.rail-tab:not(.on) .rail-tab-count { 
  color: var(--theme-ink-2);
}

.rail-radio { 
  display: none;
}

.rail-radio:checked + .rail-panel { 
  display: block;
}

.rail-panel { 
  display: none;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
  padding: 16px 18px 22px;
}

.rail-panel.on { 
  display: block;
}

.rail-summary { 
  align-items: baseline;
  border-bottom: 1px solid var(--theme-rule-soft);
  color: var(--theme-ink-2);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  gap: 6px;
  letter-spacing: 0.14em;
  margin-bottom: 10px;
  padding-bottom: 12px;
  text-transform: uppercase;
}

.rail-list { 
  display: flex;
  flex-direction: column;
  gap: 2px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.rail-file { 
  align-items: center;
  border-radius: 0;
  color: var(--theme-ink);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 8px;
  grid-template-columns: 18px 1fr auto 8px;
  padding: 7px 6px;
  text-decoration: none;
}

.rail-file:hover { 
  background: rgba(245, 211, 0, 0.14);
  text-decoration: none;
}

.rail-file.active { 
  background: var(--theme-hazard);
  box-shadow: -6px 0 0 var(--theme-hazard);
  color: #0a0a0a;
  font-weight: 700;
}

.rail-file.active .rail-stat { 
  color: #0a0a0a;
}

.rail-file.active .rail-stat .add, .rail-file.active .rail-stat .del { 
  color: #0a0a0a;
}

.rail-file.active .rail-dot { 
  background: #0a0a0a;
}

.rail-tree-summary { 
  align-items: baseline;
  border-bottom: 1px solid var(--theme-rule-soft);
  color: var(--theme-ink-3);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  justify-content: space-between;
  margin-bottom: 8px;
  padding: 0 0 10px;
}

.rail-tree-summary b { 
  color: var(--theme-ink);
}

.rail-tree-dir { 
  color: var(--theme-ink-3);
  font-family: var(--theme-font-mono);
  font-size: 12px;
  padding: 5px 0 2px;
  user-select: none;
}

.rail-tree-file { 
  align-items: center;
  color: var(--theme-ink);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  font-weight: 700;
  gap: 6px;
  grid-template-columns: 1fr auto;
  padding: 5px 4px;
  text-decoration: none;
}

.rail-tree-file:hover { 
  background: rgba(245, 211, 0, 0.14);
  text-decoration: none;
}

.rail-tree-file.active { 
  background: var(--theme-hazard);
  box-shadow: -6px 0 0 var(--theme-hazard);
  color: #0a0a0a;
}

.rail-tree-file.active .rail-stat { 
  color: #0a0a0a;
}

.rail-tree-file.active .rail-stat .add, .rail-tree-file.active .rail-stat .del { 
  color: #0a0a0a;
}

.rail-tree-dot { 
  background: var(--theme-ink-4);
  border-radius: 50%;
  height: 8px;
  justify-self: center;
  width: 8px;
}

.rail-tree-dot.ok { 
  background: var(--theme-add-strong);
}

.rail-tree-dot.warn { 
  background: var(--theme-del-strong);
}

.rail-badge { 
  align-items: center;
  background: var(--theme-mod);
  color: #fff;
  display: inline-flex;
  font-size: 10px;
  font-weight: 700;
  height: 16px;
  justify-content: center;
  letter-spacing: 0;
  width: 18px;
}

.rail-badge.add { 
  background: var(--theme-add-strong);
  color: #fff;
}

.rail-badge.del { 
  background: var(--theme-del-strong);
  color: #fff;
}

.rail-path { 
  direction: rtl;
  overflow: hidden;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rail-stat { 
  color: var(--theme-ink-3);
  font-size: 11px;
  white-space: nowrap;
}

.rail-stat .add { 
  color: var(--theme-add-strong);
  font-weight: 700;
}

.rail-stat .del { 
  color: var(--theme-del-strong);
  font-weight: 700;
}

.rail-dot { 
  background: var(--theme-ink-4);
  border-radius: 50%;
  height: 8px;
  width: 8px;
}

.rail-dot.ok { 
  background: var(--theme-add-strong);
}

.rail-dot.warn { 
  background: var(--theme-del-strong);
}

.rail-stack { 
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rail-stack-conn { 
  color: var(--theme-ink-4);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 13px;
  gap: 8px;
  grid-template-columns: 28px 14px 1fr;
  height: 8px;
  line-height: 1;
  padding: 0 6px;
}

.rail-stack-conn span { 
  text-align: center;
}

.rail-stack-row { 
  align-items: center;
  color: var(--theme-ink);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 8px;
  grid-template-columns: 28px 14px 1fr;
  padding: 7px 6px;
  text-decoration: none;
}

.rail-stack-row:hover:not(.cur) { 
  background: rgba(245, 211, 0, 0.14);
}

.rail-stack-row.cur { 
  background: var(--theme-hazard);
  box-shadow: -6px 0 0 var(--theme-hazard);
  color: #0a0a0a;
  font-weight: 700;
}

.rail-stack-num { 
  color: var(--theme-ink-3);
  font-size: 11px;
}

.rail-stack-row.cur .rail-stack-num { 
  color: #0a0a0a;
}

.rail-stack-sym { 
  font-size: 13px;
  text-align: center;
}

.rail-stack-ttl { 
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rail-approver { 
  align-items: center;
  border-bottom: 1px solid var(--theme-rule-soft);
  display: grid;
  gap: 10px;
  grid-template-columns: 26px 1fr auto;
  padding: 8px 4px;
}

.rail-approver:last-of-type { 
  border-bottom: 0;
}

.rail-approver-body { 
  min-width: 0px;
}

.rail-approver-name { 
  color: var(--theme-ink);
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
}

.rail-approver-note { 
  color: var(--theme-ink-3);
  font-family: var(--theme-font-mono);
  font-size: 10.5px;
  letter-spacing: 0.10em;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.rail-pill { 
  align-items: center;
  border: 1.5px solid var(--theme-rule);
  color: var(--theme-ink-3);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  font-weight: 700;
  height: 22px;
  justify-content: center;
  min-width: 22px;
  padding: 0 6px;
}

.rail-pill.ok { 
  background: var(--theme-add-strong);
  border-color: var(--theme-add-strong);
  color: #fff;
}

.rail-pill.bad { 
  background: var(--theme-del-strong);
  border-color: var(--theme-del-strong);
  color: #fff;
}

.rail-add { 
  background: transparent;
  border: 1.5px dashed var(--theme-rule);
  border-radius: 0;
  color: var(--theme-ink-3);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  margin-top: 6px;
  padding: 9px 6px;
  text-align: left;
  width: 100%;
}

.rail-add:hover { 
  background: rgba(245, 211, 0, 0.10);
  border-color: var(--theme-ink);
  color: var(--theme-ink);
}

.TopBarCrumb { 
  color: inherit;
  text-decoration: none;
}

.TopBarCrumb:hover { 
  text-decoration: underline;
}

.change-layout { 
  display: flex;
  position: relative;
}

.rail-slide { 
  align-self: flex-start;
  flex-shrink: 0;
  max-height: calc(100vh - 53px);
  overflow: hidden;
  position: sticky;
  top: 53px;
  transition: width 0.2s ease;
  width: 296px;
}

.change-layout.rail-hidden .rail-slide { 
  width: 0;
}

.rail-slide .rail { 
  min-width: 296px;
  width: 296px;
}

.change-layout.rail-hidden .rail { 
  border-left: 0;
}

.change-layout.rail-hidden .change-main { 
  padding-right: 0;
}

.change-layout.rail-hidden .rail-toggle { 
  right: -13px;
}

.rail-toggle { 
  align-items: center;
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  border-radius: 0;
  color: var(--theme-ink-3);
  cursor: pointer;
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  height: 26px;
  justify-content: center;
  padding: 0;
  position: absolute;
  right: 283px;
  top: -13px;
  transition: color 0.12s, background 0.12s, border-color 0.12s, right 0.2s ease;
  width: 26px;
  z-index: 6;
}

.rail-toggle:hover { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.change-main { 
  flex: 1;
  min-width: 0;
  padding: 24px 32px 0 0;
  position: relative;
}

.change-canvas { 
  margin: 0 auto;
  max-width: 1440px;
  padding: 28px 36px 48px;
  width: 100%;
}

.change-rule { 
  background: var(--theme-rule);
  height: 3px;
  margin: 0;
  position: sticky;
  top: 50px;
  z-index: 4;
}

.section-mark { 
  align-items: baseline;
  color: var(--theme-ink-3);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 700;
  gap: 10px;
  letter-spacing: 0.18em;
  padding: 18px 0 10px;
  text-transform: uppercase;
}

.section-mark .glyph { 
  color: var(--theme-ink-4);
}

.section-mark .count { 
  color: var(--theme-ink);
}

.section-mark .rule { 
  align-self: center;
  background: var(--theme-rule-soft);
  flex: 1;
  height: 1px;
}

.file { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  margin-bottom: 18px;
}

.change-footer { 
  align-items: center;
  border-top: 1.5px solid var(--theme-rule);
  display: flex;
  gap: 18px;
  margin-top: 8px;
  padding: 24px 0 8px;
}

.approve-btn { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-add-strong);
  color: var(--theme-add-strong);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  margin-top: 10px;
  padding: 8px 14px;
  text-transform: uppercase;
  transition: background 0.12s, color 0.12s;
  width: 100%;
}

.approve-btn:hover:not(:disabled) { 
  background: var(--theme-add-strong);
  color: #fff;
}

.approve-btn:disabled { 
  cursor: not-allowed;
  opacity: 0.4;
}

.ChangesPageHeader { 
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-6);
}

.MergedLabel { 
  color: var(--theme-merged-fg);
}

.MergedToggle { 
  border-top: 1px solid var(--theme-border-light);
  margin-top: var(--theme-sp-6);
  padding-top: var(--theme-sp-6);
}

.MergedSummary { 
  align-items: center;
  color: var(--theme-text-tertiary);
  cursor: pointer;
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  gap: var(--theme-sp-3);
  list-style: none;
}

.MergedSummary:hover { 
  color: var(--theme-text-secondary);
}

.TimelineHeader { 
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-6);
}

.TimelineEntry { 
  align-items: flex-start;
  border-bottom: 1px solid var(--theme-border-light);
  display: flex;
  gap: var(--theme-sp-4);
  padding: var(--theme-sp-5) 0;
  text-decoration: none;
}

.TimelineEntry:hover { 
  text-decoration: none;
}

.TimelineEntryContent { 
  flex: 1;
  min-width: 0px;
}

.TimelineEntryTop { 
  align-items: baseline;
  display: flex;
  gap: var(--theme-sp-4);
  justify-content: space-between;
  margin-bottom: var(--theme-sp-2);
}

.TimelineEntryTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-md);
  line-height: var(--theme-lh-tight);
}

.TimelineEntryMeta { 
  align-items: baseline;
  display: flex;
  gap: var(--theme-sp-4);
}

.TimelineDateHeader { 
  border-bottom: 1px solid var(--theme-border);
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  letter-spacing: var(--theme-ls-caps);
  margin-top: var(--theme-sp-4);
  padding: var(--theme-sp-6) 0 var(--theme-sp-3);
  text-transform: uppercase;
}

.TimelineDateHeader:first-child { 
  margin-top: 0px;
}

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

.RepoMain { 
  min-width: 0px;
  padding-right: 32px;
}

.RepoCanvas { 
  margin: 0 auto;
  max-width: 1200px;
  padding: var(--theme-sp-8) var(--theme-sp-8) 60px;
  width: 100%;
}

.RepoHero { 
  padding: var(--theme-sp-9) 0 var(--theme-sp-8);
}

.RepoHeroLine { 
  align-items: flex-end;
  display: flex;
  gap: 32px;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-8);
}

.RepoHeroTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-display);
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.0;
  margin: 0px;
}

.RepoHeroQuiet { 
  color: var(--theme-text-tertiary);
  font-weight: 500;
}

.RepoHeroAccent { 
  background: linear-gradient(180deg, transparent 60%, var(--theme-hazard) 60% 92%, transparent 92%);
  padding: 0 6px;
}

.RepoHeroStats { 
  align-items: stretch;
  border: 1.5px solid var(--theme-border);
  display: inline-flex;
}

.RepoHeroStat { 
  border-right: 1.5px solid var(--theme-border);
  color: inherit;
  min-width: 100px;
  padding: 14px 22px;
  text-align: left;
  text-decoration: none;
}

.RepoHeroStat:last-child { 
  border-right: 0;
}

.RepoHeroStat:hover { 
  background: var(--theme-surface-hover);
  text-decoration: none;
}

.RepoHeroStatKey { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  font-weight: 700;
  letter-spacing: var(--theme-ls-caps);
  text-transform: uppercase;
}

.RepoHeroStatVal { 
  color: var(--theme-text);
  font-family: var(--theme-font-display);
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-top: 6px;
}

.RepoHeroStatSmall { 
  color: var(--theme-text-tertiary);
  font-size: var(--theme-fs-md);
  font-weight: 500;
  margin-left: 4px;
}

.RepoQuickBar { 
  align-items: center;
  display: flex;
  gap: var(--theme-sp-4);
}

.RepoSectionMark { 
  align-items: baseline;
  color: var(--theme-text-tertiary);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  font-weight: 700;
  gap: var(--theme-sp-5);
  letter-spacing: var(--theme-ls-caps);
  padding: var(--theme-sp-9) 0 var(--theme-sp-5);
  text-transform: uppercase;
}

.RepoSectionRule { 
  align-self: center;
  background: var(--theme-border-light);
  flex: 1;
  height: 1px;
}

.RepoSectionCount { 
  color: var(--theme-text);
}

.RepoSectionMeta { 
  color: var(--theme-text-tertiary);
  font-weight: 500;
}

.RepoYardGrid { 
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  padding-top: 6px;
}

.RepoYardCard { 
  background: var(--theme-surface-bg);
  border: 1.5px solid var(--theme-border);
  display: flex;
  flex-direction: column;
}

.RepoYardCardHead { 
  align-items: baseline;
  background: var(--theme-surface-raised);
  border-bottom: 1.5px solid var(--theme-border);
  color: inherit;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr auto;
  padding: 12px 14px 10px;
  text-decoration: none;
}

.RepoYardCardHead:hover { 
  background: var(--theme-surface-hover);
  text-decoration: none;
}

.RepoYardCardName { 
  color: var(--theme-text);
  font-family: var(--theme-font-display);
  font-size: var(--theme-fs-md);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.1;
}

.RepoYardCardDesc { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  letter-spacing: 0px;
  margin-top: 3px;
}

.RepoYardCardMeta { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-align: right;
  text-transform: uppercase;
  white-space: nowrap;
}

.RepoYardCardBody { 
  flex: 1;
  padding: 8px 6px 10px;
}

.yard-row { 
  align-items: center;
  color: var(--theme-text-secondary);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 8px;
  grid-template-columns: 20px 36px 1fr auto;
  padding: 5px 8px;
  text-decoration: none;
}

.yard-row:hover { 
  background: rgba(245, 211, 0, 0.10);
  color: var(--theme-text);
  text-decoration: none;
}

.yard-row .yr-gly { 
  align-items: center;
  display: flex;
  justify-content: center;
}

.yard-row .yr-num { 
  color: var(--theme-text-tertiary);
  font-size: 11.5px;
}

.yard-row .yr-ttl { 
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.yard-row .yr-who { 
  color: var(--theme-text-muted);
  font-size: 11px;
  text-transform: lowercase;
}

.RepoYardCardFoot { 
  align-items: center;
  border-top: 1px dashed var(--theme-border-light);
  color: var(--theme-text-tertiary);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 10.5px;
  justify-content: space-between;
  letter-spacing: 0.10em;
  padding: 8px 14px;
  text-transform: uppercase;
}

.RepoYardCardFootLink { 
  color: var(--theme-text-tertiary);
  text-decoration: none;
}

.RepoYardCardFootLink:hover { 
  color: var(--theme-text);
  text-decoration: none;
}

.RepoDriftersBox { 
  background: var(--theme-surface-bg);
  border: 1.5px solid var(--theme-border);
}

.ls-row { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  color: var(--theme-text-secondary);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 8px;
  grid-template-columns: 16px 36px 1fr auto auto;
  padding: 5px 10px;
  text-decoration: none;
}

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

.ls-row:hover { 
  background: rgba(245, 211, 0, 0.10);
  color: var(--theme-text);
  text-decoration: none;
}

.ls-glyph { 
  font-family: var(--theme-font-mono);
  font-size: 13px;
  line-height: 1;
  text-align: center;
}

.ls-glyph.draft { 
  color: var(--theme-draft-fg);
}

.ls-glyph.review { 
  color: var(--theme-review-fg);
}

.ls-glyph.approved { 
  color: var(--theme-approved-fg);
}

.ls-glyph.merged { 
  color: var(--theme-merged-fg);
}

.ls-num { 
  color: var(--theme-text-tertiary);
  font-size: 11.5px;
}

.ls-ttl { 
  color: var(--theme-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ls-author { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-size: 11px;
}

.ls-time { 
  color: var(--theme-text-muted);
  flex-shrink: 0;
  font-size: 11px;
  text-align: right;
  width: 28px;
}

.ledger-group { 
  align-items: start;
  border-top: 1.5px solid var(--theme-border);
  display: grid;
  gap: 14px;
  grid-template-columns: 100px 1fr;
  padding: 14px 0 8px;
}

.ledger-group:first-child { 
  border-top: 0;
}

.ledger-group-when { 
  color: var(--theme-text);
  font-family: var(--theme-font-display);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  padding-top: 6px;
}

.ledger-group-when small { 
  color: var(--theme-text-tertiary);
  display: block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  font-weight: 700;
  letter-spacing: var(--theme-ls-caps);
  margin-top: 4px;
  text-transform: uppercase;
}

.ledger-group-rows { 
  display: flex;
  flex-direction: column;
}

.ledger-row { 
  align-items: baseline;
  border-bottom: 1px solid var(--theme-border-light);
  color: var(--theme-text-secondary);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 14px;
  grid-template-columns: 56px 68px 1fr;
  padding: 8px 4px;
  text-decoration: none;
}

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

.ledger-row:hover { 
  background: rgba(245, 211, 0, 0.10);
  text-decoration: none;
}

.ledger-when { 
  color: var(--theme-text-tertiary);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.ledger-verb { 
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-align: right;
  text-transform: uppercase;
}

.ledger-verb.created { 
  color: var(--theme-draft-fg);
}

.ledger-verb.review { 
  color: var(--theme-review-fg);
}

.ledger-verb.revised { 
  color: var(--theme-revised-fg);
}

.ledger-verb.updated { 
  color: var(--theme-text-tertiary);
}

.ledger-verb.approved { 
  color: var(--theme-approved-fg);
}

.ledger-verb.merged { 
  color: var(--theme-merged-fg);
}

.ledger-verb.commented { 
  color: var(--theme-text-tertiary);
}

.ledger-verb.archived { 
  color: var(--theme-text-tertiary);
}

.ledger-body { 
  align-items: baseline;
  display: flex;
  gap: 8px;
  min-width: 0px;
}

.ledger-body .ttl { 
  color: var(--theme-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ledger-body .who { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-size: 11px;
  margin-left: auto;
}

.repo-rail { 
  align-self: start;
  border-left: 1.5px solid var(--theme-border);
  padding: 0;
}

.repo-rail-tabs { 
  border-bottom: 1.5px solid var(--theme-border);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.repo-rail-tab { 
  align-items: flex-start;
  background: transparent;
  border: 0;
  border-radius: 0;
  border-right: 1.5px solid var(--theme-border);
  color: var(--theme-text-tertiary);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  gap: 4px;
  letter-spacing: 0.16em;
  padding: 14px 14px 12px;
  text-align: left;
  text-transform: uppercase;
}

.repo-rail-tab:last-child { 
  border-right: 0;
}

.repo-rail-tab.on { 
  box-shadow: inset 0 -3px 0 var(--theme-hazard);
  color: var(--theme-text);
  font-weight: 700;
}

.repo-rail-tab-count { 
  color: var(--theme-text);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-transform: none;
}

.repo-rail-radio { 
  display: none;
}

.repo-rail-radio:checked + .repo-rail-panel { 
  display: block;
}

.repo-rail-panel { 
  display: none;
  padding: 16px 18px 22px;
}

.repo-rail-panel.on { 
  display: block;
}

.repo-rail-row { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  color: var(--theme-text-secondary);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  gap: 8px;
  grid-template-columns: auto 1fr auto;
  padding: 7px 2px;
  text-decoration: none;
}

.repo-rail-row:last-child { 
  border-bottom: 0;
}

.repo-rail-row:hover { 
  background: rgba(245, 211, 0, 0.10);
  color: var(--theme-text);
  text-decoration: none;
}

.repo-rail-row .rr-num { 
  color: var(--theme-text-tertiary);
  font-size: 11px;
}

.repo-rail-row .rr-ttl { 
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.repo-rail-row .rr-ago { 
  color: var(--theme-text-muted);
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.repo-rail-person { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  color: var(--theme-text-secondary);
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  gap: 8px;
  grid-template-columns: auto 1fr auto;
  padding: 6px 2px;
}

.repo-rail-person:last-child { 
  border-bottom: 0;
}

.repo-rail-person .rp-name { 
  color: var(--theme-text);
  font-weight: 600;
}

.repo-rail-person .rp-stat { 
  color: var(--theme-text-tertiary);
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.RepoDivider { 
  border: 0;
  border-top: 3px solid var(--theme-border);
  margin: 0px;
}

.RepoFooter { 
  align-items: center;
  border-top: 1.5px solid var(--theme-border);
  display: flex;
  gap: 18px;
  margin-top: 32px;
  padding: var(--theme-sp-9) 0 var(--theme-sp-4);
}

.RepoFooterMeta { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
}

.RepoBtn { 
  align-items: center;
  background: var(--theme-surface-bg);
  border: 1.5px solid var(--theme-border);
  color: var(--theme-text);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  gap: 8px;
  height: 36px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 8px 14px;
  text-decoration: none;
  text-transform: uppercase;
}

.RepoBtn:hover { 
  background: var(--theme-surface-hover);
  text-decoration: none;
}

.RepoBtn.hazard { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.RepoBtn.hazard:hover { 
  background: var(--theme-hazard-2);
}

.SettingsPageHeader { 
  margin-bottom: var(--theme-sp-8);
}

.SettingsSection { 
  margin-bottom: 40px;
}

.SettingsField { 
  margin-bottom: var(--theme-sp-5);
}

.SettingsFieldLabel { 
  color: var(--theme-text-secondary);
  display: block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  margin-bottom: var(--theme-sp-2);
}

.SettingsFieldHint { 
  color: var(--theme-text-tertiary);
  font-size: var(--theme-fs-sm);
  margin-top: var(--theme-sp-1);
}

.SettingsSaveRow { 
  align-items: center;
  display: flex;
  gap: var(--theme-sp-3);
  margin-top: var(--theme-sp-4);
}

.DangerZone { 
  border: 1px solid var(--theme-danger-fg);
  border-radius: var(--theme-radius-md);
  padding: var(--theme-sp-6);
}

.DangerHeader { 
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.DangerTitle { 
  color: var(--theme-danger-fg);
  font-weight: 600;
}

.DangerDesc { 
  color: var(--theme-text-secondary);
  font-size: var(--theme-fs-sm);
  margin-top: var(--theme-sp-1);
}

.SettingsCode { 
  background: var(--theme-surface-code);
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-md);
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  overflow-x: auto;
  padding: var(--theme-sp-3) var(--theme-sp-4);
  user-select: all;
}

.DownloadGrid { 
  display: flex;
  gap: var(--theme-sp-3);
  margin-top: var(--theme-sp-3);
}

.DownloadCard { 
  align-items: center;
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-md);
  color: var(--theme-text);
  cursor: pointer;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--theme-sp-2);
  padding: var(--theme-sp-5) var(--theme-sp-6);
  text-decoration: none;
  transition: background 0.1s, border-color 0.1s;
}

.DownloadCard:hover { 
  background: var(--theme-surface-raised);
  border-color: var(--theme-border);
  text-decoration: none;
}

.PlatformIcon { 
  align-items: center;
  color: var(--theme-text-secondary);
  display: flex;
  height: 32px;
  justify-content: center;
  width: 32px;
}

.DownloadLabel { 
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
}

.DownloadMeta { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: 10px;
}

.TreeShell { 
  display: flex;
  flex-direction: column;
  height: calc(100vh - 44px);
  margin: 0 auto;
  max-width: 960px;
  overflow: hidden;
  width: 100%;
}

.TreeMain { 
  display: flex;
  flex: 1;
  min-height: 0px;
}

.TreeSidebar { 
  border-right: 1px solid var(--theme-border-light);
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  overflow-y: auto;
  padding: var(--theme-sp-2) 0;
  transition: margin-left 200ms ease, opacity 200ms ease;
  width: 260px;
}

.tree-sidebar-hidden .TreeSidebar { 
  margin-left: -260px;
  opacity: 0;
}

.tree-item { 
  align-items: center;
  color: var(--theme-text);
  cursor: pointer;
  display: flex;
  gap: 6px;
  padding: 3px 12px;
  text-decoration: none;
  user-select: none;
  white-space: nowrap;
}

.tree-item:hover { 
  background: var(--theme-surface-hover);
}

.tree-item[data-selected] { 
  background: var(--theme-accent-light);
  color: var(--theme-accent);
}

.tree-chevron { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-size: 10px;
  text-align: center;
  width: 12px;
}

.tree-icon { 
  flex-shrink: 0;
  font-size: 13px;
  text-align: center;
  width: 16px;
}

.tree-icon-folder { 
  color: #9a8c7a;
}

.tree-icon-file { 
  color: var(--theme-text-tertiary);
}

.tree-label { 
  overflow: hidden;
  text-overflow: ellipsis;
}

.TreeContent { 
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0px;
}

.TreeContentHeader { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  justify-content: space-between;
  padding: 10px var(--theme-sp-5);
}

.TreeBreadcrumb { 
  color: var(--theme-text-secondary);
}

.bc-current { 
  color: var(--theme-text);
  font-weight: 500;
}

.tree-toggle-sidebar { 
  background: none;
  border: none;
  color: var(--theme-text-tertiary);
  cursor: pointer;
  flex-shrink: 0;
  font-size: 14px;
  line-height: 1;
  padding: 0 4px;
}

.tree-toggle-sidebar:hover { 
  color: var(--theme-text);
}

.tree-wrap-toggle { 
  align-items: center;
  color: var(--theme-text-tertiary);
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  gap: 6px;
  user-select: none;
}

.tree-wrap-toggle:hover { 
  color: var(--theme-text-secondary);
}

.tree-wrap-check { 
  align-items: center;
  border: 1.5px solid var(--theme-border);
  border-radius: 3px;
  display: flex;
  flex-shrink: 0;
  height: 12px;
  justify-content: center;
  transition: border-color 0.1s, background 0.1s;
  width: 12px;
}

.tree-wrap-toggle:hover .tree-wrap-check { 
  border-color: var(--theme-text-tertiary);
}

.tree-wrap-toggle[data-active] .tree-wrap-check { 
  background: var(--theme-text-secondary);
  border-color: var(--theme-text-secondary);
}

.tree-wrap-tick { 
  color: var(--theme-surface-bg);
  display: none;
  font-size: 9px;
  font-weight: bold;
  line-height: 1;
}

.tree-wrap-toggle[data-active] .tree-wrap-tick { 
  display: block;
}

.tree-wide.TreeShell { 
  max-width: 100%;
}

.TreeCodeView { 
  flex: 1;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  line-height: 1.65;
  overflow-y: auto;
  padding: 0px;
}

.code-line { 
  display: flex;
  white-space: pre;
}

.tree-word-wrap .code-line { 
  white-space: pre-wrap;
  word-break: break-all;
}

.code-line:hover { 
  background: var(--theme-surface-hover);
}

.line-num { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  padding-right: 16px;
  text-align: right;
  user-select: none;
  width: 48px;
}

.line-content { 
  flex: 1;
  padding-right: 16px;
}

.tree-media { 
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 28px;
}

.tree-media-el { 
  background: repeating-conic-gradient(rgba(0,0,0,0.06) 0 25%, transparent 0 50%) 0 0 / 16px 16px, #fff;
  border: 1px solid var(--theme-border-light);
  height: auto;
  max-height: calc(100vh - 180px);
  max-width: 100%;
}

.tree-media-cap { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.tree-download { 
  align-items: center;
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-md);
  display: flex;
  gap: 20px;
  padding: 16px 20px;
}

.tree-download-info { 
  color: var(--theme-text-secondary);
  display: flex;
  flex-direction: column;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  gap: 2px;
}

.tree-download-size { 
  color: var(--theme-text-tertiary);
}

.tree-download-btn { 
  align-items: center;
  background: var(--theme-accent);
  border-radius: var(--theme-radius-sm);
  color: var(--theme-surface-bg);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  gap: 6px;
  padding: 6px 14px;
  text-decoration: none;
  white-space: nowrap;
}

.tree-download-btn:hover { 
  opacity: 0.85;
}

.tree-fuzzy { 
  background: var(--theme-surface-bg);
  border: 1px solid var(--theme-border);
  border-radius: var(--theme-radius-md);
  box-shadow: 0 4px 24px rgba(0,0,0,0.12);
  display: none;
  left: 50%;
  padding: 4px;
  position: absolute;
  top: 96px;
  transform: translateX(-50%);
  width: 420px;
  z-index: 50;
}

.tree-fuzzy[data-open] { 
  display: block;
}

.tree-fuzzy input { 
  background: transparent;
  border: none;
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
  outline: none;
  padding: 8px 10px;
  width: 100%;
}

.tree-fuzzy-results { 
  font-size: var(--theme-fs-sm);
  max-height: 300px;
  overflow-y: auto;
}

.tree-fuzzy-result { 
  border-radius: var(--theme-radius-sm);
  color: var(--theme-text-secondary);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  padding: 6px 10px;
}

.tree-fuzzy-result:hover, .tree-fuzzy-result[data-active] { 
  background: var(--theme-accent-light);
  color: var(--theme-accent);
}

.TreeEmptyState { 
  align-items: center;
  color: var(--theme-text-tertiary);
  display: flex;
  flex: 1;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  justify-content: center;
}

.KindPrefix.kind-added { 
  color: #22c55e;
}

.KindPrefix.kind-deleted { 
  color: #ef4444;
}

.KindPrefix.kind-modified { 
  color: #22d3ee;
}

.ActivityTimeline { 
  padding-left: 32px;
  position: relative;
}

.ActivityTimelineLine { 
  background: var(--theme-border);
  bottom: 10px;
  left: 9px;
  position: absolute;
  top: 10px;
  width: 1px;
}

.ActivityGroupRow { 
  padding-bottom: var(--theme-sp-9);
  position: relative;
}

.ActivityGroupRow:last-child { 
  padding-bottom: 0px;
}

.ActivityGroupAvatar { 
  left: -32px;
  position: absolute;
  top: 0px;
  z-index: 1;
}

.ActivityGroupName { 
  color: var(--theme-text);
  display: block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
  margin-bottom: var(--theme-sp-3);
}

.ActivityEventItem { 
  padding-bottom: var(--theme-sp-3);
  position: relative;
}

.ActivityEventItem:last-child { 
  padding-bottom: 0px;
}

.ActivityEventItem::before { 
  background: var(--theme-border);
  border-radius: var(--theme-radius-full);
  content: "";
  height: 5px;
  left: -25px;
  position: absolute;
  top: 6px;
  width: 5px;
}

.ActivityEventHeader { 
  align-items: baseline;
  display: flex;
  gap: var(--theme-sp-4);
  justify-content: space-between;
  margin-bottom: var(--theme-sp-1);
}

.ActivityEventVerb { 
  color: var(--theme-text-secondary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.ActivityEventVerb.state-draft { 
  color: var(--theme-draft-fg);
}

.ActivityEventVerb.state-review { 
  color: var(--theme-review-fg);
}

.ActivityEventVerb.state-revised { 
  color: var(--theme-revised-fg);
}

.ActivityEventVerb.state-approved { 
  color: var(--theme-approved-fg);
}

.ActivityEventVerb.state-merged { 
  color: var(--theme-merged-fg);
}

.ActivityEventTime { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xs);
  white-space: nowrap;
}

.ActivityEventDetail { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  line-height: var(--theme-lh-normal);
  margin-bottom: var(--theme-sp-1);
}

.ActivityEventQuote { 
  border-left: 2px solid var(--theme-border);
  color: var(--theme-text-secondary);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-base);
  line-height: var(--theme-lh-relaxed);
  margin-bottom: var(--theme-sp-2);
  margin-top: var(--theme-sp-4);
  padding-left: var(--theme-sp-5);
}

.ActivityQuoteAuthor { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  font-weight: 600;
}

.NoActivity { 
  color: var(--theme-text-tertiary);
  display: block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-8) 0;
}

.VersionList { 
  display: flex;
  flex-direction: column;
  gap: var(--theme-sp-1);
  margin-top: var(--theme-sp-6);
}

.VersionRow { 
  border-radius: var(--theme-radius-md);
  display: block;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-5) var(--theme-sp-5);
}

.VersionRow:hover { 
  background: var(--theme-surface-hover);
}

.VersionHeader { 
  align-items: baseline;
  color: var(--theme-text);
  display: flex;
  gap: var(--theme-sp-6);
  justify-content: space-between;
  text-decoration: none;
}

.VersionLabel { 
  font-weight: 600;
}

.VersionMeta { 
  align-items: baseline;
  display: flex;
  gap: var(--theme-sp-4);
}

.VersionFiles { 
  display: flex;
  flex-direction: column;
  gap: var(--theme-sp-1);
  margin-top: var(--theme-sp-3);
  padding-left: var(--theme-sp-1);
}

.VersionFile { 
  color: var(--theme-text-tertiary);
  font-size: var(--theme-fs-xs);
}

.VersionFilePrefix.kind-added { 
  color: #22c55e;
}

.VersionFilePrefix.kind-deleted { 
  color: #ef4444;
}

.VersionFilePrefix.kind-modified { 
  color: #22d3ee;
}

.VersionComments { 
  display: flex;
  flex-direction: column;
  gap: var(--theme-sp-3);
  margin-top: var(--theme-sp-3);
  padding-left: var(--theme-sp-1);
}

.VersionComment { 
  color: var(--theme-text-tertiary);
  font-size: var(--theme-fs-xs);
}

.VersionCommentAuthor { 
  color: var(--theme-text-secondary);
  font-weight: 600;
}

.VersionCommentPath { 
  color: var(--theme-text-muted);
}

.VersionsListHeader { 
  display: block;
  margin-bottom: var(--theme-sp-3);
  margin-top: var(--theme-sp-4);
}

.UnsavedNoDiff { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-8) 0;
  text-align: center;
}

.UnsavedNotOpen { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-8) 0;
  text-align: center;
}

.WsCard { 
  background: #fff;
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-lg);
  margin-bottom: var(--theme-sp-6);
  padding: var(--theme-sp-8);
}

[data-theme="rev-dark"] .WsCard { 
  background: var(--theme-surface-raised);
}

.WsStatusTop { 
  align-items: flex-start;
  display: flex;
  gap: var(--theme-sp-4);
  justify-content: space-between;
  margin-bottom: var(--theme-sp-2);
}

.WsStatusLeft { 
  align-items: center;
  display: flex;
  gap: var(--theme-sp-3);
}

.WsStatusActions { 
  display: flex;
  flex-shrink: 0;
  gap: var(--theme-sp-3);
}

.WsChangeTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-xl);
  font-weight: 700;
  line-height: var(--theme-lh-tight);
  margin: var(--theme-sp-2) 0;
}

.WsStatusMeta { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-bottom: var(--theme-sp-5);
}

.WsSyncBanner { 
  align-items: center;
  background: #fef9e7;
  border: 1px solid #f5e6a3;
  border-radius: var(--theme-radius-md);
  display: flex;
  justify-content: space-between;
  padding: var(--theme-sp-4) var(--theme-sp-5);
}

[data-theme="rev-dark"] .WsSyncBanner { 
  background: #332b00;
  border-color: #554a1a;
}

.WsSyncText { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
}

.WsSyncDetail { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
}

.WsSaveBar { 
  align-items: center;
  display: flex;
  gap: var(--theme-sp-4);
}

.WsAutosaveToggle { 
  align-items: center;
  display: flex;
  flex-shrink: 0;
  gap: var(--theme-sp-3);
}

.WsToggleLabel { 
  color: var(--theme-text-secondary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-base);
}

.WsToggleTrack { 
  background: var(--theme-surface-raised);
  border: 1px solid var(--theme-border);
  border-radius: 11px;
  cursor: pointer;
  flex-shrink: 0;
  height: 22px;
  padding: 0px;
  position: relative;
  transition: background 0.15s;
  width: 40px;
}

.WsToggleTrack::after { 
  background: #fff;
  border: 1px solid var(--theme-border);
  border-radius: 50%;
  content: "";
  height: 16px;
  left: 2px;
  position: absolute;
  top: 2px;
  transition: transform 0.15s;
  width: 16px;
}

.WsToggleTrack[data-on] { 
  background: var(--theme-accent);
  border-color: var(--theme-accent);
}

.WsToggleTrack[data-on]::after { 
  border-color: var(--theme-accent);
  transform: translateX(18px);
}

.WsNoDiff { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-8) 0;
  text-align: center;
}

.WsEmptyState { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: var(--theme-sp-8) 0;
  text-align: center;
}

.WsEmptyStateMsg { 
  margin-bottom: var(--theme-sp-4);
}

.WsCloseForm { 
  margin-top: var(--theme-sp-4);
}

.WsErrorBox { 
  background: var(--theme-del-bg-line);
  border: 1px solid var(--theme-del);
  border-radius: var(--theme-radius-md);
  color: var(--theme-del);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-bottom: var(--theme-sp-6);
  padding: var(--theme-sp-4);
}

.WsSuccessBox { 
  background: var(--theme-add-bg-line);
  border: 1px solid var(--theme-add);
  border-radius: var(--theme-radius-md);
  color: var(--theme-add);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-bottom: var(--theme-sp-6);
  padding: var(--theme-sp-4);
}

.ReviewsPageHeader { 
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-6);
}

.DraftsPageHeader { 
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-6);
}

.ApprovedPageHeader { 
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-6);
}

.RepoAvatar { 
  align-self: flex-start;
  border-radius: var(--theme-radius-full);
  flex-shrink: 0;
  height: 20px;
  margin-top: 2px;
  width: 20px;
}

.ReposPageHeader { 
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--theme-sp-6);
}

.RepoRow { 
  align-items: center;
  border-bottom: 1px solid var(--theme-border-light);
  border-left: 3px solid transparent;
  display: flex;
  gap: var(--theme-sp-4);
  padding: var(--theme-sp-4) 0;
  padding-left: var(--theme-sp-4);
  text-decoration: none;
}

.RepoRow:hover { 
  background: var(--theme-surface-hover);
  border-left-color: var(--repo-accent);
  text-decoration: none;
}

.RepoInfo { 
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--theme-sp-1);
  min-width: 0px;
}

.RepoName { 
  color: var(--theme-text);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-md);
  font-weight: 600;
}

.RepoDesc { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-sm);
  line-height: var(--theme-lh-tight);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.RepoStats { 
  align-items: baseline;
  display: flex;
  flex-shrink: 0;
  gap: var(--theme-sp-4);
}

.RepoActivity { 
  color: var(--theme-text-tertiary);
  flex-shrink: 0;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  min-width: 64px;
  text-align: right;
}

.LoginContainer { 
  margin: 0 auto;
  max-width: 380px;
  padding: 80px 16px;
  width: 100%;
}

.LoginTitle { 
  color: var(--theme-text);
  font-family: var(--theme-font-serif);
  font-size: var(--theme-fs-xl);
  margin-bottom: 8px;
  text-align: center;
}

.LoginHint { 
  color: var(--theme-text-tertiary);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  line-height: var(--theme-lh-relaxed);
  margin-bottom: 32px;
  text-align: center;
}

.LoginForm { 
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.LoginError { 
  color: var(--theme-del);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  margin-bottom: 16px;
  text-align: center;
}

.LoginSuccess { 
  color: var(--theme-add);
  display: none;
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  text-align: center;
}

.CodeBlock { 
  background: var(--theme-surface-raised);
  border: 1px solid var(--theme-border-light);
  border-radius: var(--theme-radius-md);
  font-family: var(--theme-font-mono);
  font-size: var(--theme-fs-sm);
  padding: 2px 6px;
}

.nd-title-input { 
  background: transparent;
  border: 0;
  caret-color: var(--theme-hazard);
  color: var(--theme-ink);
  display: block;
  font-family: var(--theme-font-display);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.028em;
  line-height: 1.06;
  margin: 0;
  min-height: 1.05em;
  outline: 0;
  overflow: hidden;
  padding: 0;
  resize: none;
  width: 100%;
}

.nd-title-input::placeholder { 
  color: var(--theme-ink-4);
  font-weight: 600;
  opacity: 1;
}

.nd-title-input:focus { 
  box-shadow: inset 0 -3px 0 var(--theme-hazard);
}

.nd-description { 
  padding-top: 6px;
}

.nd-desc-mark { 
  align-items: baseline;
  color: var(--theme-ink-3);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 700;
  gap: 10px;
  letter-spacing: 0.18em;
  padding: 18px 0 10px;
  text-transform: uppercase;
}

.nd-desc-mark .glyph { 
  color: var(--theme-ink-4);
}

.nd-desc-mark .rule { 
  align-self: center;
  background: var(--theme-rule-soft);
  flex: 1;
  height: 1px;
}

.nd-desc-count { 
  color: var(--theme-ink-3);
}

.nd-desc-count b { 
  color: var(--theme-ink);
  font-weight: 700;
}

.nd-desc-input { 
  background: transparent;
  border: 1.5px dashed var(--theme-rule-soft);
  caret-color: var(--theme-hazard);
  color: var(--theme-ink);
  display: block;
  font-family: var(--theme-font-display);
  font-size: 19px;
  font-weight: 400;
  letter-spacing: -0.005em;
  line-height: 1.5;
  margin: 0;
  min-height: 200px;
  outline: 0;
  padding: 18px 22px;
  resize: vertical;
  transition: border-color 0.12s, background 0.12s;
  width: 100%;
}

.nd-desc-input::placeholder { 
  color: var(--theme-ink-4);
}

.nd-desc-input:hover { 
  border-color: var(--theme-rule);
}

.nd-desc-input:focus { 
  background: var(--theme-bg-2);
  border-color: var(--theme-rule);
  border-style: solid;
}

.nd-stack { 
  align-items: center;
  border-top: 1px solid var(--theme-rule-soft);
  display: flex;
  flex-wrap: wrap;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  gap: 12px;
  margin-top: 16px;
  padding: 18px 0 4px;
}

.nd-stack-label { 
  align-items: baseline;
  color: var(--theme-ink-3);
  display: inline-flex;
  font-size: 10px;
  font-weight: 700;
  gap: 6px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.nd-stack-label .glyph { 
  color: var(--theme-ink-4);
}

.nd-stack-pick { 
  align-items: center;
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  color: var(--theme-ink);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 10px;
  line-height: 1.2;
  max-width: 560px;
  padding: 7px 12px;
}

.nd-stack-pick:hover { 
  background: var(--theme-bg-2);
}

.nd-stack-num { 
  color: var(--theme-ink-3);
  font-weight: 700;
}

.nd-stack-state { 
  font-size: 13px;
}

.nd-stack-state[data-state="draft"] { 
  color: var(--theme-ink);
}

.nd-stack-state[data-state="review"] { 
  color: var(--theme-review-stage);
}

.nd-stack-state[data-state="approved"] { 
  color: var(--theme-add-strong);
}

.nd-stack-state[data-state="merged"] { 
  color: var(--theme-merged);
}

.nd-stack-ttl { 
  font-weight: 600;
  max-width: 360px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nd-stack-by { 
  color: var(--theme-ink-3);
}

.nd-stack-caret { 
  color: var(--theme-ink-4);
  margin-left: auto;
  padding-left: 8px;
}

.nd-stack-clear { 
  background: transparent;
  border: 0;
  color: var(--theme-ink-3);
  cursor: pointer;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  padding: 0;
  text-decoration: underline;
  text-decoration-style: dashed;
  text-transform: uppercase;
  text-underline-offset: 3px;
}

.nd-stack-clear:hover { 
  color: var(--theme-ink);
}

.nd-stack-hint { 
  color: var(--theme-ink-3);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.nd-stack-hint b { 
  color: var(--theme-ink);
}

.nd-picker { 
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  box-shadow: 4px 4px 0 var(--theme-ink);
  display: none;
  margin: 8px 0 0;
  max-width: 720px;
}

.nd-picker.open { 
  display: block;
}

.nd-picker-head { 
  align-items: center;
  background: var(--theme-bg-2);
  border-bottom: 1.5px solid var(--theme-rule);
  color: var(--theme-ink-3);
  display: flex;
  font-family: var(--theme-font-mono);
  font-size: 10px;
  font-weight: 700;
  justify-content: space-between;
  letter-spacing: 0.18em;
  padding: 9px 14px;
  text-transform: uppercase;
}

.nd-picker-x { 
  background: transparent;
  border: 0;
  color: var(--theme-ink-3);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0 4px;
}

.nd-picker-x:hover { 
  color: var(--theme-ink);
}

.nd-picker-row { 
  align-items: center;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--theme-rule-soft);
  color: var(--theme-ink);
  cursor: pointer;
  display: grid;
  font-family: var(--theme-font-mono);
  font-size: 12.5px;
  gap: 12px;
  grid-template-columns: 56px 16px 1fr auto;
  padding: 10px 14px;
  text-align: left;
  text-decoration: none;
  width: 100%;
}

.nd-picker-row:last-child { 
  border-bottom: 0;
}

.nd-picker-row:hover { 
  background: rgba(245, 211, 0, 0.12);
}

.nd-picker-row.cur { 
  background: var(--theme-hazard);
  color: #0a0a0a;
}

.nd-picker-row.cur .nd-stack-num, .nd-picker-row.cur .nd-stack-by { 
  color: #0a0a0a;
}

.nd-picker-row.cur .nd-stack-state { 
  color: #0a0a0a;
}

.nd-actions { 
  align-items: center;
  border-top: 1.5px solid var(--theme-rule);
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 24px;
  padding: 22px 0 8px;
}

.nd-actions-left { 
  flex: 1;
  min-width: 0;
}

.nd-actions-right { 
  align-items: center;
  display: flex;
  gap: 8px;
}

.nd-create { 
  gap: 12px;
  padding-right: 8px;
}

.nd-create-kbd { 
  align-items: center;
  background: #0a0a0a;
  border-radius: 4px;
  color: var(--theme-hazard);
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 11px;
  font-weight: 700;
  gap: 1px;
  letter-spacing: 0;
  line-height: 1;
  padding: 3px 6px;
}

.nd-create-kbd .key { 
  align-items: center;
  display: inline-flex;
  justify-content: center;
  min-width: 12px;
  padding: 0 2px;
}

.nd-cmd { 
  align-items: baseline;
  color: var(--theme-ink-3);
  display: flex;
  flex-wrap: wrap;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  gap: 6px;
  padding: 10px 0 0;
}

.nd-cmd b { 
  color: var(--theme-ink);
  font-weight: 700;
}

.btn { 
  align-items: center;
  background: var(--theme-bg);
  border: 1.5px solid var(--theme-rule);
  border-radius: 0;
  color: var(--theme-ink);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--theme-font-mono);
  font-size: 12px;
  font-weight: 600;
  gap: 8px;
  height: 36px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 8px 14px;
  text-decoration: none;
  text-transform: uppercase;
}

.btn:hover { 
  background: var(--theme-bg-2);
}

.btn.solid { 
  background: var(--theme-ink);
  color: var(--theme-bg);
}

.btn.solid:hover { 
  background: var(--theme-ink-2);
}

.btn.hazard { 
  background: var(--theme-hazard);
  border-color: #0a0a0a;
  color: #0a0a0a;
}

.btn.hazard:hover { 
  background: var(--theme-hazard-2);
}

.btn.ghost { 
  border-color: var(--theme-rule-soft);
  color: var(--theme-ink-2);
}

.btn:disabled { 
  cursor: not-allowed;
  opacity: 0.45;
}

.keyhint { 
  color: var(--theme-ink-3);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.keyhint kbd { 
  border: 1.25px solid var(--theme-rule-soft);
  color: var(--theme-ink-2);
  display: inline-block;
  font-family: inherit;
  font-size: 10px;
  margin: 0 2px;
  padding: 0 5px;
}

.nd-error { 
  background: var(--theme-del-bg, #f3cdc7);
  border: 1.5px solid var(--theme-del-strong);
  color: var(--theme-del-strong);
  font-family: var(--theme-font-mono);
  font-size: 12px;
  margin-bottom: 16px;
  padding: 8px 14px;
}

.nd-message { 
  background: var(--theme-add-bg, #d4ebd6);
  border: 1.5px solid var(--theme-add-strong);
  color: var(--theme-add-strong);
  font-family: var(--theme-font-mono);
  font-size: 12px;
  margin-bottom: 16px;
  padding: 8px 14px;
}
