.form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form__group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form__label {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text);
}

.form__label--required::after {
  content: " *";
  color: var(--color-danger);
}

.form__input,
.form__select,
.form__textarea {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius);
  font-size: var(--text-base);
  color: var(--color-text);
  background-color: var(--color-surface);
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}

.form__input:focus,
.form__select:focus,
.form__textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.15);
}

.form__input::placeholder,
.form__textarea::placeholder {
  color: var(--color-text-muted);
}

.form__textarea {
  resize: vertical;
  min-height: 88px;
}

.form__select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a39c8e' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  padding-right: var(--space-10);
}

.form__hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.form__error {
  font-size: var(--text-xs);
  color: var(--color-danger);
}

.form__actions {
  display: flex;
  gap: var(--space-3);
  padding-top: var(--space-2);
}

.field_with_errors .form__input,
.field_with_errors .form__select,
.field_with_errors .form__textarea {
  border-color: var(--color-danger);
}

#error_explanation {
  background-color: var(--color-danger-light);
  border: 1px solid var(--color-danger);
  border-radius: var(--radius);
  padding: var(--space-4);
  margin-bottom: var(--space-5);
  font-size: var(--text-sm);
  color: var(--color-danger);
}

#error_explanation h2 {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-2);
}

#error_explanation ul {
  list-style: disc inside;
}

/* Sectioned form card for complex forms */
.form-card {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.form-card__section {
  padding: var(--space-6);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-card__section:last-child {
  border-bottom: none;
}

.form-card__section-title {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.form-card__actions {
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-bg);
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: var(--space-3);
}

/* Two / three column form grid */
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4) var(--space-6);
}

.form-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.form-grid--full {
  grid-column: 1 / -1;
}

@media (max-width: 640px) {
  .form-grid,
  .form-grid--3 {
    grid-template-columns: 1fr;
  }
}

/* Calculated value readout — typography-driven, no input chrome */
.form__group--readout {
  justify-content: flex-end;
}

.commission-readout {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-2) 0 var(--space-1);
  border-top: 1px solid var(--color-success-light);
}

.commission-readout__label {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-muted);
}

.commission-readout__value {
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  font-weight: var(--font-medium);
  color: var(--color-success);
  letter-spacing: -0.01em;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: baseline;
}

.commission-readout__currency {
  font-size: var(--text-base);
  margin-right: 0.15em;
  opacity: 0.7;
}
