/**
 * forms.css
 * Form element styling — inputs, textareas, selects, labels, and error states.
 * Pure CSS with custom properties — no frameworks.
 */

.field-wrapper {
    margin-bottom: var(--spacing-lg);
}

.field-label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
}

.input-field {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-base);
    color: var(--color-text);
    background-color: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.input-field:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(107, 70, 193, 0.15);
}

.input-field::placeholder {
    color: var(--color-text-muted);
}

textarea.input-field {
    min-height: 120px;
    resize: vertical;
}

select.input-field {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234A5568' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--spacing-md) center;
    padding-right: var(--spacing-xl);
}

.field-error {
    display: block;
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-sm);
    color: var(--color-danger);
}

.input-field.has-error {
    border-color: var(--color-danger);
}

.input-field:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background-color: var(--color-bg-tertiary);
}
