/* Domus Pura shared form components (opt-in) */

.dp-form-card {
  display: grid;
  gap: var(--dp-space-4);
  background: var(--dp-color-bg-surface);
  border: var(--dp-border-width) solid var(--dp-color-border-soft);
  border-radius: var(--dp-radius-lg);
  padding: var(--dp-space-5);
}

.dp-form-grid {
  display: grid;
  gap: var(--dp-space-4);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.dp-form-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dp-form-field {
  display: grid;
  gap: var(--dp-space-2);
  min-width: 0;
}

.dp-form-field__label {
  margin: 0;
  color: var(--dp-color-text-secondary);
  font-size: var(--dp-font-size-sm);
  font-weight: var(--dp-font-weight-medium);
}

.dp-form-field__control {
  width: 100%;
  min-width: 0;
}

.dp-form-field--wide {
  grid-column: 1 / -1;
}

.dp-filter-grid {
  display: grid;
  gap: var(--dp-space-3);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.dp-filter-grid--compact {
  gap: var(--dp-space-2);
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.dp-mode-switch {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--dp-space-2);
  padding: var(--dp-space-1);
  border: var(--dp-border-width) solid var(--dp-color-border-soft);
  border-radius: var(--dp-radius-md);
  background: var(--dp-color-bg-muted);
}

.dp-mode-switch__button {
  border: var(--dp-border-width) solid transparent;
  border-radius: var(--dp-radius-sm);
  background: transparent;
  color: var(--dp-color-text-secondary);
  padding: var(--dp-space-2) var(--dp-space-3);
  font-size: var(--dp-font-size-sm);
  font-weight: var(--dp-font-weight-medium);
}

.dp-mode-switch__button.is-active {
  background: var(--dp-color-accent);
  color: var(--dp-color-text-inverse);
}

.dp-form-field__control input,
.dp-form-field__control select,
.dp-form-field__control textarea,
input.dp-form-field__control,
select.dp-form-field__control,
textarea.dp-form-field__control {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  border: var(--dp-border-width) solid var(--dp-color-border-medium);
  border-radius: var(--dp-radius-md);
  padding: var(--dp-space-2) var(--dp-space-3);
  background: var(--dp-color-bg-surface);
  color: var(--dp-color-text-primary);
  font: inherit;
}

.dp-form-field__control textarea,
textarea.dp-form-field__control {
  min-height: 7rem;
  resize: vertical;
}

.dp-form-field__control input:focus-visible,
.dp-form-field__control select:focus-visible,
.dp-form-field__control textarea:focus-visible,
input.dp-form-field__control:focus-visible,
select.dp-form-field__control:focus-visible,
textarea.dp-form-field__control:focus-visible {
  outline: var(--dp-border-width) solid var(--dp-color-border-focus);
  outline-offset: var(--dp-focus-ring-offset);
  box-shadow: var(--dp-focus-ring);
}

.dp-form-field__control .dp-choice {
  display: inline-flex;
  align-items: center;
  gap: var(--dp-space-2);
  margin-right: var(--dp-space-4);
  color: var(--dp-color-text-secondary);
}

@media (max-width: 720px) {
  .dp-form-grid--two {
    grid-template-columns: minmax(0, 1fr);
  }
}
