.form-group {
    margin-bottom: var(--space-lg);
}

.form-group label {
    display: block;
    margin-bottom: var(--space-sm);
    font-size: var(--fs-xs);
    font-weight: 600;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: var(--text-secondary);
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    font-size: var(--fs-base);
    font-family: var(--font-sans);
    background-color: oklch(from var(--cream) calc(l + 0.03) c h);
    color: var(--text-primary);
    transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}

.form-group textarea {
    resize: vertical;
    min-height: 8rem;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--text-muted);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px oklch(from var(--sienna) l c h / 0.18);
}

.form-group input.error,
.form-group textarea.error,
.form-group select.error {
    border-color: var(--color-error);
}

.field-error {
    display: block;
    color: var(--color-error);
    font-size: var(--fs-sm);
    margin-top: var(--space-xs);
    min-height: 1.1rem;
}

/* Auth pages (login / register) */
.auth-card {
    max-width: 28rem;
    margin: var(--space-3xl) auto;
    background-color: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    padding: var(--space-xl);
    box-shadow: var(--shadow-md);
}

.auth-card h2 {
    margin-bottom: var(--space-lg);
    font-size: var(--fs-2xl);
}
