/* Signed Waiver Storage — page-unique components (arch layout + tokens come from ronanrx.css) */

.lede-row { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 360px); gap: 28px; align-items: start; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 16px; }
.lede-row .note {
  border-left: 3px solid var(--amber);
  background: var(--amber-soft);
  color: var(--amber-ink);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 14px 16px;
  font: 500 0.8125rem/1.5 var(--font-sans);
}

/* horizontal 5-step flow */
.flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--surface);
  margin-top: 8px;
}
.step {
  position: relative;
  min-height: 184px;
  padding: 18px 16px;
  border-right: 1px solid var(--border-subtle);
}
.step:last-child { border-right: 0; }
.step::before {
  content: attr(data-n);
  display: grid;
  place-items: center;
  width: 28px; height: 28px;
  margin-bottom: 14px;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  font: 700 0.75rem/1 var(--font-sans);
}
.step h3 { font: 700 0.9375rem/1.25 var(--font-sans); margin-bottom: 8px; }
.step p { margin: 0 0 12px; color: var(--text-muted); font: 500 0.8125rem/1.45 var(--font-sans); }
.step .owner {
  display: inline-flex; align-items: center; min-height: 24px;
  border-radius: var(--radius-pill); padding: 2px 9px;
  background: var(--mint); color: var(--brand); border: 1px solid var(--sage);
  font: 700 0.6875rem/1 var(--font-sans);
}

/* bucket key scheme */
.bucket {
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  background: #11210f;
  color: #cfe6cf;
  padding: 20px 22px;
  overflow-x: auto;
}
.bucket pre { margin: 0; font: 500 0.8125rem/1.7 var(--font-mono); white-space: pre; }
.bucket .k { color: #fff; }
.bucket .c { color: #8fb89a; }

/* data contract table */
.contract { border-collapse: collapse; width: 100%; background: var(--surface); border: 1px solid var(--border-subtle); border-radius: var(--radius); overflow: hidden; font-family: var(--font-sans); }
.contract th, .contract td { padding: 12px 13px; border-bottom: 1px solid var(--border-subtle); text-align: left; vertical-align: top; font-size: 0.8125rem; }
.contract th { background: var(--surface-dark); color: #fff; font-size: 0.75rem; }
.contract tr:last-child td { border-bottom: 0; }
.contract code { font-size: 0.78rem; }

/* what-we-need + decisions */
.split { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.list-card { border: 1px solid var(--border-subtle); border-radius: var(--radius); background: var(--surface); overflow: hidden; }
.list-card h3 { margin: 0; padding: 14px 16px; background: var(--surface-alt); border-bottom: 1px solid var(--border-subtle); font: 800 0.875rem/1.2 var(--font-sans); }
.list-card ol, .list-card ul { margin: 0; padding: 12px 18px 16px 34px; color: var(--text-muted); font: 500 0.875rem/1.55 var(--font-sans); }
.list-card li { margin-bottom: 6px; }
.list-card .rec { color: var(--brand); font-weight: 700; }

@media (max-width: 980px) {
  .lede-row, .split { grid-template-columns: 1fr; }
  .flow { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .step { border-bottom: 1px solid var(--border-subtle); }
  .step:nth-child(2n) { border-right: 0; }
  .step:last-child { grid-column: 1 / -1; border-bottom: 0; }
}
@media (max-width: 620px) {
  .flow { grid-template-columns: 1fr; }
  .step, .step:nth-child(2n) { border-right: 0; border-bottom: 1px solid var(--border-subtle); }
  .step:last-child { border-bottom: 0; }
}
