diff --git a/docs/equalities_and_entailments.md b/docs/equalities_and_entailments.md
index 7ccae535d9d9aeb89442cd4e2e64638b2c518b33..6148b8595da85899ab1a7a18cadacd1f7073404a 100644
--- a/docs/equalities_and_entailments.md
+++ b/docs/equalities_and_entailments.md
@@ -51,17 +51,17 @@ Here, stdpp adds the following facilities:
   setoid, ofe, ordered arguments), there should be a `Params f n` instance. This
   instance forces Coq's setoid rewriting mechanism not to rewrite in the first
   `n` arguments of the function `f`. This significantly reduces backtracking
-  during `Proper` search and thus improves performance/avoids diverging failing
-  instance searches. These first arguments typically include type variables
+  during `Proper` search and thus improves performance/avoids failing instance
+  searches that diverge. These first arguments typically include type variables
   (`A : Type` or `B : A → Type`), type class parameters (`C A`), and Leibniz
-  arguments (`i : nat` or `i : Z`), so they cannot be rewritten or don't need
+  arguments (`i : nat` or `i : Z`), so they cannot be rewritten or do not need
   setoid rewriting.
   Examples:
   + For `cons : ∀ A, A → list A → list A` we have `Params (@cons) 1`,
     indicating that the type argument named `A` is not up to rewriting.
   + For `replicate : ∀ A, nat → A → list A` we have `Params (@replicate) 2`
     indicating that the type argument `A` is not up to rewriting and that the
-    `nat`-typed argument also doesn't show up as rewriteable in the `Proper`
+    `nat`-typed argument also does not show up as rewriteable in the `Proper`
     instance (because rewriting with `=` doesn't need such an instance).
   + For `lookup : ∀ {Lookup K A M}, K → M → option A` we have
     `Params (@lookup) 5`: there are 3 Type parameters, 1 type class, and a key
@@ -69,22 +69,21 @@ Here, stdpp adds the following facilities:
 - Consequenently, `Proper .. f` instances are always written in such a way
   that `f` is partially applied with the first `n` arguments from `Params f n`.
   Note that implicit arguments count here.
-  This means that `Proper` instances never start with `(=) ==>`.
+  Further note that `Proper` instances never start with `(=) ==>`.
   Examples:
-  + `Proper ((≡@{A}) ==> (≡@{list A}) ==> (≡@{list A})) cons`
-    (where `cons` is `@cons A`, matching the 1 in `Params`)
-  + `Proper ((≡@{A}) ==> (≡@{list A})) (replicate n)`
-    (where `replicate n` is `@replicate A n`)
-  + `Proper ((≡@{M}) ==> (≡@{option A})) (lookup k)`
-    (where `lookup k` is `@lookup K A M _ k`, so 5 parameters are fixed, matching the `Param`)
+  + `Proper ((≡@{A}) ==> (≡@{list A}) ==> (≡@{list A})) cons`,
+    where `cons` is `@cons A`, matching the 1 in `Params`.
+  + `Proper ((≡@{A}) ==> (≡@{list A})) (replicate n)`,
+    where `replicate n` is `@replicate A n`.
+  + `Proper ((≡@{M}) ==> (≡@{option A})) (lookup k)`,
+    where `lookup k` is `@lookup K A M _ k`, so 5 parameters are fixed, matching
+    the `Params` instance.
 - Lemmas about higher-order functions often need `Params` premises.
   These are also written using the convention above. Example:
-
-```
-Lemma set_fold_ind `{Set A C} {B} (P : B → C → Prop) (f : A → B → B) (b : B) :
-  (∀ x, Proper ((≡) ==> impl) (P x)) → ...
-```
-
+  ```coq
+  Lemma set_fold_ind `{FinSet A C} {B} (P : B → C → Prop) (f : A → B → B) (b : B) :
+    (∀ x, Proper ((≡) ==> impl) (P x)) → ...
+  ```
 - For premises involving predicates (such as `P` in `set_fold_ind` above), we
   always write the weakest `Proper`: that is, use `impl` instead of `iff` (and
   in Iris, write `(⊢)` instead of `(⊣⊢)`). For "simple" `P`s, there should be