Você também pode usar diretamente IN junto com json_array_elements:
Recipe.where("'405' IN (SELECT json_array_elements(data->'category_ids')::text)")
E se sua coluna for uma coluna jsonb, você pode fazer da mesma forma:
Recipe.where("'405' IN (SELECT jsonb_array_elements(data->'category_ids')::text)")