MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  insubm Structured version   Visualization version   GIF version

Theorem insubm 18692
Description: The intersection of two submonoids is a submonoid. (Contributed by AV, 25-Feb-2024.)
Assertion
Ref Expression
insubm ((𝐴 ∈ (SubMnd‘𝑀) ∧ 𝐵 ∈ (SubMnd‘𝑀)) → (𝐴𝐵) ∈ (SubMnd‘𝑀))

Proof of Theorem insubm
Dummy variables 𝑎 𝑏 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 submrcl 18676 . . 3 (𝐴 ∈ (SubMnd‘𝑀) → 𝑀 ∈ Mnd)
2 ssinss1 4197 . . . . . . . . 9 (𝐴 ⊆ (Base‘𝑀) → (𝐴𝐵) ⊆ (Base‘𝑀))
323ad2ant1 1133 . . . . . . . 8 ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) → (𝐴𝐵) ⊆ (Base‘𝑀))
43ad2antrl 728 . . . . . . 7 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → (𝐴𝐵) ⊆ (Base‘𝑀))
5 elin 3919 . . . . . . . . . . . . 13 ((0g𝑀) ∈ (𝐴𝐵) ↔ ((0g𝑀) ∈ 𝐴 ∧ (0g𝑀) ∈ 𝐵))
65simplbi2com 502 . . . . . . . . . . . 12 ((0g𝑀) ∈ 𝐵 → ((0g𝑀) ∈ 𝐴 → (0g𝑀) ∈ (𝐴𝐵)))
763ad2ant2 1134 . . . . . . . . . . 11 ((𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵) → ((0g𝑀) ∈ 𝐴 → (0g𝑀) ∈ (𝐴𝐵)))
87com12 32 . . . . . . . . . 10 ((0g𝑀) ∈ 𝐴 → ((𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵) → (0g𝑀) ∈ (𝐴𝐵)))
983ad2ant2 1134 . . . . . . . . 9 ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) → ((𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵) → (0g𝑀) ∈ (𝐴𝐵)))
109imp 406 . . . . . . . 8 (((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵)) → (0g𝑀) ∈ (𝐴𝐵))
1110adantl 481 . . . . . . 7 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → (0g𝑀) ∈ (𝐴𝐵))
12 elin 3919 . . . . . . . . . 10 (𝑥 ∈ (𝐴𝐵) ↔ (𝑥𝐴𝑥𝐵))
13 elin 3919 . . . . . . . . . 10 (𝑦 ∈ (𝐴𝐵) ↔ (𝑦𝐴𝑦𝐵))
1412, 13anbi12i 628 . . . . . . . . 9 ((𝑥 ∈ (𝐴𝐵) ∧ 𝑦 ∈ (𝐴𝐵)) ↔ ((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)))
15 oveq1 7356 . . . . . . . . . . . . . . . . 17 (𝑎 = 𝑥 → (𝑎(+g𝑀)𝑏) = (𝑥(+g𝑀)𝑏))
1615eleq1d 2813 . . . . . . . . . . . . . . . 16 (𝑎 = 𝑥 → ((𝑎(+g𝑀)𝑏) ∈ 𝐴 ↔ (𝑥(+g𝑀)𝑏) ∈ 𝐴))
17 oveq2 7357 . . . . . . . . . . . . . . . . 17 (𝑏 = 𝑦 → (𝑥(+g𝑀)𝑏) = (𝑥(+g𝑀)𝑦))
1817eleq1d 2813 . . . . . . . . . . . . . . . 16 (𝑏 = 𝑦 → ((𝑥(+g𝑀)𝑏) ∈ 𝐴 ↔ (𝑥(+g𝑀)𝑦) ∈ 𝐴))
19 simpl 482 . . . . . . . . . . . . . . . . 17 ((𝑥𝐴𝑥𝐵) → 𝑥𝐴)
2019adantr 480 . . . . . . . . . . . . . . . 16 (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → 𝑥𝐴)
21 eqidd 2730 . . . . . . . . . . . . . . . 16 ((((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) ∧ 𝑎 = 𝑥) → 𝐴 = 𝐴)
22 simpl 482 . . . . . . . . . . . . . . . . 17 ((𝑦𝐴𝑦𝐵) → 𝑦𝐴)
2322adantl 481 . . . . . . . . . . . . . . . 16 (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → 𝑦𝐴)
2416, 18, 20, 21, 23rspc2vd 3899 . . . . . . . . . . . . . . 15 (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴 → (𝑥(+g𝑀)𝑦) ∈ 𝐴))
2524com12 32 . . . . . . . . . . . . . 14 (∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴 → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐴))
26253ad2ant3 1135 . . . . . . . . . . . . 13 ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐴))
2726ad2antrl 728 . . . . . . . . . . . 12 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐴))
2827imp 406 . . . . . . . . . . 11 (((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) ∧ ((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵))) → (𝑥(+g𝑀)𝑦) ∈ 𝐴)
2915eleq1d 2813 . . . . . . . . . . . . . . . . 17 (𝑎 = 𝑥 → ((𝑎(+g𝑀)𝑏) ∈ 𝐵 ↔ (𝑥(+g𝑀)𝑏) ∈ 𝐵))
3017eleq1d 2813 . . . . . . . . . . . . . . . . 17 (𝑏 = 𝑦 → ((𝑥(+g𝑀)𝑏) ∈ 𝐵 ↔ (𝑥(+g𝑀)𝑦) ∈ 𝐵))
31 simpr 484 . . . . . . . . . . . . . . . . . 18 ((𝑥𝐴𝑥𝐵) → 𝑥𝐵)
3231adantr 480 . . . . . . . . . . . . . . . . 17 (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → 𝑥𝐵)
33 eqidd 2730 . . . . . . . . . . . . . . . . 17 ((((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) ∧ 𝑎 = 𝑥) → 𝐵 = 𝐵)
34 simpr 484 . . . . . . . . . . . . . . . . . 18 ((𝑦𝐴𝑦𝐵) → 𝑦𝐵)
3534adantl 481 . . . . . . . . . . . . . . . . 17 (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → 𝑦𝐵)
3629, 30, 32, 33, 35rspc2vd 3899 . . . . . . . . . . . . . . . 16 (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵 → (𝑥(+g𝑀)𝑦) ∈ 𝐵))
3736com12 32 . . . . . . . . . . . . . . 15 (∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵 → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐵))
38373ad2ant3 1135 . . . . . . . . . . . . . 14 ((𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵) → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐵))
3938adantl 481 . . . . . . . . . . . . 13 (((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵)) → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐵))
4039adantl 481 . . . . . . . . . . . 12 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ 𝐵))
4140imp 406 . . . . . . . . . . 11 (((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) ∧ ((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵))) → (𝑥(+g𝑀)𝑦) ∈ 𝐵)
4228, 41elind 4151 . . . . . . . . . 10 (((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) ∧ ((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵))) → (𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵))
4342ex 412 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → (((𝑥𝐴𝑥𝐵) ∧ (𝑦𝐴𝑦𝐵)) → (𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵)))
4414, 43biimtrid 242 . . . . . . . 8 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → ((𝑥 ∈ (𝐴𝐵) ∧ 𝑦 ∈ (𝐴𝐵)) → (𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵)))
4544ralrimivv 3170 . . . . . . 7 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → ∀𝑥 ∈ (𝐴𝐵)∀𝑦 ∈ (𝐴𝐵)(𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵))
464, 11, 453jca 1128 . . . . . 6 ((𝑀 ∈ Mnd ∧ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))) → ((𝐴𝐵) ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ (𝐴𝐵) ∧ ∀𝑥 ∈ (𝐴𝐵)∀𝑦 ∈ (𝐴𝐵)(𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵)))
4746ex 412 . . . . 5 (𝑀 ∈ Mnd → (((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵)) → ((𝐴𝐵) ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ (𝐴𝐵) ∧ ∀𝑥 ∈ (𝐴𝐵)∀𝑦 ∈ (𝐴𝐵)(𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵))))
48 eqid 2729 . . . . . . 7 (Base‘𝑀) = (Base‘𝑀)
49 eqid 2729 . . . . . . 7 (0g𝑀) = (0g𝑀)
50 eqid 2729 . . . . . . 7 (+g𝑀) = (+g𝑀)
5148, 49, 50issubm 18677 . . . . . 6 (𝑀 ∈ Mnd → (𝐴 ∈ (SubMnd‘𝑀) ↔ (𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴)))
5248, 49, 50issubm 18677 . . . . . 6 (𝑀 ∈ Mnd → (𝐵 ∈ (SubMnd‘𝑀) ↔ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵)))
5351, 52anbi12d 632 . . . . 5 (𝑀 ∈ Mnd → ((𝐴 ∈ (SubMnd‘𝑀) ∧ 𝐵 ∈ (SubMnd‘𝑀)) ↔ ((𝐴 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐴 ∧ ∀𝑎𝐴𝑏𝐴 (𝑎(+g𝑀)𝑏) ∈ 𝐴) ∧ (𝐵 ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ 𝐵 ∧ ∀𝑎𝐵𝑏𝐵 (𝑎(+g𝑀)𝑏) ∈ 𝐵))))
5448, 49, 50issubm 18677 . . . . 5 (𝑀 ∈ Mnd → ((𝐴𝐵) ∈ (SubMnd‘𝑀) ↔ ((𝐴𝐵) ⊆ (Base‘𝑀) ∧ (0g𝑀) ∈ (𝐴𝐵) ∧ ∀𝑥 ∈ (𝐴𝐵)∀𝑦 ∈ (𝐴𝐵)(𝑥(+g𝑀)𝑦) ∈ (𝐴𝐵))))
5547, 53, 543imtr4d 294 . . . 4 (𝑀 ∈ Mnd → ((𝐴 ∈ (SubMnd‘𝑀) ∧ 𝐵 ∈ (SubMnd‘𝑀)) → (𝐴𝐵) ∈ (SubMnd‘𝑀)))
5655expd 415 . . 3 (𝑀 ∈ Mnd → (𝐴 ∈ (SubMnd‘𝑀) → (𝐵 ∈ (SubMnd‘𝑀) → (𝐴𝐵) ∈ (SubMnd‘𝑀))))
571, 56mpcom 38 . 2 (𝐴 ∈ (SubMnd‘𝑀) → (𝐵 ∈ (SubMnd‘𝑀) → (𝐴𝐵) ∈ (SubMnd‘𝑀)))
5857imp 406 1 ((𝐴 ∈ (SubMnd‘𝑀) ∧ 𝐵 ∈ (SubMnd‘𝑀)) → (𝐴𝐵) ∈ (SubMnd‘𝑀))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395  w3a 1086  wcel 2109  wral 3044  cin 3902  wss 3903  cfv 6482  (class class class)co 7349  Basecbs 17120  +gcplusg 17161  0gc0g 17343  Mndcmnd 18608  SubMndcsubmnd 18656
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2701  ax-sep 5235  ax-nul 5245  ax-pow 5304  ax-pr 5371
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2533  df-eu 2562  df-clab 2708  df-cleq 2721  df-clel 2803  df-nfc 2878  df-ne 2926  df-ral 3045  df-rex 3054  df-rab 3395  df-v 3438  df-sbc 3743  df-csb 3852  df-dif 3906  df-un 3908  df-in 3910  df-ss 3920  df-nul 4285  df-if 4477  df-pw 4553  df-sn 4578  df-pr 4580  df-op 4584  df-uni 4859  df-br 5093  df-opab 5155  df-mpt 5174  df-id 5514  df-xp 5625  df-rel 5626  df-cnv 5627  df-co 5628  df-dm 5629  df-rn 5630  df-res 5631  df-ima 5632  df-iota 6438  df-fun 6484  df-fv 6490  df-ov 7352  df-submnd 18658
This theorem is referenced by:  symgsubmefmnd  19277
  Copyright terms: Public domain W3C validator