/* VS-009.U — Contextual Parameter Composer / 99% UX Patch */
/* Static. Contextual. No animation. No runtime/platform authority. */

.rv-tpos-composer.rv-u-composer {
  border: 1px solid var(--rv-border-subtle);
  background: #fff;
}

.rv-u-composer-summary {
  display: grid;
  gap: 6px;
  padding: 8px;
  background: #f8fafc;
  border: 1px solid var(--rv-border-subtle);
}

.rv-u-composer-summary strong {
  display: block;
  color: var(--rv-text-primary);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.rv-u-composer-summary span {
  display: block;
  color: var(--rv-text-secondary);
  font-size: 10.5px;
  line-height: 1.4;
}

.rv-u-composer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.rv-u-composer-grid.wide {
  grid-template-columns: 1fr;
}

.rv-u-field {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.rv-u-field label {
  color: var(--rv-text-muted);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .07em;
}

.rv-u-field input,
.rv-u-field select,
.rv-u-field textarea {
  width: 100%;
  min-height: 32px;
  border: 1px solid var(--rv-border-subtle);
  background: #f8fafc;
  padding: 6px 7px;
  color: var(--rv-text-primary);
  font-size: 11px;
}

.rv-u-field textarea {
  min-height: 72px;
  resize: vertical;
}

.rv-u-field small {
  display: block;
  color: var(--rv-text-secondary);
  font-size: 9.8px;
  line-height: 1.35;
}

.rv-u-zone {
  display: grid;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--rv-border-subtle);
}

.rv-u-zone-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.rv-u-zone-title strong {
  color: var(--rv-text-primary);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .065em;
}

.rv-u-zone-title span {
  color: var(--rv-text-muted);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: .055em;
}

.rv-u-impact-stack {
  display: grid;
  gap: 6px;
}

.rv-u-impact-row {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 7px;
  align-items: start;
  padding: 7px;
  border: 1px solid var(--rv-border-subtle);
  background: #f8fafc;
}

.rv-u-impact-row label {
  color: var(--rv-text-muted);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .07em;
}

.rv-u-impact-row div {
  color: var(--rv-text-primary);
  font-size: 10.5px;
  line-height: 1.35;
}

.rv-u-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.rv-u-pill {
  display: inline-flex;
  align-items: center;
  min-height: 19px;
  padding: 0 6px;
  border: 1px solid var(--rv-border-subtle);
  background: #fff;
  color: var(--rv-text-secondary);
  font-size: 8.5px;
  text-transform: uppercase;
  letter-spacing: .055em;
}

.rv-u-pill.ready { color: var(--rv-state-ready); border-color: rgba(47,125,89,.35); }
.rv-u-pill.warning { color: var(--rv-state-warning); border-color: rgba(168,110,0,.35); }
.rv-u-pill.blocked { color: var(--rv-state-blocked); border-color: rgba(124,31,31,.35); }
.rv-u-pill.future { color: var(--rv-state-future-plane); border-color: rgba(91,74,125,.35); }
.rv-u-pill.review { color: var(--rv-accent-primary); border-color: rgba(31,111,159,.35); }

.rv-u-guardrail {
  padding: 8px;
  border: 1px solid rgba(124,31,31,.35);
  background: rgba(124,31,31,.06);
  color: var(--rv-text-secondary);
  font-size: 10.5px;
  line-height: 1.45;
}

.rv-u-preview {
  padding: 8px;
  border: 1px solid rgba(31,111,159,.25);
  background: rgba(31,111,159,.05);
  color: var(--rv-text-secondary);
  font-size: 10.5px;
  line-height: 1.45;
}

.rv-u-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.rv-u-actions button {
  min-height: 30px;
  border: 1px solid var(--rv-border-subtle);
  background: #fff;
  color: var(--rv-text-secondary);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .055em;
  cursor: pointer;
}

.rv-u-actions button.primary {
  background: #162331;
  color: #fff;
}

.rv-u-actions button[disabled] {
  opacity: .55;
  cursor: not-allowed;
}

.rv-u-context-label {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 0 6px;
  border: 1px solid rgba(31,111,159,.25);
  background: rgba(31,111,159,.05);
  color: var(--rv-accent-primary);
  font-size: 8.5px;
  text-transform: uppercase;
  letter-spacing: .055em;
}

@media (max-width: 720px), (hover: none) and (pointer: coarse) {
  .rv-u-composer-grid {
    grid-template-columns: 1fr;
  }

  .rv-u-actions {
    grid-template-columns: 1fr;
  }

  .rv-u-impact-row {
    grid-template-columns: 1fr;
  }
}
