/**
 * congregation.css — THE MALFUNCTIONING CRUCIBLE
 * Paper Redesign: Phase 2 Slice 12
 * Zero backdrop-filter. Parish bulletin / membership rolls aesthetic.
 * Spectral serif body + Michroma headers. Hard-offset shadows.
 */

/* =========================================================
   RESET & BODY
   ========================================================= */

body {
  margin: 0;
  padding: 0;
  background: transparent; /* cloud-background.js paints the background via .cloud-background */
  color: var(--ink-primary);
  font-family: 'Spectral', Georgia, 'Times New Roman', serif;
  /* min-height moved to .con-document to match Syndicate pattern (cloud visibility) */
}

/* =========================================================
   DOCUMENT WRAPPER
   ========================================================= */

.con-document {
  /* position: relative removed — matched to Syndicate's non-positioned .syndicate-page wrapper */
  /* (positioned elements participate differently in stacking order, blocking cloud background) */
  max-width: 960px;
  margin: 0 auto;
  padding: 48px 16px 80px; /* top padding to create visible cloud sky strip above cover */
  min-height: 100vh; /* moved from body to ensure full-height layout */
}

/* =========================================================
   COVER HEADER
   ========================================================= */

.con-cover {
  background: var(--paper-bg-aged);
  border: 1.5px solid var(--rule-primary);
  box-shadow: var(--shadow-deep);
  padding: 32px 36px 28px;
  margin-bottom: 0;
  border-bottom: 3px double var(--rule-primary);
}

.con-cover-eyebrow {
  font-family: 'Michroma', monospace;
  font-size: 0.65rem;
  color: var(--ink-meta);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.con-cover-org {
  font-family: 'Michroma', monospace;
  font-size: 0.72rem;
  color: var(--ink-accent);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.con-cover-title {
  font-family: 'Michroma', monospace;
  font-size: clamp(1.4rem, 3.5vw, 2.3rem);
  color: var(--ink-accent-dark);
  margin: 0 0 6px;
  line-height: 1.15;
  letter-spacing: 0.04em;
}

.con-cover-subtitle {
  font-family: 'Spectral', Georgia, serif;
  font-style: italic;
  font-size: 0.92rem;
  color: var(--ink-meta);
  margin: 0 0 24px;
  letter-spacing: 0.06em;
}

.con-cover-fields {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
}

.con-cover-fields td {
  padding: 6px 12px 6px 0;
  font-size: 0.8rem;
  vertical-align: top;
}

.con-cover-fields .field-label {
  font-family: 'Michroma', monospace;
  font-size: 0.65rem;
  color: var(--ink-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  width: 160px;
  padding-right: 8px;
}

.con-cover-fields .field-value {
  font-family: 'Spectral', Georgia, serif;
  color: var(--ink-primary);
  font-size: 0.85rem;
  padding-right: 24px;
}

/* =========================================================
   SECTIONS
   ========================================================= */

.con-section {
  margin-top: 0;
}

.con-section-header {
  background: var(--paper-bg-aged);
  border-left: 1.5px solid var(--rule-primary);
  border-right: 1.5px solid var(--rule-primary);
  border-top: 1.5px solid var(--rule-primary);
  border-bottom: 3px double var(--rule-primary);
  padding: 14px 28px;
  box-shadow: 3px 0 0 rgba(0,0,0,0.08);
}

.con-section-header h2 {
  font-family: 'Michroma', monospace;
  font-size: 0.8rem;
  color: var(--ink-accent-dark);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0;
}

.con-section-body {
  background: var(--paper-bg-alt);
  border-left: 1.5px solid var(--rule-primary);
  border-right: 1.5px solid var(--rule-primary);
  border-bottom: 1.5px solid var(--rule-primary);
  padding: 24px 28px;
  box-shadow: var(--shadow-md);
  color: var(--ink-primary);
  margin-bottom: 16px;
}

.con-section-intro {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.92rem;
  color: var(--ink-secondary);
  margin: 0 0 20px;
  line-height: 1.6;
}

/* =========================================================
   LOADING STATE
   ========================================================= */

.loading-state {
  padding: 24px;
  text-align: center;
  border: 1.5px dashed var(--rule-soft);
}

.loading-state p {
  font-family: 'Spectral', Georgia, serif;
  font-style: italic;
  color: var(--ink-meta);
  margin: 0;
}

/* =========================================================
   MEMBER GRID & CARDS
   ========================================================= */

.member-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.member-card {
  background: var(--paper-bg);
  border: 1.5px solid var(--rule-soft);
  border-top: 4px solid var(--member-color, var(--ink-accent));
  padding: 18px 18px 16px;
  box-shadow: var(--shadow-sm);
}

.member-header {
  margin-bottom: 12px;
}

.member-name {
  font-family: 'Spectral', Georgia, serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink-primary);
  margin: 0 0 4px;
}

.member-role {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.78rem;
  color: var(--ink-meta);
  font-style: italic;
  display: block;
  margin-bottom: 6px;
}

.persona-badge {
  font-family: 'Michroma', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  padding: 2px 8px;
  border: 1px solid var(--member-color, var(--ink-accent));
  color: var(--member-color, var(--ink-accent));
  text-transform: uppercase;
}

/* Vote weight */
.vote-weight {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.vote-label {
  font-family: 'Michroma', monospace;
  font-size: 0.6rem;
  color: var(--ink-meta);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.vote-pips {
  display: flex;
  gap: 4px;
}

.vote-pip {
  font-size: 0.85rem;
  line-height: 1;
}

.vote-pip.filled { color: var(--member-color, var(--ink-accent)); }
.vote-pip.empty { color: var(--rule-soft); opacity: 0.5; }

/* Personality */
.member-personality {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  line-height: 1.6;
  margin: 0 0 12px;
  font-style: italic;
  border-left: 2px solid var(--rule-soft);
  padding-left: 10px;
}

/* Values, quirks, conflicts */
.member-values,
.member-quirks,
.member-conflicts {
  margin-bottom: 10px;
}

.member-values h4,
.member-quirks h4,
.member-conflicts h4 {
  font-family: 'Michroma', monospace;
  font-size: 0.62rem;
  color: var(--ink-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 6px;
}

.member-conflicts h4 {
  color: var(--ink-stamp);
}

.member-values ul,
.member-quirks ul,
.member-conflicts ul {
  margin: 0;
  padding-left: 18px;
}

.member-values li,
.member-quirks li,
.member-conflicts li {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.82rem;
  color: var(--ink-secondary);
  line-height: 1.5;
  margin-bottom: 3px;
}

.member-conflicts li {
  color: var(--ink-stamp);
}

/* =========================================================
   FEEDBACK DASHBOARD
   ========================================================= */

.dashboard-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.dashboard-card {
  background: var(--paper-bg);
  border: 1.5px solid var(--rule-soft);
  border-top: 3px solid var(--ink-accent);
  padding: 20px;
  box-shadow: var(--shadow-sm);
}

.dashboard-card h3 {
  font-family: 'Michroma', monospace;
  font-size: 0.72rem;
  color: var(--ink-accent-dark);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0 0 14px;
}

/* Overall Rating Gauge */
.overall-rating-card {
  border-top-color: var(--ink-stamp);
}

.rating-gauge {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.gauge-display {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.gauge-value {
  font-family: 'Michroma', monospace;
  font-size: 2.4rem;
  color: var(--ink-accent-dark);
  line-height: 1;
}

.gauge-max {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.9rem;
  color: var(--ink-meta);
  font-style: italic;
}

.gauge-bar {
  height: 10px;
  background: var(--rule-soft);
  border: 1px solid var(--rule-primary);
  overflow: hidden;
}

.gauge-fill {
  height: 100%;
  width: 0%;
  background: var(--ink-accent);
  transition: width 0.8s ease;
}

.gauge-fill.excellent { background: var(--ink-green); }
.gauge-fill.good { background: var(--ink-accent); }
.gauge-fill.average { background: #b87400; }
.gauge-fill.poor { background: var(--ink-stamp); }

/* Metrics card */
.metrics-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.metric-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule-soft);
}

.metric-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.metric-label {
  font-family: 'Michroma', monospace;
  font-size: 0.6rem;
  color: var(--ink-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.metric-value {
  font-family: 'Michroma', monospace;
  font-size: 1rem;
  color: var(--ink-accent-dark);
}

/* Charts */
.charts-row {
  grid-template-columns: 1fr 1fr;
}

.chart-description {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.78rem;
  color: var(--ink-meta);
  font-style: italic;
  margin: -8px 0 12px;
}

.chart-container {
  /* Dark background so Chart.js white/grey labels remain legible */
  background: var(--paper-onyx);
  padding: 16px;
  max-height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rule-soft);
}

.chart-container canvas {
  max-height: 228px !important;
}

/* =========================================================
   FEEDBACK HISTORY
   ========================================================= */

.history-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.history-item {
  background: var(--paper-bg);
  border: 1.5px solid var(--rule-soft);
  padding: 12px 16px;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.history-item:hover {
  border-color: var(--ink-accent);
  box-shadow: var(--shadow-md);
}

.history-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
  gap: 8px;
  flex-wrap: wrap;
}

.history-service-id {
  font-family: 'Michroma', monospace;
  font-size: 0.7rem;
  color: var(--ink-accent);
  letter-spacing: 0.08em;
}

.history-timestamp {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.75rem;
  color: var(--ink-meta);
  font-style: italic;
}

.history-body {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.history-rating {
  display: flex;
  align-items: center;
  gap: 6px;
}

.rating-label {
  font-family: 'Michroma', monospace;
  font-size: 0.6rem;
  color: var(--ink-meta);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.rating-value {
  font-family: 'Michroma', monospace;
  font-size: 0.95rem;
  color: var(--ink-accent-dark);
}

.rating-value.excellent { color: var(--ink-green); }
.rating-value.good { color: var(--ink-accent); }
.rating-value.average { color: #b87400; }
.rating-value.poor { color: var(--ink-stamp); }

.history-signal { margin-left: auto; }

.signal-badge {
  font-family: 'Michroma', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  padding: 3px 10px;
}

.signal-badge.signal-better {
  background: var(--ink-green);
  color: white;
}

.signal-badge.signal-usual {
  background: var(--ink-accent);
  color: white;
}

.signal-badge.signal-worse {
  background: var(--ink-stamp);
  color: white;
}

/* Empty and error states in history */
.history-empty,
.empty-state {
  text-align: center;
  padding: 32px 20px;
  border: 1.5px dashed var(--rule-soft);
}

.empty-icon {
  font-size: 2rem;
  margin-bottom: 8px;
  opacity: 0.6;
}

.empty-title {
  font-family: 'Michroma', monospace;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  letter-spacing: 0.06em;
  margin: 0 0 6px;
}

.empty-hint {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-meta);
  font-style: italic;
  margin: 0 0 16px;
  line-height: 1.5;
}

.empty-schedule {
  text-align: left;
  display: inline-block;
  background: var(--paper-bg-aged);
  border: 1px solid var(--rule-soft);
  padding: 12px 16px;
  margin-top: 8px;
}

.empty-schedule h4 {
  font-family: 'Michroma', monospace;
  font-size: 0.65rem;
  color: var(--ink-meta);
  letter-spacing: 0.1em;
  margin: 0 0 6px;
  text-transform: uppercase;
}

.empty-schedule ul {
  margin: 0;
  padding-left: 16px;
}

.empty-schedule li {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.82rem;
  color: var(--ink-secondary);
  margin-bottom: 3px;
}

.error-state {
  text-align: center;
  padding: 24px;
  border: 1.5px solid var(--ink-stamp);
  background: rgba(184,51,42,0.04);
}

.error-state p {
  font-family: 'Spectral', Georgia, serif;
  color: var(--ink-stamp);
  margin: 0 0 4px;
}

.error-message {
  font-size: 0.82rem !important;
  color: var(--ink-meta) !important;
  font-style: italic;
}

/* Countdown */
.next-feedback-countdown {
  margin-top: 16px;
  display: inline-block;
}

.next-feedback-countdown h4 {
  font-family: 'Michroma', monospace;
  font-size: 0.65rem;
  color: var(--ink-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 4px;
}

.countdown-timer {
  background: var(--ink-accent-dark);
  padding: 8px 18px;
  display: inline-block;
  margin-bottom: 4px;
}

.countdown-value {
  font-family: 'Michroma', monospace;
  font-size: 1.2rem;
  color: #e8eeff;
  letter-spacing: 0.06em;
}

.countdown-label {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.78rem;
  color: var(--ink-meta);
  font-style: italic;
  margin: 0;
}

/* =========================================================
   HOW IT WORKS — PROCESS STEPS
   ========================================================= */

.process-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  margin-bottom: 20px;
}

.process-step {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--paper-bg);
  border: 1px solid var(--rule-soft);
  border-top: 3px solid var(--ink-accent);
  padding: 14px 16px;
  box-shadow: var(--shadow-sm);
}

.step-number {
  font-family: 'Michroma', monospace;
  font-size: 1.2rem;
  color: var(--paper-bg-alt);
  background: var(--ink-accent-dark);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  line-height: 1;
}

.step-content h3 {
  font-family: 'Michroma', monospace;
  font-size: 0.72rem;
  color: var(--ink-accent-dark);
  letter-spacing: 0.08em;
  margin: 0 0 6px;
}

.step-content p {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  line-height: 1.6;
  margin: 0;
}

/* Technical note */
.technical-note {
  background: var(--paper-bg-aged);
  border: 1px solid var(--rule-soft);
  border-left: 3px solid var(--ink-meta);
  padding: 16px 20px;
  box-shadow: var(--shadow-sm);
}

.technical-note h4 {
  font-family: 'Michroma', monospace;
  font-size: 0.65rem;
  color: var(--ink-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 8px;
}

.technical-note p {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  line-height: 1.6;
  margin: 0;
  font-style: italic;
}

/* =========================================================
   MODAL
   ========================================================= */

.feedback-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 24px 16px;
  overflow-y: auto;
}

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(16,14,12,0.85);
  z-index: -1;
}

.modal-content {
  background: var(--paper-bg-alt);
  border: 2px solid var(--rule-primary);
  border-top: 5px solid var(--ink-accent-dark);
  max-width: 800px;
  width: 100%;
  position: relative;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.35);
  z-index: 1;
}

.modal-close {
  position: absolute;
  top: 12px;
  right: 14px;
  background: none;
  border: 1.5px solid var(--rule-soft);
  font-size: 1.2rem;
  color: var(--ink-meta);
  cursor: pointer;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: monospace;
  line-height: 1;
  padding: 0;
}

.modal-close:hover {
  border-color: var(--ink-stamp);
  color: var(--ink-stamp);
}

.modal-body {
  padding: 24px 28px;
  max-height: 85vh;
  overflow-y: auto;
  color: var(--ink-primary);
}

/* Modal header */
.modal-header {
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 3px double var(--rule-primary);
}

.modal-header h2 {
  font-family: 'Michroma', monospace;
  font-size: 0.85rem;
  color: var(--ink-accent-dark);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0 0 8px;
}

.modal-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.modal-service-id {
  font-family: 'Michroma', monospace;
  font-size: 0.72rem;
  color: var(--ink-accent);
  letter-spacing: 0.08em;
}

.modal-divider {
  color: var(--rule-soft);
}

.modal-date {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.82rem;
  color: var(--ink-meta);
  font-style: italic;
}

.modal-rating {
  font-family: 'Michroma', monospace;
  font-size: 0.9rem;
  color: var(--ink-accent-dark);
}

.modal-rating.excellent { color: var(--ink-green); }
.modal-rating.good { color: var(--ink-accent); }
.modal-rating.average { color: #b87400; }
.modal-rating.poor { color: var(--ink-stamp); }

/* Modal member grid */
.modal-member-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  margin-bottom: 20px;
}

.modal-member-card {
  background: var(--paper-bg);
  border: 1.5px solid var(--rule-soft);
  border-top: 4px solid var(--member-color, var(--ink-accent));
  padding: 16px;
  box-shadow: var(--shadow-sm);
}

.modal-member-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
  gap: 8px;
}

.modal-member-name {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink-primary);
  margin: 0;
}

.modal-member-rating {
  font-family: 'Michroma', monospace;
  font-size: 0.9rem;
  color: var(--ink-accent-dark);
  white-space: nowrap;
}

.modal-member-rating.excellent { color: var(--ink-green); }
.modal-member-rating.good { color: var(--ink-accent); }
.modal-member-rating.average { color: #b87400; }
.modal-member-rating.poor { color: var(--ink-stamp); }

/* Dimensional bars */
.modal-dimension-bars {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}

.dimension-bar {
  display: grid;
  grid-template-columns: 36px 1fr 36px;
  align-items: center;
  gap: 8px;
}

.dimension-label {
  font-family: 'Michroma', monospace;
  font-size: 0.6rem;
  color: var(--ink-meta);
  letter-spacing: 0.06em;
  text-align: right;
}

.dimension-bar-track {
  height: 8px;
  background: var(--rule-soft);
  border: 1px solid var(--rule-soft);
  overflow: hidden;
}

.dimension-bar-fill {
  height: 100%;
  width: 0%;
  background: var(--member-color, var(--ink-accent));
  transition: width 0.5s ease;
}

.dimension-value {
  font-family: 'Michroma', monospace;
  font-size: 0.65rem;
  color: var(--ink-secondary);
  text-align: left;
}

/* Feedback lists */
.feedback-lists {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

.feedback-list ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.positive-item,
.concern-item,
.suggestion-item {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.82rem;
  line-height: 1.5;
  margin-bottom: 4px;
  padding-left: 4px;
}

.positive-item { color: var(--ink-green); }
.concern-item { color: #b87400; }
.suggestion-item { color: var(--ink-accent); }

/* Rationale */
.modal-member-rationale {
  border-top: 1px solid var(--rule-soft);
  padding-top: 10px;
}

.rationale-text {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  font-style: italic;
  line-height: 1.6;
  margin: 0;
}

/* Consensus section */
.consensus-section {
  background: var(--paper-bg-aged);
  border: 1.5px solid var(--rule-soft);
  border-top: 3px solid var(--ink-accent);
  padding: 18px 20px;
  box-shadow: var(--shadow-sm);
}

.consensus-section h3 {
  font-family: 'Michroma', monospace;
  font-size: 0.72rem;
  color: var(--ink-accent-dark);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0 0 14px;
}

.consensus-positive,
.consensus-negative {
  margin-bottom: 12px;
}

.consensus-positive h4 {
  font-family: 'Michroma', monospace;
  font-size: 0.62rem;
  color: var(--ink-green);
  letter-spacing: 0.1em;
  margin: 0 0 6px;
  text-transform: uppercase;
}

.consensus-negative h4 {
  font-family: 'Michroma', monospace;
  font-size: 0.62rem;
  color: #b87400;
  letter-spacing: 0.1em;
  margin: 0 0 6px;
  text-transform: uppercase;
}

.consensus-positive ul,
.consensus-negative ul {
  margin: 0;
  padding-left: 18px;
}

.consensus-positive li {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  line-height: 1.5;
  margin-bottom: 3px;
}

.consensus-negative li {
  font-family: 'Spectral', Georgia, serif;
  font-size: 0.85rem;
  color: var(--ink-secondary);
  line-height: 1.5;
  margin-bottom: 3px;
}

/* Modal loading/error */
.modal-loading,
.modal-error {
  text-align: center;
  padding: 32px;
}

.modal-loading p,
.modal-error p {
  font-family: 'Spectral', Georgia, serif;
  color: var(--ink-meta);
  font-style: italic;
  margin: 0 0 4px;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width: 768px) {
  .con-document {
    padding: 12px 10px 60px;
  }

  .con-cover {
    padding: 22px 18px 18px;
  }

  .con-section-header,
  .con-section-body {
    padding: 12px 16px;
  }

  .dashboard-row {
    grid-template-columns: 1fr;
  }

  .charts-row {
    grid-template-columns: 1fr;
  }

  .member-grid {
    grid-template-columns: 1fr;
  }

  .modal-member-grid {
    grid-template-columns: 1fr;
  }

  .process-steps {
    grid-template-columns: 1fr;
  }

  .con-cover-fields .field-label {
    width: 100px;
  }
}

@media (max-width: 480px) {
  .history-body {
    flex-direction: column;
    align-items: flex-start;
  }

  .history-signal {
    margin-left: 0;
  }
}
