:root {
  color-scheme: light;
  --bg: #efebe2;
  --bg2: #e6e0d2;
  --paper: #faf6ec;
  --paper-warm: #f3edde;
  --ink: #1a1410;
  --ink-soft: rgba(26, 20, 16, 0.7);
  --ink-muted: rgba(26, 20, 16, 0.5);
  --ink-faint: rgba(26, 20, 16, 0.32);
  --line: rgba(55, 13, 8, 0.16);
  --line-soft: rgba(55, 13, 8, 0.08);
  --line-strong: rgba(55, 13, 8, 0.32);
  --cedar: #370d08;
  --cedar-soft: #5a1d12;
  --seraphim: #c95a21;
  --gold: #b8872c;
  --olive: #6b7d43;
  --crimson: #9b1b01;
  --serif: "Fraunces", Georgia, serif;
  --mono: "IBM Plex Mono", "Courier New", monospace;
  --ui: "DM Sans", "Helvetica Neue", sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--ui);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

button, textarea, input, select { font: inherit; color: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }

.app {
  display: grid;
  grid-template-rows: auto auto 1fr;
  height: 100vh;
  overflow: hidden;
}

.topbar {
  display: grid;
  grid-template-columns: 280px 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--line);
  background: var(--paper);
}

.brand { display: flex; align-items: center; gap: 12px; }
.brand__mark {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: linear-gradient(135deg, var(--seraphim), #a83c18);
  box-shadow: 0 4px 10px rgba(155, 27, 1, 0.15);
  display: grid;
  place-items: center;
  color: var(--paper);
  font-family: var(--serif);
  font-weight: 600;
  font-size: 14px;
}
.brand__name { display: grid; line-height: 1.15; }
.brand__name strong {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0;
  color: var(--cedar);
}
.brand__name small {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--ink-muted);
  text-transform: uppercase;
}

.topbar__stats {
  display: flex;
  gap: 8px;
  justify-content: center;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-muted);
  letter-spacing: 0.06em;
}
.topbar__stat {
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--ink-muted);
  display: inline-flex;
  align-items: baseline;
  padding: 6px 8px;
  transition: background 160ms, border-color 160ms;
}
.topbar__stat:hover {
  background: var(--paper-warm);
  border-color: var(--line);
}
.topbar__stat strong {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
  color: var(--cedar);
  letter-spacing: 0;
  margin-right: 6px;
}
.topbar__stat.approved strong { color: var(--olive); }
.topbar__stat.needs strong { color: var(--seraphim); }
.topbar__actions { display: flex; gap: 6px; align-items: center; }
.mode-banner {
  border-bottom: 1px solid rgba(184, 135, 44, 0.28);
  background: rgba(184, 135, 44, 0.12);
  color: #6a4a14;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  padding: 7px 20px;
  text-transform: uppercase;
}
.topbar__chip {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--cedar);
  background: var(--paper-warm);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.topbar__chip .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ink-muted);
}
.topbar__chip.live .dot { background: var(--olive); }

.btn {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--cedar);
  transition: background 160ms, border-color 160ms, color 160ms;
}
.btn:hover { background: var(--paper-warm); border-color: var(--line-strong); }
.btn--primary { background: var(--cedar); color: var(--paper); border-color: var(--cedar); }
.btn--primary:hover { background: var(--cedar-soft); border-color: var(--cedar-soft); }
.btn--success { background: var(--olive); color: var(--paper); border-color: var(--olive); }
.btn--success:hover { background: #57693a; }
.btn--ghost { background: transparent; border-color: transparent; color: var(--ink-soft); }
.btn--ghost:hover { color: var(--cedar); background: var(--paper-warm); border-color: var(--line); }
.btn--danger { color: var(--crimson); }
.btn--danger:hover { background: rgba(155, 27, 1, 0.08); border-color: rgba(155, 27, 1, 0.32); }
.btn .kbd {
  margin-left: 6px;
  padding: 1px 5px;
  border: 1px solid currentColor;
  border-radius: 4px;
  font-size: 9px;
  opacity: 0.6;
}

.cols {
  display: grid;
  grid-template-columns: 280px minmax(520px, 1fr) 320px;
  height: 100%;
  overflow: hidden;
}
.cols.collapsed-right { grid-template-columns: 280px minmax(520px, 1fr) 44px; }

.list {
  display: grid;
  grid-template-rows: auto 1fr;
  border-right: 1px solid var(--line);
  background: var(--paper);
  overflow: hidden;
}
.list__head {
  padding: 14px 16px 10px;
  display: grid;
  gap: 10px;
  border-bottom: 1px solid var(--line);
}
.field { display: grid; gap: 4px; }
.field label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
  text-transform: uppercase;
}
.field input,
.field select,
.inline-field,
.notes textarea,
#lessonsText {
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper-warm);
  font-size: 13px;
  color: var(--ink);
  width: 100%;
  transition: border-color 160ms, background 160ms;
}
.field input:focus,
.field select:focus,
.inline-field:focus,
.notes textarea:focus,
#lessonsText:focus {
  outline: none;
  border-color: var(--cedar);
  background: var(--paper);
}
.field input::placeholder { color: var(--ink-faint); }
.fields-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }

.list__filters {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.04em;
}
.filter {
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--ink-soft);
  background: transparent;
}
.filter.is-active { background: var(--cedar); color: var(--paper); border-color: var(--cedar); }
.list__rows {
  overflow-y: auto;
  padding: 4px 0 80px;
  scrollbar-width: thin;
}
.row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  padding: 10px 16px;
  border: 0;
  border-bottom: 1px solid var(--line-soft);
  background: transparent;
  text-align: left;
  width: 100%;
  transition: background 120ms;
  align-items: start;
}
.row:hover { background: var(--paper-warm); }
.row.is-active {
  background: rgba(216, 169, 72, 0.14);
  border-left: 2px solid var(--seraphim);
  padding-left: 14px;
}
.row__status {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1.5px solid var(--line-strong);
  background: transparent;
  margin-top: 3px;
  position: relative;
  flex-shrink: 0;
}
.row__status.is-approved,
.row__status.is-saved-ready,
.row__status.is-approved-post { background: var(--olive); border-color: var(--olive); }
.row__status.is-approved::after,
.row__status.is-saved-ready::after,
.row__status.is-approved-post::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border-right: 2px solid var(--paper);
  border-bottom: 2px solid var(--paper);
  transform: rotate(45deg);
}
.row__status.is-changes,
.row__status.is-needs-review,
.row__status.is-unsaved { background: var(--seraphim); border-color: var(--seraphim); }
.row__status.is-changes::after,
.row__status.is-needs-review::after,
.row__status.is-unsaved::after {
  content: "";
  position: absolute;
  inset: 4px;
  background: var(--paper);
  border-radius: 50%;
}
.row__status.is-rejected { background: var(--crimson); border-color: var(--crimson); }
.row__status.is-rejected::after {
  content: "×";
  position: absolute;
  inset: -1px 0 0;
  text-align: center;
  color: var(--paper);
  font-size: 13px;
  line-height: 14px;
  font-weight: 600;
}
.row__status.is-needs-review { background: var(--gold); border-color: var(--gold); }
.row__status.is-unsaved { background: #6f4b99; border-color: #6f4b99; }
.row__status.is-saved-ready { background: var(--olive); border-color: var(--olive); }
.row__status.is-approved-post { background: var(--gold); border-color: var(--gold); }
.row__body { min-width: 0; }
.row__top { display: flex; gap: 8px; align-items: baseline; margin-bottom: 2px; }
.row__lane {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--seraphim);
  font-weight: 600;
}
.row__date {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--ink-muted);
  letter-spacing: 0.06em;
}
.row__path {
  font-size: 13px;
  line-height: 1.35;
  color: var(--ink-soft);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.row__snippet {
  display: block;
  margin-top: 4px;
  color: var(--ink-muted);
  font-size: 12px;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.row__dirty {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--seraphim);
  font-weight: 600;
  margin-top: 4px;
}

.review {
  display: grid;
  grid-template-rows: auto 1fr auto;
  overflow: hidden;
  background: var(--bg);
}
.review__head {
  display: grid;
  padding: 14px 32px;
  border-bottom: 1px solid var(--line);
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  background: var(--paper);
}
.review__id { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.review__path {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-muted);
  letter-spacing: 0.04em;
}
.review__path strong { color: var(--cedar); font-weight: 600; }
.review__sep { color: var(--ink-faint); }
.review__status-row { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.pill {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 999px;
  font-weight: 600;
  background: var(--paper-warm);
  color: var(--ink-soft);
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.pill.is-on { background: rgba(107, 125, 67, 0.14); color: #4a5a2c; border-color: rgba(107, 125, 67, 0.3); }
.pill.is-warn { background: rgba(184, 135, 44, 0.16); color: #6a4a14; border-color: rgba(184, 135, 44, 0.32); }
.pill.is-bad { background: rgba(155, 27, 1, 0.1); color: var(--crimson); border-color: rgba(155, 27, 1, 0.28); }
.pill.is-needs-review { background: rgba(184, 135, 44, 0.18); color: #6a4a14; border-color: rgba(184, 135, 44, 0.4); }
.pill.is-unsaved { background: rgba(111, 75, 153, 0.16); color: #5a3c80; border-color: rgba(111, 75, 153, 0.42); }
.pill.is-saved-ready { background: rgba(107, 125, 67, 0.18); color: #45542b; border-color: rgba(107, 125, 67, 0.42); }
.pill.is-approved-post { background: rgba(184, 135, 44, 0.24); color: #6a4a14; border-color: rgba(184, 135, 44, 0.48); }
.pill.is-rejected { background: rgba(155, 27, 1, 0.12); color: var(--crimson); border-color: rgba(155, 27, 1, 0.42); }
.pill .dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; opacity: 0.7; }
.review__head-actions { display: flex; gap: 4px; }
.iconbtn {
  width: 32px;
  height: 32px;
  border-radius: 7px;
  border: 1px solid transparent;
  background: transparent;
  display: grid;
  place-items: center;
  color: var(--ink-soft);
}
.iconbtn:hover { background: var(--paper-warm); color: var(--cedar); border-color: var(--line); }
.iconbtn svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.review__body {
  overflow-y: auto;
  padding: 18px 34px 62px;
}
.review__body-inner {
  max-width: 980px;
  margin: 0 auto;
  display: grid;
  gap: 10px;
}
.publish-desk {
  display: grid;
  gap: 0;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.publish-guide {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
  color: var(--ink-soft);
  font-size: 11px;
  line-height: 1.25;
}
.publish-guide strong {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--seraphim);
}
.publish-grid {
  display: grid;
  grid-template-columns: minmax(180px, 1.2fr) minmax(104px, 0.6fr) minmax(144px, 0.78fr) minmax(140px, 0.75fr) minmax(112px, 0.65fr);
  gap: 8px;
  align-items: stretch;
}
.compact-meta,
.compact-check {
  min-width: 0;
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  background: rgba(250, 246, 236, 0.54);
  padding: 5px 8px;
  display: grid;
  gap: 1px;
}
.compact-meta span,
.tag-field > span {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.compact-meta strong {
  min-width: 0;
  color: var(--cedar);
  font-weight: 500;
  font-size: 12px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.compact-meta--field { padding-bottom: 7px; }
.compact-meta--field .inline-field {
  min-height: 26px;
  padding: 3px 7px;
  font-size: 12px;
}
.compact-check {
  grid-template-columns: 16px 1fr;
  align-items: center;
  align-content: center;
  gap: 7px;
  color: var(--cedar);
}
.compact-check input {
  appearance: none;
  width: 15px;
  height: 15px;
  border: 1.5px solid var(--line-strong);
  border-radius: 4px;
  background: var(--paper);
  margin: 0;
  position: relative;
}
.compact-check input:checked { background: var(--olive); border-color: var(--olive); }
.compact-check input:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border-right: 2px solid var(--paper);
  border-bottom: 2px solid var(--paper);
  transform: rotate(45deg);
}
.compact-check span:last-child {
  font-size: 11px;
  font-weight: 600;
  color: var(--cedar);
  line-height: 1.15;
}
.publish-summary {
  display: grid;
  grid-template-columns: minmax(170px, 0.42fr) minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
  font-size: 11px;
  line-height: 1.25;
  color: var(--ink-muted);
}
.publish-summary strong {
  font-weight: 500;
  color: var(--ink-soft);
}
.publish-actions {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  align-items: center;
}
.publish-actions .btn {
  padding: 5px 9px;
  font-size: 10px;
}
.tag-editor {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line-soft);
}
.tag-field {
  min-width: 0;
  display: grid;
  gap: 6px;
}
.tag-field .inline-field {
  min-height: 28px;
  padding: 4px 7px;
  font-size: 12px;
}
.meta-grid {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 10px 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.meta-grid dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.meta-grid dd {
  margin: 0;
  font-size: 14px;
  color: var(--cedar);
}
.inline-field {
  min-height: 34px;
  resize: vertical;
}
textarea.inline-field {
  min-height: 68px;
  line-height: 1.45;
}
.publish-note,
.suggestion-empty {
  margin: 6px 0 0;
  color: var(--ink-muted);
  font-size: 12px;
  line-height: 1.35;
}
.suggestion-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 0;
}
.suggestion-chip {
  flex: 1 1 calc(50% - 6px);
  max-width: 100%;
  min-width: 130px;
  padding: 4px 8px;
  border: 1px solid rgba(107, 125, 67, 0.28);
  border-radius: 999px;
  background: rgba(107, 125, 67, 0.1);
  color: #48582f;
  font-family: var(--mono);
  font-size: 9px;
  line-height: 1.25;
  letter-spacing: 0;
  white-space: nowrap;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
}
.suggestion-chip:hover,
.suggestion-chip:focus-visible {
  outline: none;
  border-color: rgba(107, 125, 67, 0.55);
  background: rgba(107, 125, 67, 0.16);
}
.prayer-block { display: grid; gap: 10px; }
.prayer-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 23px;
  line-height: 1.12;
  letter-spacing: 0;
  color: var(--cedar);
  margin: 0;
  text-wrap: balance;
  max-width: 34ch;
  font-variation-settings: "opsz" 36;
  border: 1px dashed transparent;
  padding: 1px 6px;
  margin-left: -6px;
  border-radius: 6px;
  cursor: text;
}
.prayer-title:hover { background: var(--paper-warm); border-color: var(--line); }
.prayer-title:focus { outline: none; background: var(--paper); border-color: var(--cedar); }
.prayer-body {
  font-family: var(--serif);
  font-weight: 500;
  font-style: italic;
  font-size: 15.5px;
  line-height: 1.23;
  letter-spacing: 0;
  color: var(--cedar);
  max-width: 44em;
  border: 1px dashed transparent;
  padding: 6px 9px;
  margin-left: -10px;
  border-radius: 8px;
  cursor: text;
  min-height: 96px;
  white-space: pre-wrap;
}
.prayer-body:hover { background: var(--paper-warm); border-color: var(--line); }
.prayer-body:focus { outline: none; background: var(--paper); border-color: var(--cedar); }
.scripture {
  display: grid;
  grid-template-columns: minmax(140px, auto) 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  align-items: start;
}
.scripture-panel {
  display: grid;
  gap: 8px;
  padding: 10px 0 12px;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}
.section-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.section-title h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 600;
  color: var(--cedar);
}
.section-title span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
}
.scripture__ref {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--seraphim);
}
.scripture__text {
  font-family: var(--serif);
  font-size: 13px;
  line-height: 1.38;
  color: var(--ink-soft);
  margin: 0;
}
.checklist {
  display: grid;
  gap: 8px;
  padding: 18px 0 4px;
}
.checklist__title {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0 0 2px;
}
.check {
  display: grid;
  grid-template-columns: 22px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  background: var(--paper);
}
.check:hover { background: var(--paper-warm); border-color: var(--line); }
.check input {
  appearance: none;
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--line-strong);
  border-radius: 4px;
  background: var(--paper);
  margin: 0;
  position: relative;
}
.check input:checked { background: var(--olive); border-color: var(--olive); }
.check input:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border-right: 2px solid var(--paper);
  border-bottom: 2px solid var(--paper);
  transform: rotate(45deg);
}
.check__label { font-size: 14px; color: var(--cedar); font-weight: 500; }
.check__hint {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.notes {
  display: grid;
  gap: 6px;
  padding-top: 8px;
}
.notes__head { display: flex; align-items: baseline; gap: 10px; }
.notes h3 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0;
  color: var(--cedar);
}
.notes textarea {
  min-height: 92px;
  font-size: 14px;
  line-height: 1.55;
  resize: vertical;
}
.ai-panel {
  display: grid;
  gap: 8px;
}
.note-grid {
  display: grid;
  gap: 8px;
}
.note {
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  background: var(--paper);
  color: var(--ink-soft);
  font-size: 13px;
}
.note strong {
  display: block;
  color: var(--cedar);
  margin-bottom: 4px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.ai-note {
  border-left: 3px solid var(--gold);
  background: rgba(184, 135, 44, 0.11);
  padding: 10px 12px;
  border-radius: 0 8px 8px 0;
  font-size: 13px;
  color: var(--ink-soft);
}
.ai-note strong { display: block; color: var(--cedar); margin-bottom: 5px; }
.ai-note button { margin-right: 8px; }

.actionbar {
  border-top: 1px solid var(--line);
  background: var(--paper);
  padding: 8px 18px;
  display: grid;
  grid-template-columns: auto minmax(80px, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.actionbar__nav,
.actionbar__decisions { display: flex; gap: 5px; flex-wrap: nowrap; }
.actionbar .btn {
  padding: 5px 8px;
  font-size: 10px;
}
.actionbar .kbd { display: none; }
.actionbar__center {
  display: flex;
  gap: 8px;
  justify-content: center;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  text-transform: uppercase;
  align-items: center;
}
.actionbar__center #saveStatus {
  display: inline-flex;
  align-items: center;
}
.actionbar__center .saved { color: var(--olive); font-weight: 600; }
.actionbar__center .dirty { color: var(--seraphim); font-weight: 600; }
.editor-name {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.editor-name span { color: var(--ink-muted); }
.editor-name input {
  width: 120px;
  min-height: 28px;
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper-warm);
  font-family: var(--ui);
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
}

.right {
  border-left: 1px solid var(--line);
  background: var(--paper-warm);
  overflow: hidden;
  display: grid;
  grid-template-rows: 1fr;
}
.collapsed-right .right__body,
.collapsed-right .right__actions,
.collapsed-right .right__sub { display: none; }
.right__head {
  padding: 0 0 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border-bottom: 1px solid var(--line);
}
.collapsed-right .right__head {
  flex-direction: column;
  padding: 14px 8px;
  border-bottom: 0;
}
.collapsed-right .right__head h2 {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  margin: 0;
  font-size: 13px;
}
.right__title { display: grid; gap: 2px; }
.right__sub {
  margin: 0;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--seraphim);
  font-weight: 600;
}
.right h2 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0;
  color: var(--cedar);
  line-height: 1.1;
}
.right__actions { display: flex; gap: 6px; flex-wrap: wrap; justify-content: end; }
.right__body {
  overflow-y: auto;
  padding: 16px 18px 80px;
  display: grid;
  align-content: start;
  gap: 18px;
}
.right-section {
  display: grid;
  gap: 12px;
  min-width: 0;
}
.rules-md {
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink);
}
.rules-md h1,
.rules-md h2,
.rules-md h3 {
  font-family: var(--serif);
  font-weight: 600;
  letter-spacing: 0;
  color: var(--cedar);
  margin: 18px 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--line-soft);
}
.rules-md h1 { font-size: 18px; }
.rules-md h2 { font-size: 16px; }
.rules-md h3 { font-size: 15px; }
.rules-md p { margin: 0 0 10px; }
.rules-md ul {
  margin: 0 0 12px;
  padding-left: 18px;
}
.rules-md li { margin: 0 0 6px; }
.rules-md mark {
  background: rgba(216, 169, 72, 0.32);
  padding: 0 3px;
  border-radius: 3px;
}
.commentary {
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.comment-form {
  display: grid;
  gap: 8px;
}
.comment-form label {
  display: grid;
  gap: 4px;
}
.comment-form span {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.comment-form input,
.comment-form textarea {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper);
  padding: 7px 9px;
  resize: vertical;
}
.comment-feed {
  display: grid;
  gap: 10px;
}
.comment {
  display: grid;
  gap: 7px;
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  background: rgba(250, 246, 236, 0.62);
  padding: 10px;
}
.comment__meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
}
.comment__meta strong { color: var(--cedar); }
.comment__meta time {
  color: var(--ink-muted);
  font-family: var(--mono);
  font-size: 9px;
}
.comment p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 13px;
  line-height: 1.45;
}
.comment__tag {
  justify-self: start;
  border: 1px solid rgba(107, 125, 67, 0.28);
  border-radius: 999px;
  background: rgba(107, 125, 67, 0.1);
  color: #48582f;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.02em;
  max-width: 100%;
  overflow: hidden;
  padding: 4px 8px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.comment__tag.is-active {
  border-color: rgba(107, 125, 67, 0.62);
  background: rgba(107, 125, 67, 0.22);
  font-weight: 700;
}

.source-compare {
  border-top: 1px solid var(--line);
  padding-top: 12px;
}
.source-compare summary {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cedar);
  cursor: pointer;
}
.variant-note {
  display: grid;
  gap: 3px;
  margin: 10px 0 12px;
  padding: 10px 12px;
  border: 1px solid rgba(184, 135, 44, 0.24);
  border-radius: 8px;
  background: rgba(184, 135, 44, 0.1);
  color: var(--ink-soft);
  font-size: 13px;
}
.variant-note strong {
  color: var(--cedar);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.source-compare__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}
.source-compare article {
  min-width: 0;
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  background: var(--paper);
  padding: 12px;
}
.source-compare article strong {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--seraphim);
  margin-bottom: 8px;
}
.source-use {
  float: right;
  margin-top: -3px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper-warm);
  color: var(--cedar);
  padding: 3px 8px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.04em;
}
.source-use:hover { border-color: var(--line-strong); background: var(--paper); }
.source-compare pre {
  margin: 0;
  white-space: pre-wrap;
  font-family: var(--ui);
  font-size: 12px;
  line-height: 1.45;
  color: var(--ink-soft);
}
.empty-state {
  padding: 18px 16px;
  color: var(--ink-muted);
  font-size: 13px;
}

.toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--cedar);
  color: var(--paper);
  padding: 10px 18px;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  box-shadow: 0 20px 40px rgba(20, 17, 15, 0.2);
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms, transform 200ms;
  z-index: 100;
}
.toast.is-on {
  opacity: 1;
  transform: translateX(-50%) translateY(-8px);
}

@media (max-width: 1180px) {
  .topbar { grid-template-columns: 1fr; align-items: start; }
  .topbar__stats { justify-content: start; flex-wrap: wrap; }
  .cols,
  .cols.collapsed-right { grid-template-columns: 260px minmax(420px, 1fr); }
  .right { display: none; }
  .publish-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .tag-editor { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .publish-summary { grid-template-columns: 1fr; gap: 2px; }
}

@media (max-width: 820px) {
  .app { height: auto; min-height: 100vh; overflow: visible; }
  .cols,
  .cols.collapsed-right {
    display: block;
    height: auto;
    overflow: visible;
  }
  .list,
  .review,
  .right { display: block; border: 0; }
  .list__rows { max-height: 42vh; }
  .review__head,
  .actionbar {
    grid-template-columns: 1fr;
    padding: 14px 18px;
  }
  .review__body { padding: 18px 20px 56px; }
  .publish-guide,
  .publish-grid,
  .tag-editor,
  .meta-grid,
  .scripture { grid-template-columns: 1fr; gap: 6px; }
  .source-compare__grid { grid-template-columns: 1fr; }
  .prayer-title { font-size: 24px; }
  .prayer-body { font-size: 18px; }
  .actionbar__center { justify-content: start; }
  .actionbar__decisions { flex-wrap: wrap; }
}

/* ---- Publish-confidence score badge + strip (scoring/reorder pass) ---- */
.row__score {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 18px;
  padding: 0 5px;
  border-radius: 5px;
  font: 600 11px/1 var(--mono);
  color: #fff;
  background: var(--ink-muted);
  flex: none;
}
.row__score.is-hi { background: var(--olive); }
.row__score.is-med { background: var(--gold); }
.row__score.is-lo { background: var(--ink-faint); color: var(--ink); }
.row__score.is-rev { background: var(--crimson); }

.score-strip {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 10px 12px;
  margin-bottom: 10px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--ink-faint);
  border-radius: 8px;
  background: var(--paper-warm);
}
.score-strip.is-hi { border-left-color: var(--olive); }
.score-strip.is-med { border-left-color: var(--gold); }
.score-strip.is-lo { border-left-color: var(--ink-faint); }
.score-strip.is-rev { border-left-color: var(--crimson); }
.score-strip__num {
  font: 700 22px/1 var(--serif);
  color: var(--cedar);
  min-width: 34px;
  text-align: center;
}
.score-strip__main { display: flex; flex-direction: column; gap: 3px; }
.score-strip__main strong { font: 600 12px/1.2 var(--ui); text-transform: capitalize; }
.score-strip__why { font: 400 12px/1.35 var(--ui); color: var(--ink-soft); }
.score-strip__dims { font: 500 11px/1 var(--mono); color: var(--ink-muted); letter-spacing: 0.02em; }
.score-strip__img { margin-top: 2px; }
.score-strip__img summary { font: 500 11px/1 var(--ui); color: var(--seraphim); cursor: pointer; }
.score-strip__img p { font: 400 12px/1.4 var(--ui); color: var(--ink-soft); margin: 4px 0 0; }

/* ---- Publish-gate pass (fresh-eyes + direct publish + speed triage) ---- */
.row__dp {
  font-size: 11px;
  flex: none;
  filter: saturate(1.4);
}
.suggestion-chip.is-attached {
  border-color: rgba(107, 125, 67, 0.7);
  background: rgba(107, 125, 67, 0.32);
  color: #2e3a1d;
  font-weight: 700;
}
/* Multi-ref scripture preview: container stacks rows; each row keeps the ref|text grid. */
.scripture { display: grid; grid-template-columns: 1fr; gap: 0; }
.scripture__row {
  display: grid;
  grid-template-columns: minmax(140px, auto) 1fr;
  gap: 12px;
  padding: 6px 0;
  align-items: start;
}
.scripture__row + .scripture__row { border-top: 1px dashed var(--line-soft); }
.scripture__row.is-missing .scripture__ref { color: var(--crimson); }
