diff --git a/Gemfile.lock b/Gemfile.lock
index 6ba72d1d77ae45ea6fc70e6265a5139ad24d1256..2083508780a4927fb0d1318c318578e1196eac57 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -88,7 +88,7 @@ GEM
     autoprefixer-rails (10.4.7.0)
       execjs (~> 2)
     aws-eventstream (1.2.0)
-    aws-partitions (1.595.0)
+    aws-partitions (1.597.0)
     aws-sdk-core (3.131.1)
       aws-eventstream (~> 1, >= 1.0.2)
       aws-partitions (~> 1, >= 1.525.0)
@@ -133,7 +133,7 @@ GEM
     childprocess (4.1.0)
     cocoon (1.2.15)
     concurrent-ruby (1.1.10)
-    countries (5.0.1)
+    countries (5.0.2)
       i18n_data (~> 0.16.0)
       sixarm_ruby_unaccent (~> 1.1)
     country_select (7.0.0)
@@ -142,9 +142,9 @@ GEM
     crack (0.4.5)
       rexml
     crass (1.0.6)
-    curation (1.9)
+    curation (1.10)
       htmlentities
-      metainspector
+      metainspector (~> 5.12)
       nokogiri
     delayed_job (4.1.10)
       activesupport (>= 3.0, < 8.0)
@@ -164,6 +164,8 @@ GEM
       warden (~> 1.2.3)
     devise-i18n (1.10.2)
       devise (>= 4.8.0)
+    domain_name (0.5.20190701)
+      unf (>= 0.0.5, < 1.0.0)
     encryptor (3.0.0)
     enum_help (0.0.19)
       activesupport (>= 3.0.0)
@@ -174,10 +176,39 @@ GEM
     faceted_search (3.5.13)
       font-awesome-sass
       rails (>= 5.2.0, < 7)
-    faraday (2.3.0)
-      faraday-net_http (~> 2.0)
+    faraday (1.10.0)
+      faraday-em_http (~> 1.0)
+      faraday-em_synchrony (~> 1.0)
+      faraday-excon (~> 1.1)
+      faraday-httpclient (~> 1.0)
+      faraday-multipart (~> 1.0)
+      faraday-net_http (~> 1.0)
+      faraday-net_http_persistent (~> 1.0)
+      faraday-patron (~> 1.0)
+      faraday-rack (~> 1.0)
+      faraday-retry (~> 1.0)
       ruby2_keywords (>= 0.0.4)
-    faraday-net_http (2.0.3)
+    faraday-cookie_jar (0.0.7)
+      faraday (>= 0.8.0)
+      http-cookie (~> 1.0.0)
+    faraday-em_http (1.0.0)
+    faraday-em_synchrony (1.0.0)
+    faraday-encoding (0.0.5)
+      faraday
+    faraday-excon (1.1.0)
+    faraday-http-cache (2.4.0)
+      faraday (>= 0.8)
+    faraday-httpclient (1.0.1)
+    faraday-multipart (1.0.4)
+      multipart-post (~> 2)
+    faraday-net_http (1.0.1)
+    faraday-net_http_persistent (1.2.0)
+    faraday-patron (1.0.0)
+    faraday-rack (1.0.0)
+    faraday-retry (1.0.3)
+    faraday_middleware (1.2.0)
+      faraday (~> 1.0)
+    fastimage (2.2.6)
     ffi (1.15.5)
     figaro (1.2.0)
       thor (>= 0.14.0, < 2)
@@ -199,10 +230,9 @@ GEM
     hash_dot (2.5.0)
     hashdiff (1.0.1)
     hashie (5.0.0)
-    hoe (3.23.1)
-      rake (>= 0.8, < 15.0)
-    hpricot (0.8.6)
     htmlentities (4.3.4)
+    http-cookie (1.0.5)
+      domain_name (~> 0.5)
     httparty (0.20.0)
       mime-types (~> 3.0)
       multi_xml (>= 0.5.2)
@@ -224,7 +254,7 @@ GEM
     js_cookie_rails (2.2.0)
       railties (>= 3.1)
     json (2.6.2)
-    jwt (2.3.0)
+    jwt (2.4.1)
     kamifusen (1.11.2)
       image_processing
       rails
@@ -250,25 +280,36 @@ GEM
       mini_mime (>= 0.1.1)
     marcel (1.0.2)
     matrix (0.4.2)
-    metainspector (1.0.2)
-      hoe (>= 1.3.0)
-      hpricot (> 0.0.0)
+    metainspector (5.12.1)
+      addressable (~> 2.7)
+      faraday (>= 1.4, < 3.0)
+      faraday-cookie_jar (~> 0.0)
+      faraday-encoding (~> 0.0)
+      faraday-http-cache (~> 2.2)
+      faraday_middleware (~> 1.0)
+      fastimage (~> 2.2)
+      nesty (~> 1.0)
+      nokogiri (~> 1.11)
     method_source (1.0.0)
     mime-types (3.4.1)
       mime-types-data (~> 3.2015)
     mime-types-data (3.2022.0105)
     mini_magick (4.11.0)
     mini_mime (1.1.2)
-    mini_portile2 (2.8.0)
     minitest (5.15.0)
     msgpack (1.5.2)
     multi_json (1.15.0)
     multi_xml (0.6.0)
+    multipart-post (2.2.0)
     mustermann (1.1.1)
       ruby2_keywords (~> 0.0.1)
+    nesty (1.0.2)
     nio4r (2.5.8)
-    nokogiri (1.13.6)
-      mini_portile2 (~> 2.8.0)
+    nokogiri (1.13.6-arm64-darwin)
+      racc (~> 1.4)
+    nokogiri (1.13.6-x86_64-darwin)
+      racc (~> 1.4)
+    nokogiri (1.13.6-x86_64-linux)
       racc (~> 1.4)
     oauth2 (1.4.9)
       faraday (>= 0.17.3, < 3.0)
@@ -276,7 +317,7 @@ GEM
       multi_json (~> 1.3)
       multi_xml (~> 0.5)
       rack (>= 1.2, < 3)
-    octokit (4.23.0)
+    octokit (4.24.0)
       faraday (>= 1, < 3)
       sawyer (~> 0.9)
     omniauth (2.1.0)
@@ -364,7 +405,7 @@ GEM
       sprockets (> 3.0)
       sprockets-rails
       tilt
-    sawyer (0.9.1)
+    sawyer (0.9.2)
       addressable (>= 2.3.5)
       faraday (>= 0.17.3, < 3)
     selenium-webdriver (4.2.1)
@@ -412,6 +453,9 @@ GEM
       ethon (>= 0.9.0)
     tzinfo (2.0.4)
       concurrent-ruby (~> 1.0)
+    unf (0.1.4)
+      unf_ext
+    unf_ext (0.0.8.2)
     unicode-display_width (2.1.0)
     unicode_utils (1.4.0)
     unsplash (2.1.0)
@@ -442,7 +486,9 @@ GEM
     zeitwerk (2.5.4)
 
 PLATFORMS
-  ruby
+  arm64-darwin-21
+  x86_64-darwin-21
+  x86_64-linux
 
 DEPENDENCIES
   angularjs-rails
@@ -509,4 +555,4 @@ RUBY VERSION
    ruby 2.7.5p203
 
 BUNDLED WITH
-   2.3.12
+   2.3.15
diff --git a/app/controllers/admin/communication/websites/posts/curations_controller.rb b/app/controllers/admin/communication/websites/posts/curations_controller.rb
index f659841f1e18d50b83ee14baf7ed0ce1c966c68d..04f417d94568e73445600d1a018dcf11f18fb9af 100644
--- a/app/controllers/admin/communication/websites/posts/curations_controller.rb
+++ b/app/controllers/admin/communication/websites/posts/curations_controller.rb
@@ -6,7 +6,8 @@ class Admin::Communication::Websites::Posts::CurationsController < Admin::Commun
   def create
     @curator = Curator.new @website, current_user, curation_params[:url]
     if @curator.valid?
-      redirect_to [:edit, :admin, @curator.post], notice: t('admin.successfully_created_html', model: @curator.post.to_s)
+      redirect_to [:edit, :admin, @curator.post],
+                  notice: t('admin.successfully_created_html', model: @curator.post.to_s)
     else
       breadcrumb
       flash[:alert] = "Erreur lors de la curation"
diff --git a/app/controllers/admin/users_controller.rb b/app/controllers/admin/users_controller.rb
index ddb1f9b14892952864005cc7807c0495be6273cc..9c856b761d7091cca3cde116bca33238a34f4a60 100644
--- a/app/controllers/admin/users_controller.rb
+++ b/app/controllers/admin/users_controller.rb
@@ -1,6 +1,7 @@
 class Admin::UsersController < Admin::ApplicationController
   load_and_authorize_resource through: :current_university
 
+  has_scope :for_language
   has_scope :for_role
   has_scope :for_search_term
 
diff --git a/app/models/communication/website/page/with_kind.rb b/app/models/communication/website/page/with_kind.rb
index 22644ce295943ec6ef4268a7ac75c6e47ad6d624..a1b0ea544157ca08e7836300114f825194a96578 100644
--- a/app/models/communication/website/page/with_kind.rb
+++ b/app/models/communication/website/page/with_kind.rb
@@ -13,6 +13,7 @@ module Communication::Website::Page::WithKind
       legal_terms: 80,
         sitemap: 81,
         privacy_policy: 82,
+        accessibility: 83,
       organizations: 90,
       persons: 100,
         administrators: 110,
diff --git a/app/models/communication/website/with_dependencies.rb b/app/models/communication/website/with_dependencies.rb
index 0303b6685b9b6902d0aa4cb7ea1d877b87937c1c..c9939dc2b03d01632982ac5b83df91bb3125443c 100644
--- a/app/models/communication/website/with_dependencies.rb
+++ b/app/models/communication/website/with_dependencies.rb
@@ -118,6 +118,10 @@ module Communication::Website::WithDependencies
     true
   end
 
+  def has_accessibility?
+    true
+  end
+
   def has_communication_posts?
     posts.published.any?
   end
diff --git a/app/models/communication/website/with_special_pages.rb b/app/models/communication/website/with_special_pages.rb
index 56d01100c365961cf40de6c4fd6bdeb300bcde0b..4e5d446ca103181f78b3c93998b5fc3c32dad9b9 100644
--- a/app/models/communication/website/with_special_pages.rb
+++ b/app/models/communication/website/with_special_pages.rb
@@ -13,7 +13,7 @@ module Communication::Website::WithSpecialPages
     def create_missing_special_pages
       homepage = create_special_page('home')
       # first level pages with test
-      ['legal_terms', 'sitemap', 'privacy_policy', 'communication_posts', 'education_programs', 'education_diplomas', 'research_articles', 'research_volumes', 'organizations'].each do |kind|
+      ['legal_terms', 'sitemap', 'privacy_policy', 'accessibility', 'communication_posts', 'education_programs', 'education_diplomas', 'research_articles', 'research_volumes', 'organizations'].each do |kind|
         create_special_page(kind, homepage.id) if public_send("has_#{kind}?")
       end
       # team pages
diff --git a/app/models/university/person/experience.rb b/app/models/university/person/experience.rb
index 7a07ecd396a65efa71e56702971532a3a3227802..3cee8c3347cd85fbc792cc0aac2bfa61b3ac4523 100644
--- a/app/models/university/person/experience.rb
+++ b/app/models/university/person/experience.rb
@@ -29,7 +29,5 @@ class University::Person::Experience < ApplicationRecord
   belongs_to :person
   belongs_to :organization, class_name: "University::Organization"
 
-  validates :from_year, presence: true
-
   scope :ordered, -> { order(from_year: :desc)}
 end
diff --git a/app/models/university/person/with_experiences.rb b/app/models/university/person/with_experiences.rb
index 3de7c0e972a23cacb411d15a733cea149e1e5a2d..45b6cbba52826bf63258092a56f5e6039e9ba5c4 100644
--- a/app/models/university/person/with_experiences.rb
+++ b/app/models/university/person/with_experiences.rb
@@ -10,8 +10,7 @@ module University::Person::WithExperiences
                                   reject_if: :all_blank,
                                   allow_destroy: true
 
-    # PA FIXME
-    # validates_associated :experiences
+    validates_associated :experiences
 
     scope :for_alumni_organization, -> (organization_id) {
       left_joins(:experiences)
diff --git a/app/models/user.rb b/app/models/user.rb
index 0b7266b7eee47105b9edd65fa93bd81db33a373d..ee8e99f437f8767ad2cf4ffe352c06d4d73742e4 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -65,6 +65,7 @@ class User < ApplicationRecord
   belongs_to :language
 
   scope :ordered, -> { order(:last_name, :first_name) }
+  scope :for_language, -> (language_id) { where(language_id: language_id) }
   scope :for_search_term, -> (term) {
     where("
       unaccent(concat(users.first_name, ' ', users.last_name)) ILIKE unaccent(:term) OR
diff --git a/app/services/curator.rb b/app/services/curator.rb
index 8b56f1a912e21ccf745cc288fde9e03c190760bf..4a0a31cde76dba103154b2dcb2bb23b52737385c 100644
--- a/app/services/curator.rb
+++ b/app/services/curator.rb
@@ -16,7 +16,7 @@ class Curator
   protected
 
   def create_post!
-    text = Wordpress.clean_html("#{page.text}<br><a href=\"#{@url}\" target=\"_blank\">Source</a>")
+    text = Wordpress.clean_html("#{page.text}<p><a href=\"#{@url}\" target=\"_blank\">Source</a></p>")
     @post = website.posts.create(
       university: website.university,
       title: page.title,
diff --git a/app/services/filters/admin/users.rb b/app/services/filters/admin/users.rb
index 5438038118677358d22fd77657476ee056b5660c..62691ceffc6174f0550cce0442cdbe03df72a762 100644
--- a/app/services/filters/admin/users.rb
+++ b/app/services/filters/admin/users.rb
@@ -3,6 +3,12 @@ module Filters
     def initialize(user)
       super
       add_search
+      add :for_language,
+          ::Language.all.map { |l| { to_s: I18n.t("languages.#{l.iso_code}"), id: l.id } },
+          I18n.t(
+            'filters.attributes.element',
+            element: Language.model_name.human.downcase
+          )
       add :for_role,
           ::User.roles.keys.map { |r| { to_s: I18n.t("activerecord.attributes.user.roles.#{r}"), id: r } },
           I18n.t('filters.attributes.role')
diff --git a/app/views/admin/communication/blocks/_static.html.erb b/app/views/admin/communication/blocks/_static.html.erb
index 22377454bf009046a56668ebf0d883852d96fa1e..f48693db8af3b0f27d902061e6799268d68a02e2 100644
--- a/app/views/admin/communication/blocks/_static.html.erb
+++ b/app/views/admin/communication/blocks/_static.html.erb
@@ -5,7 +5,7 @@ blocks:
   @university = about.university
   %>
   - template: <%= block.template_kind %>
-    title: >
+    title: >-
       <%= prepare_text_for_static block.title, 3 %>
     position: <%= block.position %>
     data:
diff --git a/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb b/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb
index cbc779dcec1065b5351677e4eedcca6cebee80f3..d17eb5d06ecd6cd3890c112d48cfce4dfc78d8fb 100644
--- a/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb
+++ b/app/views/admin/communication/blocks/templates/call_to_action/_static.html.erb
@@ -4,8 +4,10 @@
       image:
         id: "<%= block.template.image.blob.id %>"
         file: "<%= block.template.image.blob.id %>"
-        alt: <%= prepare_text_for_static block.template.image.alt %>
-        credit: <%= prepare_text_for_static block.template.image.credit %>
+        alt: >-
+          <%= prepare_text_for_static block.template.image.alt, 5 %>
+        credit: >-
+          <%= prepare_text_for_static block.template.image.credit, 5 %>
     <% end %>
       button:
         text: >-
diff --git a/app/views/admin/communication/blocks/templates/files/_static.html.erb b/app/views/admin/communication/blocks/templates/files/_static.html.erb
index cbfb04c22cc65b327b433099652b03f2e2f74168..6a73fcab9406836a14d27bcfd3611eb8285fffbd 100644
--- a/app/views/admin/communication/blocks/templates/files/_static.html.erb
+++ b/app/views/admin/communication/blocks/templates/files/_static.html.erb
@@ -1,5 +1,6 @@
       files:
 <% block.template.files.each do |file| %>
-        - title: "<%= file.title %>"
+        - title: >-
+            <%= prepare_text_for_static file.title, 6 %>
           id: "<%= file.blob.id if file.blob %>"
 <% end %>
diff --git a/app/views/admin/education/teachers/_list.html.erb b/app/views/admin/education/teachers/_list.html.erb
index d9deb9b99ae6a7c2f3ce31b2884d0c70f2f11d80..cdcbf4649fcda328e908c0d62cc1d5e96c7c04a0 100644
--- a/app/views/admin/education/teachers/_list.html.erb
+++ b/app/views/admin/education/teachers/_list.html.erb
@@ -3,6 +3,8 @@
     <tr>
       <th><%= University::Person.human_attribute_name('last_name') %></th>
       <th><%= University::Person.human_attribute_name('first_name') %></th>
+      <th><%= Education::Program.model_name.human(count: 2) %></th>
+      <th></th>
       <th></th>
     </tr>
   </thead>
@@ -11,9 +13,14 @@
       <tr>
         <td><%= link_to teacher.last_name, admin_education_teacher_path(teacher) %></td>
         <td><%= link_to teacher.first_name, admin_education_teacher_path(teacher) %></td>
+        <td><%= teacher.involvements.size %></td>
+        <td class="p-0">
+          <%= kamifusen_tag teacher.best_picture,
+                            width: 40 if teacher.best_picture.attached? %>
+        </td>
         <td class="text-end">
           <div class="btn-group" role="group">
-            <%#= link_to t('edit'),
+            <%= link_to t('edit'),
                       edit_admin_education_teacher_path(teacher),
                       class: button_classes %>
           </div>
diff --git a/app/views/admin/research/researchers/index.html.erb b/app/views/admin/research/researchers/index.html.erb
index d0256588dcffd2d64877dc044571ab30f21803f9..d20f3591baaf0bbd51dbb3315f83e29b768694b8 100644
--- a/app/views/admin/research/researchers/index.html.erb
+++ b/app/views/admin/research/researchers/index.html.erb
@@ -7,6 +7,7 @@
     <tr>
       <th><%= University::Person.human_attribute_name('name') %></th>
       <th><%= University::Person.human_attribute_name('first_name') %></th>
+      <th></th>
       <th><%= t('research.number_of_articles') %></th>
     </tr>
   </thead>
@@ -16,6 +17,10 @@
       <tr>
         <td><%= link_to researcher.last_name, admin_research_researcher_path(researcher) %></td>
         <td><%= link_to researcher.first_name, admin_research_researcher_path(researcher) %></td>
+        <td class="p-0">
+          <%= kamifusen_tag researcher.best_picture,
+                            width: 40 if researcher.best_picture.attached? %>
+        </td>
         <td><%= researcher.research_journal_articles.count %></td>
       </tr>
     <% end %>
diff --git a/app/views/admin/university/alumni/_list.html.erb b/app/views/admin/university/alumni/_list.html.erb
index e8676343406419cacc52936259be44191a1fc8ca..212f867b40057810d3ddb5b1ac898737945cfed2 100644
--- a/app/views/admin/university/alumni/_list.html.erb
+++ b/app/views/admin/university/alumni/_list.html.erb
@@ -3,14 +3,23 @@
     <tr>
       <th><%= University::Person.human_attribute_name('last_name') %></th>
       <th><%= University::Person.human_attribute_name('first_name') %></th>
+      <th><%= Education::Cohort.model_name.human(count: 2) %></th>
+      <th><%= University::Person::Experience.model_name.human(count: 2) %></th>
+      <th></th>
     </tr>
   </thead>
   <tbody>
     <% alumni.each do |alumnus| %>
       <% path = admin_university_alumnus_path(alumnus) %>
       <tr>
-        <td><%= link_to alumnus.last_name, path %></td>
-        <td><%= link_to alumnus.first_name, path %></td>
+        <td><%= link_to_if can?(:read, alumnus), alumnus.last_name, path %></td>
+        <td><%= link_to_if can?(:read, alumnus), alumnus.first_name, path %></td>
+        <td><%= link_to_if can?(:update, alumnus), alumnus.cohorts.size, cohorts_admin_university_alumnus_path(alumnus) %></td>
+        <td><%= link_to_if can?(:update, alumnus), alumnus.experiences.size, experiences_admin_university_alumnus_path(alumnus) %></td>
+        <td class="p-0">
+          <%= kamifusen_tag alumnus.best_picture,
+                            width: 40 if alumnus.best_picture.attached? %>
+        </td>
       </tr>
     <% end %>
   </tbody>
diff --git a/app/views/admin/university/alumni/show.html.erb b/app/views/admin/university/alumni/show.html.erb
index 22ceb9fe5559597262e38e89aeebed86d23083da..fe27cf2c690364bbfd76336dbfa182ef58672feb 100644
--- a/app/views/admin/university/alumni/show.html.erb
+++ b/app/views/admin/university/alumni/show.html.erb
@@ -28,7 +28,7 @@
         <% organization = experience.organization %>
         <li>
           <%= link_to_if can?(:read, organization), organization, [:admin, organization] %>
-          <%= "(#{experience.from_year} - #{experience.to_year.present? ? experience.to_year : t('today')})" %>
+          <%= "(#{experience.from_year} - #{experience.to_year.present? ? experience.to_year : t('today')})" if experience.from_year %>
         </li>
       <% end %>
       </ul>
diff --git a/app/views/admin/users/index.html.erb b/app/views/admin/users/index.html.erb
index bda69d5ff4c56faa033a05a8206a563a5a2a6b12..ba72682ee1b08d693970200749dfa7c7ffbe16b1 100644
--- a/app/views/admin/users/index.html.erb
+++ b/app/views/admin/users/index.html.erb
@@ -11,26 +11,20 @@
       <th><%= User.human_attribute_name('first_name') %></th>
       <th><%= User.human_attribute_name('email') %></th>
       <th><%= User.human_attribute_name('role') %></th>
-      <th><%= User.human_attribute_name('language') %></th>
       <th></th>
     </tr>
   </thead>
   <tbody>
     <% @users.each do |user| %>
       <tr>
-        <td><%= user.last_name %></td>
-        <td><%= user.first_name %></td>
+        <td><%= link_to_if can?(:read, user), user.last_name, [:admin, user] %></td>
+        <td><%= link_to_if can?(:read, user), user.first_name, [:admin, user] %></td>
         <td><%= link_to user.email, [:admin, user] %></td>
         <td>
           <span class="badge bg-secondary">
             <%= t("activerecord.attributes.user.roles.#{user.role}") %>
           </span>
         </td>
-        <td>
-          <span class="badge bg-secondary">
-            <%= user.language %>
-          </span>
-        </td>
         <td class="text-end">
           <div class="btn-group" role="group">
             <%= edit_link user %>
diff --git a/config/locales/communication/en.yml b/config/locales/communication/en.yml
index bfd4da71d4cf89c484d104a3153abab33cf9d01a..838b4f54374e4b20711d38e8acb8dc04bd4c896a 100644
--- a/config/locales/communication/en.yml
+++ b/config/locales/communication/en.yml
@@ -365,6 +365,11 @@ en:
       last_posts: Last posts
       pages:
         defaults:
+          accessibility:
+            admin_description: accessibility page
+            description_short: ''
+            slug: accessibility
+            title: Accessibility
           administrators:
             admin_description: list of members in the administrative team
             description_short: List of members in the administrative team
diff --git a/config/locales/communication/fr.yml b/config/locales/communication/fr.yml
index 566db9759de326d54d989d63306c44b5c38a8b60..45fad5ead09d12708acdd1294bc4b38ca68a6d06 100644
--- a/config/locales/communication/fr.yml
+++ b/config/locales/communication/fr.yml
@@ -383,6 +383,11 @@ fr:
       last_posts: Dernières actualités
       pages:
         defaults:
+          accessibility:
+            admin_description: page accessibilité
+            description_short: ''
+            slug: accessibilite
+            title: Accessibilité
           administrators:
             admin_description: liste des membres de l'équipe administrative
             description_short: Liste des membres de l'équipe administrative
diff --git a/config/locales/en.yml b/config/locales/en.yml
index c2bba1bca1222961a37dcb3a6c62c182e38fa186..87184496fcdebdd063422a2e420cdb847e208adb 100644
--- a/config/locales/en.yml
+++ b/config/locales/en.yml
@@ -128,17 +128,17 @@ en:
     title: Image
     alt:
       label: Alternative text
-      hint: This text is important for accessibility
+      hint: This text is important for accessibility. If the image conveys important information, it must be written here. If the information is already written somewhere else in the page, or if the image is purely decorative, the field must be left empty. Otherwise, it would pollute voice navigation.
     credit:
       label: Credit
       hint: The credit must be present according to copyright or copyleft licenses.
     remove: Remove image
   filters:
     attributes:
-      date: Filter by Date
+      date: Filter by date
       element: Filter by %{element}
-      kind: Filter by Kind
-      role: Filter by Role
+      kind: Filter by kind
+      role: Filter by role
     buttons:
       expand: Filter table
       submit: Filter
diff --git a/config/locales/fr.yml b/config/locales/fr.yml
index 824f1bfb57e913b854386c65f5d224b27b9edaff..81430035d31a21e3da34a1b678bcd7f426b0c699 100644
--- a/config/locales/fr.yml
+++ b/config/locales/fr.yml
@@ -128,17 +128,17 @@ fr:
     title: Image
     alt:
       label: Texte alternatif
-      hint: Ce texte est essentiel pour l'accessibilité
+      hint: Ce texte est essentiel pour l'accessibilité. Si l'image donne une information importante, il faut écrire ici cette information. Si l'information est déjà présente ailleurs dans la page, ou si l'image est purement décorative, il faut laisser le texte alternatif vide, pour éviter de polluer la navigation vocale.
     credit:
       label: Crédit
-      hint: Le crédit photo doit être indiqué, dans le respect du droit d'auteur
+      hint: Le crédit photo doit être indiqué, dans le respect du droit d'auteur.
     remove: Supprimer l'image
   filters:
     attributes:
-      date: Filtrer par Date
+      date: Filtrer par date
       element: Filtrer par %{element}
-      kind: Filtrer par Type
-      role: Filtrer par Rôle
+      kind: Filtrer par type
+      role: Filtrer par rôle
     buttons:
       expand: Filtrer le tableau
       submit: Filtrer