/* =============================================================================
   stage-proposal.css — Stage 01 · Proposal page styles.
   Loaded after controls.css + pages.css. Page-specific composition only —
   primitives (.panel, .seg, .doc-chip, .stat-tile, .badge) come from controls.
   All colour via CSS custom properties. Square corners, no shadows.
   ========================================================================== */

.prop-stage { display: flex; flex-direction: column; gap: var(--space-6); }

/* ── source-document + stat row ─────────────────────────────────────────────── */

.prop-source-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--space-5);
  align-items: stretch;
}

.prop-source { height: 100%; }
.prop-source .panel__body { display: flex; flex-direction: column; gap: var(--space-3); }

.prop-source__summary { margin-top: var(--space-2); }

/* let the two StatTiles inside the row's StatBlock span the remaining columns */
.prop-source-row .stat-block {
  grid-column: 2 / 4;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  align-items: stretch;
}

/* ── tab bar ────────────────────────────────────────────────────────────────── */

.prop-tabbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
}

/* ── tab body ───────────────────────────────────────────────────────────────── */

.prop-tab { display: flex; flex-direction: column; gap: var(--space-6); }

.prop-block { display: flex; flex-direction: column; gap: var(--space-3); }

.prop-sub { display: flex; flex-direction: column; gap: var(--space-4); }
.prop-sub__title { font-size: var(--text-h3); }

/* ── grids ──────────────────────────────────────────────────────────────────── */

.prop-grid { display: grid; gap: var(--space-4); }
.prop-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.prop-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* ── prose ──────────────────────────────────────────────────────────────────── */

.prop-prose {
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: 1.55;
}
.prop-prose--lede { font-size: var(--text-body); }
.prop-prose--sm { font-size: var(--text-body-xs); }
.prop-prose--tight { margin-top: var(--space-1); }
.prop-prose--strong { color: var(--text-primary); }

/* ── rules ──────────────────────────────────────────────────────────────────── */

.prop-rule {
  height: 1px;
  background: var(--hairline);
  margin: var(--space-5) 0 var(--space-1);
}
/* Spacer only — the feathered divider was removed; the margin keeps the gap. */
.prop-rule--soft {
  background: transparent;
  margin: var(--space-5) 0 0;
}

/* ── labelled field ─────────────────────────────────────────────────────────── */

.prop-field {
  border-top: 1px solid var(--hairline);
  padding: var(--space-3) var(--space-4) var(--space-3) 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.prop-field__value {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--text-primary);
  line-height: 1.5;
}

/* ── deal overview ──────────────────────────────────────────────────────────── */

.prop-overview .panel__body { display: flex; flex-direction: column; }
.prop-overview__name { font-size: var(--text-h3); margin-bottom: var(--space-3); }

/* ── recommendation ─────────────────────────────────────────────────────────── */

.prop-rec .panel__body { display: flex; flex-direction: column; }
.prop-rec__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.prop-rec__title { font-size: var(--text-h3); color: var(--accent-emphasis); }

/* Stylized ordered list — a mono accent "01 02 03" marker. */
.prop-list {
  margin: var(--space-3) 0 0;
  padding-left: 0;
  list-style: none;
  counter-reset: prop-item;
  color: var(--text-secondary);
}
.prop-list li {
  counter-increment: prop-item;
  position: relative;
  padding-left: var(--space-7);
  margin-bottom: var(--space-3);
  line-height: 1.5;
}
.prop-list li::before {
  content: counter(prop-item, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 0.05em;
  font-family: var(--font-mono);
  font-size: var(--text-body-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--accent-emphasis);
}

/* ── early-flag / disclosure card heads ─────────────────────────────────────── */

.prop-flag__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.prop-disc__pillar { font-size: var(--text-h4); }

/* tag cluster on the right of a card head — category badge + severity etc. */
.prop-flag__tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* ── decisive factors grid ──────────────────────────────────────────────────── */

.prop-factors {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: var(--space-3);
}
.prop-factor {
  border-top: 1px solid var(--hairline);
  padding-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.prop-factor__head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.prop-factor__weight {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

/* ── diligence plan total ───────────────────────────────────────────────────── */

.prop-plan__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-3);
}
.prop-plan__total-value {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--text-primary);
}

/* ── two-column card splits ─────────────────────────────────────────────────── */

.prop-conflict__cols { margin-top: var(--space-3); }

.prop-confirm {
  margin-top: var(--space-4);
  background: color-mix(in srgb, var(--accent-emphasis) 6%, transparent);
  border: 1px solid var(--accent-emphasis);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* ── responsive ─────────────────────────────────────────────────────────────── */

@media (max-width: 960px) {
  .prop-source-row { grid-template-columns: 1fr; }
  .prop-source-row .stat-block { grid-column: 1; }
  .prop-grid--2,
  .prop-grid--3,
  .prop-factors { grid-template-columns: 1fr; }
}
