:root {
  color-scheme: light;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font: 17px/1.65 Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a {
  color: inherit;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 3;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(0, auto);
  align-items: center;
  gap: 18px;
  min-height: 68px;
  padding: 10px clamp(18px, 4vw, 56px);
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--paper) 94%, white 6%);
  box-shadow: 0 10px 24px rgba(35, 31, 26, 0.06);
}

.brand {
  display: flex;
  flex-direction: column;
  min-width: 0;
  color: var(--ink);
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none;
}

.brand span {
  max-width: min(52vw, 620px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.brand small {
  max-width: min(58vw, 760px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-top: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 650;
}

.top-links {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 6px;
  justify-content: flex-end;
  max-width: min(760px, 58vw);
  min-width: 0;
  overflow-x: auto;
  padding: 2px 0;
  scrollbar-width: none;
}

.top-links::-webkit-scrollbar {
  display: none;
}

.top-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 12px;
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.top-links a:hover,
.top-links a.active {
  border-color: color-mix(in srgb, var(--accent) 24%, var(--line) 76%);
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.site-grid {
  display: grid;
  grid-template-columns: minmax(230px, 290px) minmax(0, 1fr);
  min-height: calc(100vh - 68px);
}

.sidebar {
  position: sticky;
  top: 68px;
  height: calc(100vh - 68px);
  overflow: auto;
  padding: 24px clamp(18px, 3vw, 32px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 78%, var(--paper) 22%);
}

.menu-section {
  margin: 0 0 28px;
}

.menu-section h2 {
  margin: 0 0 10px;
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.menu-section a {
  display: block;
  margin: 0 -10px 4px;
  padding: 7px 10px;
  border-radius: 6px;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
  text-decoration: none;
}

.menu-section a:hover,
.menu-section a.active {
  background: var(--surface);
  color: var(--accent);
}

.menu-section a.active {
  box-shadow: inset 3px 0 0 var(--accent);
  font-weight: 800;
}

.main-panel {
  min-width: 0;
}

.article {
  min-height: 100%;
}

.hero {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: clamp(310px, 44vw, 520px);
  padding: clamp(32px, 7vw, 86px);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.hero.has-image {
  min-height: clamp(380px, 54vw, 620px);
  color: white;
  background-position: center;
  background-size: cover;
}

.hero.has-image::before {
  position: absolute;
  inset: 0;
  content: "";
  background: rgba(20, 20, 18, 0.54);
}

.hero-copy {
  position: relative;
  z-index: 1;
  width: min(920px, 100%);
}

.eyebrow {
  margin: 0 0 12px;
  color: var(--accent-2);
  font-size: 13px;
  font-weight: 850;
  text-transform: uppercase;
}

.hero.has-image .eyebrow {
  color: color-mix(in srgb, white 78%, var(--accent-2) 22%);
}

h1 {
  margin: 0;
  max-width: 980px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(38px, 6vw, 82px);
  font-weight: 800;
  line-height: 1.02;
}

.lead {
  max-width: 820px;
  margin: 22px 0 0;
  color: var(--muted);
  font-size: clamp(18px, 2.3vw, 24px);
  line-height: 1.45;
}

.hero.has-image .lead {
  color: rgba(255, 255, 255, 0.88);
}

.archive-ribbon {
  margin: 0;
  padding: 22px clamp(20px, 7vw, 92px);
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 84%, var(--soft) 16%);
}

.archive-ribbon img {
  display: block;
  width: min(860px, 100%);
  max-height: 180px;
  object-fit: contain;
}

.content {
  width: min(100%, 1040px);
  padding: clamp(30px, 6vw, 78px) clamp(20px, 7vw, 92px) 92px;
}

.content > * {
  max-width: 800px;
}

.content h2 {
  margin: 42px 0 14px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.18;
}

.content p {
  margin: 0 0 18px;
}

.content ul,
.content ol {
  padding-left: 24px;
}

.content blockquote {
  margin: 34px 0;
  padding: 4px 0 4px 22px;
  border-left: 4px solid var(--accent);
  color: var(--muted);
}

.breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.breadcrumbs a {
  color: var(--accent);
  text-decoration: none;
}

.hero.has-image .breadcrumbs,
.hero.has-image .breadcrumbs a {
  color: rgba(255, 255, 255, 0.86);
}

.portal-actions,
.related-pages {
  max-width: 1040px;
  margin-top: 54px;
}

.portal-action-grid,
.related-grid,
.search-results,
.region-index {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.portal-action-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.related-grid,
.search-results {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.region-index {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 1040px;
}

.region-jump-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  max-width: 1040px;
  margin: 0 0 34px;
}

.region-jump-list a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.region-jump-list a:hover {
  background: var(--soft);
}

.region-jump-list span {
  color: var(--accent);
  font-size: 12px;
}

.hero-static-group {
  max-width: 1040px;
  margin: 0 0 42px;
}

.hero-static-group h2 {
  margin-bottom: 6px;
}

.hero-static-group > p {
  margin-bottom: 16px;
  color: var(--muted);
  font-weight: 800;
}

.portal-action-grid a,
.related-grid a,
.search-result,
.region-card {
  display: flex;
  min-height: 180px;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.portal-action-grid a:hover,
.related-grid a:hover,
.search-result:hover,
.region-card:hover {
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.portal-action-grid strong,
.related-grid strong,
.search-result strong,
.region-card strong {
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 22px;
  line-height: 1.16;
}

.portal-action-grid span,
.related-grid span,
.search-result span,
.region-card span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.portal-action-grid span {
  margin-top: 18px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 650;
  line-height: 1.42;
  text-transform: none;
}

.related-grid em,
.search-result em,
.region-card em {
  display: block;
  margin-top: 16px;
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
}

.region-map-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.region-map-grid .tracker-empty {
  grid-column: 1 / -1;
}

.region-map-card {
  display: grid;
  min-height: 320px;
  grid-template-rows: auto 1fr auto;
  gap: 18px;
  padding: clamp(20px, 3vw, 30px);
  background: var(--surface);
}

.region-map-card-expanded {
  grid-column: 1 / -1;
}

.region-map-card-head span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.region-map-card-head h2 {
  margin: 12px 0 10px;
}

.region-map-card-head p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 720;
  line-height: 1.45;
}

.region-hero-list {
  display: grid;
  align-content: start;
  gap: 8px;
}

.region-hero-list a,
.region-map-more {
  padding: 9px 10px;
  border: 1px solid var(--line);
  background: var(--soft);
  color: var(--ink);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.35;
  text-decoration: none;
}

.region-hero-list a:hover {
  background: color-mix(in srgb, var(--soft) 68%, var(--surface) 32%);
}

.region-map-more {
  color: var(--muted);
}

.region-map-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.region-map-actions a {
  display: inline-flex;
  min-height: 40px;
  align-items: center;
  padding: 0 12px;
  border: 1px solid var(--line);
  background: var(--ink);
  color: var(--paper);
  font-size: 13px;
  font-weight: 850;
  text-decoration: none;
}

.region-map-actions a:nth-child(n + 2) {
  background: var(--surface);
  color: var(--ink);
}

.alphabet-panel {
  max-width: 1040px;
}

.search-controls.alphabet-controls {
  grid-template-columns: minmax(260px, 1.25fr) minmax(150px, 0.45fr) minmax(220px, 0.75fr);
}

.alphabet-letter-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 0 0 18px;
}

.alphabet-letter-nav button {
  display: inline-flex;
  min-width: 48px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  cursor: pointer;
}

.alphabet-letter-nav button.active,
.alphabet-letter-nav button:hover:not(:disabled) {
  background: var(--ink);
  color: var(--paper);
}

.alphabet-letter-nav button:disabled {
  cursor: default;
  opacity: 0.36;
}

.alphabet-letter-nav strong {
  font-size: 18px;
  line-height: 1;
}

.alphabet-letter-nav span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.alphabet-letter-nav button.active span,
.alphabet-letter-nav button:hover:not(:disabled) span {
  color: color-mix(in srgb, var(--paper) 78%, transparent);
}

.alphabet-results {
  display: grid;
  gap: 18px;
}

.alphabet-group {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--line);
}

.alphabet-group-head {
  padding: 22px;
  background: var(--ink);
  color: var(--paper);
}

.alphabet-group-head span {
  color: color-mix(in srgb, var(--paper) 72%, transparent);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.alphabet-group-head h2 {
  margin: 14px 0 0;
  color: var(--paper);
  font-size: clamp(42px, 5vw, 64px);
}

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

.alphabet-hero {
  display: grid;
  min-height: 210px;
  align-content: start;
  gap: 12px;
  padding: 20px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.alphabet-hero:hover {
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.alphabet-hero span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.alphabet-hero strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 24px;
  line-height: 1.14;
}

.alphabet-hero em,
.alphabet-hero small {
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
}

.alphabet-hero small {
  display: block;
}

.memory-calendar-panel {
  max-width: 1040px;
}

.memory-calendar-controls {
  grid-template-columns: minmax(260px, 1.4fr) minmax(170px, 0.6fr) minmax(190px, 0.7fr);
}

.memory-calendar-toolbar {
  margin-top: 18px;
}

.memory-calendar-results {
  display: grid;
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.memory-date-card {
  display: grid;
  grid-template-columns: minmax(160px, 0.26fr) minmax(0, 1fr);
  min-height: 210px;
  background: var(--surface);
}

.memory-date-head {
  padding: clamp(18px, 3vw, 28px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 78%, var(--surface) 22%);
}

.memory-date-head span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.memory-date-head h2 {
  margin: 14px 0 0;
}

.memory-event-list {
  display: grid;
  gap: 1px;
  background: var(--line);
}

.memory-event {
  display: grid;
  gap: 10px;
  padding: clamp(18px, 3vw, 26px);
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.memory-event:hover {
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.memory-event span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.memory-event strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(21px, 2.4vw, 28px);
  line-height: 1.15;
}

.memory-event em {
  max-width: 740px;
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
}

.archive-audit-panel {
  max-width: 1040px;
}

.archive-audit-controls {
  grid-template-columns: minmax(260px, 1.35fr) minmax(190px, 0.7fr) minmax(180px, 0.65fr);
}

.archive-audit-toolbar {
  margin-top: 18px;
}

.archive-audit-results {
  display: grid;
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.archive-audit-card {
  display: grid;
  grid-template-columns: minmax(150px, 0.22fr) minmax(0, 1fr);
  background: var(--surface);
}

.archive-audit-score {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  padding: clamp(18px, 3vw, 28px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 76%, var(--surface) 24%);
}

.archive-audit-score strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(36px, 5vw, 54px);
  line-height: 1;
}

.archive-audit-score span,
.audit-region {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.archive-audit-main {
  display: grid;
  gap: 16px;
  padding: clamp(20px, 4vw, 34px);
}

.archive-audit-main h2 {
  margin: 0;
}

.archive-audit-main h2 a {
  text-decoration: none;
}

.archive-audit-main p {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
}

.audit-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.audit-metrics span {
  padding: 6px 9px;
  border: 1px solid var(--line);
  background: var(--soft);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.audit-issue-list {
  display: grid;
  gap: 1px;
  margin: 0;
  padding: 0;
  border: 1px solid var(--line);
  background: var(--line);
  list-style: none;
}

.audit-issue {
  display: grid;
  gap: 4px;
  padding: 13px 14px;
  background: var(--surface);
}

.audit-issue strong {
  font-size: 15px;
  line-height: 1.25;
}

.audit-issue span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.audit-high {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.audit-medium {
  box-shadow: inset 4px 0 0 var(--accent);
}

.audit-low {
  box-shadow: inset 4px 0 0 var(--line);
}

.archive-audit-actions {
  margin-top: 2px;
}

.archive-audit-priority .archive-audit-score {
  background: color-mix(in srgb, var(--accent-2) 14%, var(--surface) 86%);
}

.archive-audit-attention .archive-audit-score {
  background: color-mix(in srgb, var(--accent) 12%, var(--surface) 88%);
}

.memory-patrol-panel {
  max-width: 1040px;
}

.search-controls.memory-patrol-controls {
  grid-template-columns: minmax(260px, 1.35fr) minmax(190px, 0.7fr) minmax(170px, 0.62fr);
}

.memory-patrol-toolbar {
  margin-top: 18px;
}

.memory-patrol-results {
  display: grid;
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.memory-patrol-card {
  display: grid;
  grid-template-columns: minmax(155px, 0.22fr) minmax(0, 1fr);
  background: var(--surface);
}

.memory-patrol-aside {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  padding: clamp(18px, 3vw, 28px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 76%, var(--surface) 24%);
}

.memory-patrol-aside span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
  text-transform: uppercase;
}

.memory-patrol-aside strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(34px, 5vw, 52px);
  line-height: 1;
}

.memory-patrol-aside em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 760;
}

.memory-patrol-main {
  display: grid;
  gap: 16px;
  padding: clamp(20px, 4vw, 34px);
}

.memory-patrol-main h2 {
  margin: 0;
}

.memory-patrol-main h2 a {
  text-decoration: none;
}

.memory-patrol-main p {
  max-width: 780px;
  margin: 0;
  color: var(--muted);
}

.memory-patrol-action {
  max-width: 780px;
}

.memory-patrol-actions {
  margin-top: 2px;
}

.patrol-high .memory-patrol-aside {
  background: color-mix(in srgb, var(--accent-2) 15%, var(--surface) 85%);
}

.patrol-medium .memory-patrol-aside {
  background: color-mix(in srgb, var(--accent) 12%, var(--surface) 88%);
}

.quality-matrix-panel {
  max-width: 1040px;
}

.quality-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.quality-overview span {
  display: grid;
  min-height: 112px;
  align-content: center;
  gap: 8px;
  padding: 18px;
  background: color-mix(in srgb, var(--soft) 70%, var(--surface) 30%);
  color: var(--muted);
  font-size: 13px;
  font-weight: 820;
  text-transform: uppercase;
}

.quality-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1;
  text-transform: none;
}

.search-controls.quality-matrix-controls {
  grid-template-columns: minmax(260px, 1.35fr) minmax(190px, 0.7fr) minmax(180px, 0.65fr);
}

.quality-matrix-toolbar {
  margin-top: 18px;
}

.quality-matrix-results {
  display: grid;
  gap: 18px;
  max-width: 1040px;
}

.quality-region-card {
  display: grid;
  grid-template-columns: minmax(230px, 0.31fr) minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
}

.quality-region-head {
  display: grid;
  align-content: start;
  gap: 16px;
  padding: clamp(20px, 4vw, 34px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.quality-region-critical .quality-region-head {
  background: color-mix(in srgb, var(--accent-2) 14%, var(--surface) 86%);
}

.quality-region-attention .quality-region-head {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface) 90%);
}

.quality-region-head > span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.quality-region-head h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(27px, 3vw, 38px);
  line-height: 1.08;
}

.quality-scoreline {
  display: grid;
  gap: 4px;
}

.quality-scoreline strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6vw, 64px);
  line-height: 1;
}

.quality-scoreline em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 820;
}

.quality-region-metrics {
  display: grid;
  gap: 7px;
}

.quality-region-metrics span {
  padding: 7px 9px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.quality-region-body {
  display: grid;
  gap: 18px;
  padding: clamp(20px, 4vw, 34px);
}

.quality-issues {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.quality-issue {
  display: grid;
  gap: 5px;
  padding: 13px 14px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.quality-issue:hover {
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.quality-issue strong {
  font-size: 15px;
  line-height: 1.25;
}

.quality-issue span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 760;
}

.quality-high {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.quality-medium {
  box-shadow: inset 4px 0 0 var(--accent);
}

.quality-low {
  box-shadow: inset 4px 0 0 var(--line);
}

.quality-hero-list {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.quality-hero {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.quality-hero:hover {
  background: color-mix(in srgb, var(--soft) 54%, var(--surface) 46%);
}

.quality-hero span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.quality-hero strong {
  font-size: 18px;
  line-height: 1.25;
}

.quality-hero em {
  color: var(--muted);
  display: -webkit-box;
  overflow: hidden;
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.quality-actions {
  margin-top: 2px;
}

.storylines-panel {
  max-width: 1040px;
}

.search-controls.storyline-controls {
  grid-template-columns: minmax(260px, 1.35fr) minmax(210px, 0.8fr) minmax(190px, 0.72fr);
}

.storyline-toolbar {
  margin-top: 18px;
}

.storyline-results {
  display: grid;
  gap: 18px;
  max-width: 1040px;
}

.storyline-card {
  display: grid;
  grid-template-columns: minmax(230px, 0.34fr) minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
}

.storyline-head {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: clamp(20px, 4vw, 34px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 70%, var(--surface) 30%);
}

.storyline-head span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.storyline-head h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(25px, 3vw, 34px);
  line-height: 1.1;
}

.storyline-head p,
.storyline-head em {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.5;
}

.storyline-hero-list {
  display: grid;
  gap: 1px;
  background: var(--line);
}

.storyline-hero {
  display: grid;
  gap: 6px;
  padding: 18px 22px;
  background: var(--surface);
  text-decoration: none;
}

.storyline-hero:hover {
  background: color-mix(in srgb, var(--soft) 54%, var(--surface) 46%);
}

.storyline-hero span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.storyline-hero strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.storyline-hero em {
  color: var(--muted);
  display: -webkit-box;
  overflow: hidden;
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.storyline-actions {
  grid-column: 1 / -1;
  padding: 16px clamp(20px, 4vw, 34px);
  border-top: 1px solid var(--line);
  background: color-mix(in srgb, var(--paper) 68%, var(--surface) 32%);
}

.linking-center-panel {
  max-width: 1040px;
}

.linking-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.linking-overview span {
  display: grid;
  min-height: 112px;
  align-content: center;
  gap: 8px;
  padding: 18px;
  background: color-mix(in srgb, var(--soft) 70%, var(--surface) 30%);
  color: var(--muted);
  font-size: 13px;
  font-weight: 820;
  text-transform: uppercase;
}

.linking-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1;
  text-transform: none;
}

.search-controls.linking-controls {
  grid-template-columns: minmax(240px, 1.25fr) minmax(160px, 0.58fr) minmax(180px, 0.68fr) minmax(170px, 0.62fr);
}

.linking-toolbar {
  margin-top: 18px;
}

.linking-results {
  display: grid;
  gap: 18px;
  max-width: 1040px;
}

.linking-card {
  display: grid;
  grid-template-columns: minmax(245px, 0.34fr) minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
}

.linking-card-head {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: clamp(20px, 4vw, 34px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.linking-priority-high .linking-card-head {
  background: color-mix(in srgb, var(--accent-2) 14%, var(--surface) 86%);
}

.linking-priority-medium .linking-card-head {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface) 90%);
}

.linking-card-head > span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.linking-card-head h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(25px, 3vw, 36px);
  line-height: 1.08;
}

.linking-card-head h2 a {
  text-decoration: none;
}

.linking-card-head p {
  margin: 0;
  color: var(--muted);
  display: -webkit-box;
  overflow: hidden;
  font-size: 14px;
  line-height: 1.5;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.linking-scoreline {
  display: grid;
  gap: 5px;
}

.linking-scoreline strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6vw, 64px);
  line-height: 1;
}

.linking-scoreline em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 820;
}

.linking-metrics {
  display: grid;
  gap: 7px;
}

.linking-metrics span {
  padding: 7px 9px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.linking-card-body {
  display: grid;
  gap: 18px;
  padding: clamp(20px, 4vw, 34px);
}

.linking-opportunities {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.linking-opportunity {
  display: grid;
  gap: 7px;
  padding: 16px 18px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.linking-opportunity:hover {
  background: color-mix(in srgb, var(--soft) 54%, var(--surface) 46%);
}

.linking-opportunity span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 880;
  text-transform: uppercase;
}

.linking-opportunity strong {
  font-size: 17px;
  line-height: 1.25;
}

.linking-opportunity em {
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
}

.linking-region,
.linking-calendar,
.linking-theme,
.linking-quality,
.linking-support {
  box-shadow: inset 4px 0 0 var(--line);
}

.linking-region,
.linking-calendar {
  box-shadow: inset 4px 0 0 var(--accent);
}

.linking-theme,
.linking-quality {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.linking-peer-box {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.linking-peer-box > strong {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.linking-peer-box div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.linking-peer-box a,
.linking-peer-box span {
  padding: 8px 10px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.35;
  text-decoration: none;
}

.linking-peer-box span {
  color: var(--muted);
}

.linking-actions {
  margin-top: 2px;
}

.source-registry-panel {
  max-width: 1040px;
}

.source-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.source-overview span {
  display: grid;
  min-height: 112px;
  align-content: center;
  gap: 8px;
  padding: 18px;
  background: color-mix(in srgb, var(--soft) 70%, var(--surface) 30%);
  color: var(--muted);
  font-size: 13px;
  font-weight: 820;
  text-transform: uppercase;
}

.source-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1;
  text-transform: none;
}

.search-controls.source-controls {
  grid-template-columns: minmax(240px, 1.25fr) minmax(160px, 0.58fr) minmax(190px, 0.7fr) minmax(170px, 0.62fr);
}

.source-toolbar {
  margin-top: 18px;
}

.source-results {
  display: grid;
  gap: 18px;
  max-width: 1040px;
}

.source-card {
  display: grid;
  grid-template-columns: minmax(245px, 0.34fr) minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
}

.source-card-head {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: clamp(20px, 4vw, 34px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.source-status-critical .source-card-head {
  background: color-mix(in srgb, var(--accent-2) 15%, var(--surface) 85%);
}

.source-status-attention .source-card-head {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface) 90%);
}

.source-card-head > span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.source-card-head h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(25px, 3vw, 36px);
  line-height: 1.08;
}

.source-card-head h2 a {
  text-decoration: none;
}

.source-card-head p {
  margin: 0;
  color: var(--muted);
  display: -webkit-box;
  overflow: hidden;
  font-size: 14px;
  line-height: 1.5;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.source-scoreline {
  display: grid;
  gap: 5px;
}

.source-scoreline strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6vw, 64px);
  line-height: 1;
}

.source-scoreline em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 820;
}

.source-metrics {
  display: grid;
  gap: 7px;
}

.source-metrics span {
  padding: 7px 9px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.source-card-body {
  display: grid;
  gap: 18px;
  padding: clamp(20px, 4vw, 34px);
}

.source-types,
.source-facts,
.source-recommendations {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

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

.source-type,
.source-fact,
.source-recommendation {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  background: var(--surface);
  overflow-wrap: anywhere;
}

.source-type {
  box-shadow: inset 4px 0 0 var(--accent);
}

.source-official,
.source-award {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.source-missing {
  box-shadow: inset 4px 0 0 var(--accent-2);
  background: color-mix(in srgb, var(--accent-2) 10%, var(--surface) 90%);
}

.source-type strong,
.source-fact strong,
.source-recommendation strong {
  font-size: 15px;
  line-height: 1.25;
}

.source-type span,
.source-fact em,
.source-recommendation span {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 740;
  line-height: 1.45;
}

.source-facts {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.source-fact-ok {
  box-shadow: inset 4px 0 0 var(--accent);
}

.source-fact-gap {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.source-contexts {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.source-contexts blockquote,
.source-contexts p {
  margin: 0;
  padding: 0 0 0 14px;
  border-left: 3px solid var(--accent);
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.source-recommendations {
  margin: 0;
  padding: 0;
  list-style: none;
}

.source-rec-high {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.source-rec-medium {
  box-shadow: inset 4px 0 0 var(--accent);
}

.source-rec-low {
  box-shadow: inset 4px 0 0 var(--line);
}

.source-actions {
  margin-top: 2px;
}

.hero-passport-panel {
  max-width: 1040px;
}

.passport-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.passport-overview span {
  display: grid;
  min-height: 112px;
  align-content: center;
  gap: 8px;
  padding: 18px;
  background: color-mix(in srgb, var(--soft) 70%, var(--surface) 30%);
  color: var(--muted);
  font-size: 13px;
  font-weight: 820;
  text-transform: uppercase;
}

.passport-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1;
  text-transform: none;
}

.search-controls.passport-controls {
  grid-template-columns: minmax(240px, 1.22fr) minmax(160px, 0.58fr) minmax(190px, 0.72fr) minmax(170px, 0.62fr);
}

.passport-toolbar {
  margin-top: 18px;
}

.passport-results {
  display: grid;
  gap: 18px;
  max-width: 1040px;
}

.passport-card {
  display: grid;
  grid-template-columns: minmax(255px, 0.34fr) minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
}

.passport-card-head {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: clamp(20px, 4vw, 34px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.passport-status-critical .passport-card-head {
  background: color-mix(in srgb, var(--accent-2) 15%, var(--surface) 85%);
}

.passport-status-attention .passport-card-head {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface) 90%);
}

.passport-card-head > span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.passport-card-head h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(25px, 3vw, 36px);
  line-height: 1.08;
}

.passport-card-head h2 a {
  text-decoration: none;
}

.passport-card-head p {
  display: -webkit-box;
  overflow: hidden;
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.passport-scoreline {
  display: grid;
  gap: 5px;
}

.passport-scoreline strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6vw, 64px);
  line-height: 1;
}

.passport-scoreline em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 820;
}

.passport-meta {
  display: grid;
  gap: 7px;
}

.passport-meta span {
  padding: 7px 9px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.passport-card-body {
  display: grid;
  gap: 18px;
  padding: clamp(20px, 4vw, 34px);
}

.passport-facts,
.passport-service-links,
.passport-mini-grid {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.passport-facts {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.passport-fact,
.passport-service-links a,
.passport-event,
.passport-source,
.passport-linking,
.passport-peer,
.passport-task {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.passport-fact:hover,
.passport-service-links a:hover,
.passport-linking:hover,
.passport-peer:hover,
.passport-task:hover {
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.passport-fact-ok {
  box-shadow: inset 4px 0 0 var(--accent);
}

.passport-fact-gap,
.passport-source-gap {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.passport-fact strong,
.passport-service-links strong,
.passport-event strong,
.passport-source strong,
.passport-linking strong,
.passport-peer strong,
.passport-task strong {
  font-size: 15px;
  line-height: 1.25;
}

.passport-fact span,
.passport-service-links span,
.passport-event span,
.passport-source span,
.passport-linking span,
.passport-peer span,
.passport-task span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.35;
  text-transform: uppercase;
}

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

.passport-section {
  display: grid;
  align-content: start;
  gap: 10px;
}

.passport-section h3 {
  margin: 0;
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.passport-task-list {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.passport-task-high {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.passport-task-medium,
.passport-linking {
  box-shadow: inset 4px 0 0 var(--accent);
}

.passport-task-low,
.passport-event,
.passport-source,
.passport-peer {
  box-shadow: inset 4px 0 0 var(--line);
}

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

.passport-service-links {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.editorial-board-panel {
  max-width: 1040px;
}

.editorial-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.editorial-overview span {
  display: grid;
  min-height: 112px;
  align-content: center;
  gap: 8px;
  padding: 18px;
  background: color-mix(in srgb, var(--soft) 70%, var(--surface) 30%);
  color: var(--muted);
  font-size: 13px;
  font-weight: 820;
  text-transform: uppercase;
}

.editorial-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1;
  text-transform: none;
}

.search-controls.editorial-controls {
  grid-template-columns: minmax(240px, 1.25fr) minmax(160px, 0.58fr) minmax(170px, 0.62fr) minmax(180px, 0.68fr);
}

.editorial-toolbar {
  margin-top: 18px;
}

.editorial-results {
  display: grid;
  gap: 18px;
  max-width: 1040px;
}

.editorial-card {
  display: grid;
  grid-template-columns: minmax(245px, 0.34fr) minmax(0, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
}

.editorial-card-head {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: clamp(20px, 4vw, 34px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.editorial-status-critical .editorial-card-head {
  background: color-mix(in srgb, var(--accent-2) 15%, var(--surface) 85%);
}

.editorial-status-attention .editorial-card-head {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface) 90%);
}

.editorial-card-head > span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.editorial-card-head h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(25px, 3vw, 36px);
  line-height: 1.08;
}

.editorial-card-head h2 a {
  text-decoration: none;
}

.editorial-card-head p {
  margin: 0;
  color: var(--muted);
  display: -webkit-box;
  overflow: hidden;
  font-size: 14px;
  line-height: 1.5;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.editorial-scoreline {
  display: grid;
  gap: 5px;
}

.editorial-scoreline strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6vw, 64px);
  line-height: 1;
}

.editorial-scoreline em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 820;
}

.editorial-metrics {
  display: grid;
  gap: 7px;
}

.editorial-metrics span {
  padding: 7px 9px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.editorial-card-body {
  display: grid;
  gap: 18px;
  padding: clamp(20px, 4vw, 34px);
}

.editorial-issue-line {
  display: grid;
  gap: 7px;
  padding: 16px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 72%, var(--surface) 28%);
}

.editorial-issue-line strong {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.editorial-issue-line span {
  color: var(--muted);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.45;
}

.editorial-actions-list {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.editorial-action {
  display: grid;
  gap: 7px;
  padding: 16px 18px;
  background: var(--surface);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.editorial-action:hover {
  background: color-mix(in srgb, var(--soft) 54%, var(--surface) 46%);
}

.editorial-action span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 880;
  text-transform: uppercase;
}

.editorial-action strong {
  font-size: 16px;
  line-height: 1.3;
}

.editorial-high {
  box-shadow: inset 4px 0 0 var(--accent-2);
}

.editorial-medium {
  box-shadow: inset 4px 0 0 var(--accent);
}

.editorial-low {
  box-shadow: inset 4px 0 0 var(--line);
}

.editorial-actions {
  margin-top: 2px;
}

.data-hub-panel {
  max-width: 1040px;
}

.data-hub-controls {
  grid-template-columns: minmax(260px, 1.35fr) minmax(210px, 0.65fr);
}

.data-hub-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin: 0 0 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.data-hub-overview span {
  display: grid;
  gap: 6px;
  min-height: 92px;
  align-content: center;
  padding: 16px;
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.data-hub-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 25px;
  line-height: 1;
}

.data-hub-results {
  display: grid;
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.data-hub-card {
  display: grid;
  grid-template-columns: minmax(160px, 0.24fr) minmax(0, 1fr);
  min-height: 240px;
  background: var(--surface);
}

.data-hub-card-head {
  display: grid;
  align-content: center;
  gap: 10px;
  padding: clamp(18px, 3vw, 28px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 78%, var(--surface) 22%);
}

.data-hub-card-head span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.data-hub-card-head strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(38px, 5vw, 58px);
  line-height: 1;
}

.data-hub-card-head em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 780;
}

.data-hub-card-body {
  display: grid;
  gap: 16px;
  padding: clamp(20px, 3vw, 30px);
}

.data-hub-card-body h2 {
  margin: 0;
}

.data-hub-card-body p {
  margin: 0;
  color: var(--muted);
}

.data-hub-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.data-hub-fields span {
  padding: 6px 8px;
  border: 1px solid var(--line);
  background: var(--soft);
  color: var(--ink);
  font-size: 12px;
  font-weight: 820;
}

.data-hub-actions {
  margin-top: 2px;
}

.memory-route-panel {
  max-width: 1040px;
}

.memory-route-controls {
  grid-template-columns: minmax(260px, 1.25fr) minmax(190px, 0.55fr) minmax(190px, 0.55fr);
}

.memory-route-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin: 0 0 18px;
  border: 1px solid var(--line);
  background: var(--line);
}

.memory-route-overview span {
  display: grid;
  gap: 6px;
  min-height: 92px;
  align-content: center;
  padding: 16px;
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.memory-route-overview strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 25px;
  line-height: 1;
}

.memory-route-results {
  display: grid;
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.memory-route-card {
  display: grid;
  grid-template-columns: minmax(170px, 0.24fr) minmax(0, 1fr);
  min-height: 320px;
  background: var(--surface);
}

.memory-route-head {
  display: grid;
  align-content: center;
  gap: 10px;
  padding: clamp(18px, 3vw, 28px);
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft) 76%, var(--surface) 24%);
}

.memory-route-head span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.35;
  text-transform: uppercase;
}

.memory-route-head strong {
  color: var(--accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 5vw, 62px);
  line-height: 1;
}

.memory-route-head em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 780;
}

.memory-route-body {
  display: grid;
  gap: 16px;
  padding: clamp(20px, 3vw, 30px);
}

.memory-route-body h2 {
  margin: 0;
}

.memory-route-body h2 a {
  color: inherit;
  text-decoration: none;
}

.memory-route-body p {
  margin: 0;
  color: var(--muted);
}

.memory-route-evidence,
.memory-route-examples {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.memory-route-evidence span,
.memory-route-examples span {
  padding: 6px 8px;
  border: 1px solid var(--line);
  background: var(--soft);
  color: var(--ink);
  font-size: 12px;
  font-weight: 820;
}

.memory-route-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.memory-route-step {
  display: grid;
  min-height: 150px;
  align-content: start;
  gap: 9px;
  padding: 14px;
  background: color-mix(in srgb, var(--surface) 92%, var(--soft) 8%);
  color: var(--ink);
  overflow-wrap: anywhere;
  text-decoration: none;
}

.memory-route-step:hover {
  background: color-mix(in srgb, var(--surface) 74%, var(--soft) 26%);
}

.memory-route-step span {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--ink);
  color: var(--paper);
  font-size: 13px;
  font-weight: 850;
}

.memory-route-step strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  line-height: 1.16;
}

.memory-route-step em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  line-height: 1.4;
}

.memory-route-footer {
  display: grid;
  gap: 12px;
}

.memory-route-links {
  margin-top: 2px;
}

.portal-lead,
.tool-panel,
.portal-note {
  max-width: 960px;
  margin: 0 0 34px;
  padding: clamp(22px, 4vw, 38px);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 88%, white 12%);
}

.portal-lead p,
.portal-note p {
  max-width: 820px;
  font-size: 19px;
}

.search-controls {
  display: grid;
  grid-template-columns: minmax(260px, 1.5fr) minmax(220px, 0.75fr);
  gap: 14px;
  margin-bottom: 18px;
}

.search-controls.memory-calendar-controls {
  grid-template-columns: minmax(260px, 1.4fr) minmax(170px, 0.6fr) minmax(190px, 0.7fr);
}

.search-controls.archive-audit-controls {
  grid-template-columns: minmax(260px, 1.35fr) minmax(190px, 0.7fr) minmax(180px, 0.65fr);
}

.field {
  display: grid;
  gap: 7px;
}

.field label {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 0;
  background: var(--soft);
  color: var(--ink);
  font: inherit;
}

.field textarea {
  min-height: 122px;
  resize: vertical;
}

.search-stats,
.draft-status {
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
}

.memorial-form {
  display: grid;
  gap: 18px;
}

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

.form-grid .field-wide {
  grid-column: 1 / -1;
}

.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.checkbox-grid label {
  display: flex;
  min-height: 54px;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: var(--soft);
  color: var(--ink);
  font-size: 15px;
  font-weight: 720;
  text-transform: none;
}

.checkbox-grid input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.draft-output {
  min-height: 260px;
}

.draft-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.draft-actions button,
.draft-actions a {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border: 1px solid var(--line);
  background: var(--ink);
  color: var(--paper);
  font: inherit;
  font-weight: 850;
  text-decoration: none;
  cursor: pointer;
}

.draft-actions .secondary-action {
  background: var(--surface);
  color: var(--ink);
}

.tracker-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  max-width: 1040px;
  margin: 0 0 18px;
}

.tracker-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
}

.tracker-stats span {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
  font-weight: 780;
}

.tracker-stats strong {
  color: var(--accent);
  font-size: 18px;
  line-height: 1;
}

.tracker-list {
  display: grid;
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.tracker-item,
.tracker-empty {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  padding: clamp(18px, 3vw, 26px);
  background: var(--surface);
}

.tracker-empty {
  display: flex;
  min-height: 150px;
  flex-direction: column;
  justify-content: center;
}

.tracker-empty strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 24px;
}

.tracker-empty span {
  max-width: 620px;
  margin-top: 8px;
  color: var(--muted);
}

.tracker-item-main h2 {
  margin: 12px 0 8px;
  font-size: clamp(23px, 2.6vw, 32px);
}

.tracker-item-main p {
  margin-bottom: 12px;
  color: var(--ink);
  font-weight: 760;
}

.tracker-item-main em {
  display: block;
  max-width: 760px;
  margin-top: 12px;
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
}

.tracker-status {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 5px 9px;
  border: 1px solid var(--line);
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.tracker-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tracker-meta span {
  padding: 5px 8px;
  background: var(--soft);
  color: var(--muted);
  font-size: 13px;
  font-weight: 730;
}

.tracker-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 132px;
}

.tracker-actions button {
  min-height: 40px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  font-size: 14px;
  font-weight: 820;
  cursor: pointer;
}

.tracker-actions button:hover {
  background: var(--soft);
}

.tracker-overdue {
  box-shadow: inset 5px 0 0 var(--accent-2);
}

.tracker-overdue .tracker-status {
  border-color: var(--accent-2);
  background: color-mix(in srgb, var(--accent-2) 12%, var(--surface) 88%);
}

.tracker-soon {
  box-shadow: inset 5px 0 0 var(--accent);
}

.tracker-done {
  opacity: 0.78;
}

.site-disclaimer {
  width: min(100%, 1040px);
  margin: 0;
  padding: 28px clamp(20px, 7vw, 92px) 42px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  background: color-mix(in srgb, var(--soft) 70%, var(--paper) 30%);
  font-size: 13px;
  line-height: 1.55;
}

.site-disclaimer strong {
  display: block;
  margin-bottom: 6px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.site-disclaimer span {
  display: block;
  max-width: 900px;
}

.home-intro {
  max-width: 820px;
  margin-bottom: 42px;
  padding-left: 22px;
  border-left: 5px solid var(--accent);
}

.home-intro h2 {
  margin-top: 0;
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  max-width: 1040px;
  border: 1px solid var(--line);
  background: var(--line);
}

.feature-card {
  display: flex;
  min-height: 220px;
  flex-direction: column;
  justify-content: space-between;
  padding: 22px;
  background: var(--surface);
  color: var(--ink);
  text-decoration: none;
}

.feature-card:hover {
  background: color-mix(in srgb, var(--surface) 82%, var(--soft) 18%);
}

.feature-card span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.feature-card strong {
  display: block;
  margin: 18px 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 24px;
  line-height: 1.16;
}

.feature-card em {
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
}

body.visual-orthodox_service {
  background:
    linear-gradient(90deg, rgba(92, 82, 69, 0.14) 1px, transparent 1px) 0 0 / 44px 44px,
    var(--paper);
}

body.visual-orthodox_service .topbar {
  position: relative;
  align-items: center;
  border-bottom: 4px double color-mix(in srgb, var(--accent-2) 76%, white 24%);
  background: linear-gradient(115deg, var(--accent), color-mix(in srgb, var(--accent) 68%, black 32%));
  color: var(--soft);
}

body.visual-orthodox_service .brand,
body.visual-orthodox_service .top-links a {
  color: var(--soft);
}

body.visual-orthodox_service .brand small {
  color: color-mix(in srgb, var(--soft) 78%, var(--accent-2) 22%);
}

body.visual-orthodox_service .top-links a {
  border-color: color-mix(in srgb, var(--accent-2) 52%, white 48%);
  background: color-mix(in srgb, var(--accent) 78%, black 22%);
}

body.visual-orthodox_service .site-grid {
  display: block;
}

body.visual-orthodox_service .sidebar {
  position: sticky;
  top: 68px;
  z-index: 2;
  display: flex;
  height: auto;
  flex-wrap: wrap;
  gap: 12px 22px;
  justify-content: center;
  padding: 12px clamp(18px, 4vw, 56px);
  border-right: 0;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 86%, var(--soft) 14%);
}

body.visual-orthodox_service .menu-section {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}

body.visual-orthodox_service .menu-section h2 {
  margin: 0;
  color: var(--accent-2);
}

body.visual-orthodox_service .menu-section a {
  margin: 0;
  padding: 7px 11px;
  border: 1px solid transparent;
  border-radius: 0;
}

body.visual-orthodox_service .menu-section a:hover,
body.visual-orthodox_service .menu-section a.active {
  border-color: var(--line);
  background: var(--soft);
  box-shadow: none;
}

body.visual-orthodox_service .hero {
  width: min(1120px, calc(100% - 40px));
  min-height: auto;
  margin: clamp(26px, 5vw, 58px) auto 0;
  padding: clamp(38px, 7vw, 88px);
  border: 4px double var(--line);
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--accent-2) 14%, transparent) 0 38%, transparent 39%),
    linear-gradient(180deg, var(--soft), var(--surface));
  text-align: center;
}

body.visual-orthodox_service .hero-copy {
  margin: 0 auto;
}

body.visual-orthodox_service .hero-copy::before {
  display: block;
  width: 62px;
  height: 62px;
  margin: 0 auto 24px;
  content: "";
  background:
    linear-gradient(var(--accent), var(--accent)) center / 12px 100% no-repeat,
    linear-gradient(var(--accent), var(--accent)) center / 100% 12px no-repeat;
  opacity: 0.78;
}

body.visual-orthodox_service .eyebrow,
body.visual-orthodox_service h1,
body.visual-orthodox_service .lead {
  margin-right: auto;
  margin-left: auto;
}

body.visual-orthodox_service .eyebrow {
  max-width: 760px;
  color: var(--accent);
}

body.visual-orthodox_service h1 {
  max-width: 980px;
  font-size: clamp(40px, 5.6vw, 76px);
}

body.visual-orthodox_service .lead {
  max-width: 840px;
}

body.visual-orthodox_service .archive-ribbon,
body.visual-orthodox_service .content {
  width: min(100%, 1120px);
  margin-right: auto;
  margin-left: auto;
}

body.visual-orthodox_service .home-intro {
  position: relative;
  max-width: 920px;
  padding: clamp(26px, 4vw, 42px);
  border: 3px double var(--line);
  background: color-mix(in srgb, var(--surface) 88%, white 12%);
  box-shadow: 0 18px 42px rgba(44, 36, 27, 0.11);
}

body.visual-orthodox_service .home-intro::before {
  display: block;
  margin-bottom: 18px;
  color: var(--accent);
  content: "Служение / Память / Традиция";
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

body.visual-orthodox_service .feature-grid {
  max-width: 1120px;
  border: 0;
  background: transparent;
}

body.visual-orthodox_service .feature-card {
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 90%, white 10%);
}

body.visual-civic_institution .topbar,
body.visual-medical_clean .topbar,
body.visual-local_business .topbar {
  background: var(--surface);
}

body.visual-civic_institution .hero,
body.visual-medical_clean .hero,
body.visual-local_business .hero {
  min-height: clamp(280px, 34vw, 430px);
}

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

  .main-panel {
    order: 1;
  }

  .sidebar {
    position: static;
    order: 2;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    height: auto;
    gap: 0 24px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .hero {
    min-height: 340px;
  }

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

  .portal-action-grid,
  .related-grid,
  .region-index,
  .region-map-grid,
  .alphabet-hero-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.visual-orthodox_service .sidebar {
    position: static;
  }
}

@media (max-width: 680px) {
  .topbar {
    align-items: flex-start;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .brand span,
  .brand small {
    max-width: calc(100vw - 36px);
  }

  .top-links {
    width: 100%;
    max-width: 100%;
    justify-content: flex-start;
    padding-bottom: 4px;
  }

  .sidebar,
  .feature-grid,
  .portal-action-grid,
  .related-grid,
  .region-index,
  .region-map-grid,
  .alphabet-group,
  .alphabet-hero-grid,
  .search-controls,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .hero,
  .content {
    padding-inline: 20px;
  }

  .search-controls.memory-calendar-controls,
  .search-controls.alphabet-controls,
  .search-controls.archive-audit-controls,
  .search-controls.quality-matrix-controls,
  .search-controls.storyline-controls,
  .search-controls.source-controls,
  .search-controls.passport-controls,
  .search-controls.editorial-controls,
  .search-controls.data-hub-controls,
  .search-controls.memory-route-controls,
  .editorial-overview,
  .data-hub-overview,
  .data-hub-card,
  .memory-route-overview,
  .memory-route-card,
  .memory-route-steps,
  .passport-overview,
  .passport-card,
  .passport-facts,
  .passport-columns,
  .passport-mini-grid,
  .passport-service-links,
  .editorial-card,
  .memory-date-card,
  .archive-audit-card,
  .quality-overview,
  .quality-region-card,
  .quality-issues,
  .storyline-card,
  .source-overview,
  .source-card,
  .source-types,
  .source-facts {
    grid-template-columns: 1fr;
  }

  .memory-date-head,
  .alphabet-group-head,
  .archive-audit-score,
  .quality-region-head,
  .storyline-head,
  .source-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .passport-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .editorial-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .data-hub-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .memory-route-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  h1 {
    font-size: 38px;
  }
}


/* Site-specific generated design: Tactical_Dossier */
body.design-040dbb42 {
  --site-radius: 0px;
  --site-pad: clamp(30px, 5vw, 70px);
}
body.design-040dbb42 .menu-section a,
body.design-040dbb42 .feature-card,
body.design-040dbb42 .home-intro {
  border-radius: var(--site-radius);
}

.support-lead {
  max-width: 900px;
  margin: 0 0 34px;
  padding: clamp(22px, 4vw, 38px);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 86%, white 14%);
}

.support-lead p {
  max-width: 780px;
  font-size: 19px;
}

.support-navigator {
  border-color: color-mix(in srgb, var(--accent) 56%, var(--line) 44%);
  background: color-mix(in srgb, var(--surface) 76%, var(--soft) 24%);
}

.family-archive-panel {
  border-color: color-mix(in srgb, var(--accent-2) 48%, var(--line) 52%);
  background: color-mix(in srgb, var(--surface) 80%, var(--soft) 20%);
}

.family-archive-panel .draft-output {
  min-height: 340px;
}

.family-story-library {
  max-width: 1040px;
  margin: 0 0 42px;
}

.family-story-list .tracker-item {
  box-shadow: inset 5px 0 0 var(--accent);
}

.family-story-draft {
  box-shadow: inset 5px 0 0 var(--accent-2);
}

.family-story-item .tracker-actions {
  min-width: 150px;
}

.support-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  max-width: 1040px;
  margin: 0 0 42px;
  border: 1px solid var(--line);
  background: var(--line);
}

.support-card {
  min-height: 330px;
  padding: clamp(22px, 4vw, 34px);
  background: var(--surface);
}

.support-card-strong {
  background: color-mix(in srgb, var(--soft) 68%, var(--surface) 32%);
}

.support-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  margin-bottom: 18px;
  border: 1px solid var(--accent);
  color: var(--accent);
  font-size: 13px;
  font-weight: 900;
}

.support-card h2,
.support-steps h2,
.support-docs h2,
.support-official h2,
.support-faq h2,
.support-warning h2,
.support-cta h2 {
  margin-top: 0;
}

.support-card ul,
.support-steps ol {
  margin-bottom: 0;
}

.support-steps,
.support-docs,
.support-official,
.support-faq,
.support-warning,
.support-cta {
  max-width: 960px;
  margin: 0 0 34px;
  padding: clamp(22px, 4vw, 38px);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 90%, white 10%);
}

.support-steps ol {
  display: grid;
  gap: 14px;
  padding-left: 24px;
}

.support-checklist {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  max-width: 860px;
}

.support-checklist p {
  margin: 0;
  padding: 13px 14px;
  border: 1px solid var(--line);
  background: var(--soft);
  font-weight: 760;
}

.support-official {
  max-width: 1040px;
}

.support-faq details {
  border-top: 1px solid var(--line);
  padding: 16px 0;
}

.support-faq details:first-of-type {
  border-top: 0;
}

.support-faq summary {
  cursor: pointer;
  color: var(--ink);
  font-weight: 850;
}

.support-faq p {
  max-width: 820px;
  margin: 12px 0 0;
  color: var(--muted);
}

.official-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  margin-top: 24px;
  border: 1px solid var(--line);
  background: var(--line);
}

.official-links a {
  display: flex;
  min-height: 220px;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px;
  background: var(--surface);
  color: var(--ink);
  text-decoration: none;
}

.official-links a:hover {
  background: color-mix(in srgb, var(--surface) 78%, var(--soft) 22%);
}

.official-links span {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.official-links strong {
  display: block;
  margin: 16px 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 21px;
  line-height: 1.16;
}

.official-links em {
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  line-height: 1.45;
}

.support-warning {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--soft) 74%, var(--surface) 26%);
}

.support-cta {
  background: var(--ink);
  color: var(--paper);
}

.support-cta h2,
.support-cta a {
  color: var(--paper);
}

.support-cta a {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  padding: 0 18px;
  border: 1px solid color-mix(in srgb, var(--paper) 78%, transparent);
  text-decoration: none;
  font-weight: 850;
}

@media (max-width: 820px) {
  .support-grid,
  .official-links,
  .support-checklist,
  .checkbox-grid,
  .tracker-item,
  .alphabet-group,
  .alphabet-hero-grid,
  .alphabet-controls,
  .memory-patrol-controls,
  .memory-patrol-card,
  .quality-matrix-controls,
  .quality-overview,
  .quality-region-card,
  .quality-issues,
  .storyline-controls,
  .storyline-card,
  .linking-controls,
  .linking-overview,
  .linking-card,
  .source-controls,
  .source-overview,
  .source-card,
  .passport-controls,
  .passport-overview,
  .passport-card,
  .passport-facts,
  .passport-columns,
  .passport-mini-grid,
  .passport-service-links,
  .editorial-controls,
  .editorial-overview,
  .editorial-card,
  .memory-route-controls,
  .memory-route-overview,
  .memory-route-card,
  .memory-route-steps,
  .source-types,
  .source-facts,
  .memory-calendar-controls,
  .memory-date-card {
    grid-template-columns: 1fr;
  }

  .support-card {
    min-height: auto;
  }

  .memory-date-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .memory-patrol-aside {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .quality-region-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .storyline-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .linking-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .source-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .passport-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .editorial-card-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .memory-route-head {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .tracker-actions {
    min-width: 0;
  }
}
