diff --git a/.ci/.autoRedirect b/.ci/.autoRedirect
index 6ee4103f26afcb967c94c82b104eaad76e3aee3e..f729e683481780c14e187ae8543f84e1f1cb4bd5 100644
--- a/.ci/.autoRedirect
+++ b/.ci/.autoRedirect
@@ -35,11 +35,11 @@
             if (sub.length > 0) {
                 UrlExists(internalURL+'/stable/internal/'+sub, function(status){
                     if (status == 200) { // if sub-card is internal in the internal directory and exists
-                        window.location.href = internalURL+'/stable/internal/'+sub;
+                        window.location.href = internalURL+'/stable/internal/cards/'+sub;
                     } else {
                         UrlExists(internalURL+'/stable/external/'+sub, function(status){
                             if (status == 200) { // if sub-card is internal in the external directory and exists
-                                window.location.href = internalURL+'/stable/external/'+sub;
+                                window.location.href = internalURL+'/stable/external/cards/'+sub;
                             } else {
                                 window.location.href = internalURL+'/stable/404.html';
                             }
@@ -58,9 +58,9 @@
         // external pages
         } else {
             if (sub.length > 0) { sub = 'external/'+sub; }
-            UrlExists(externalURL+'/stable/'+sub, function(status){
-                if (status == 200) { // if sub-car is internal and exists
-                    window.location.href = externalURL+'/stable/'+sub;
+            UrlExists(externalURL+'/stable/cards/'+sub, function(status){
+                if (status == 200) { // if sub-card is internal and exists
+                    window.location.href = externalURL+'/stable/cards/'+sub;
                 } else {
                     window.location.href = externalURL+'/stable/404.html';
                 }
diff --git a/Gemfile b/Gemfile
index 05a3baca698ddfc4da66824074abdc51f19974d0..9c4719c6f0990058e065960d6a1cb77e27be5f60 100644
--- a/Gemfile
+++ b/Gemfile
@@ -32,6 +32,8 @@ group :jekyll_plugins do
      :git => "https://git-r3lab.uni.lu/core-services/jekyll-theme-lcsb-frozen-components.git",
      :branch => "master"
 
+ gem 'jekyll-redirect-from',
+     '0.16.0'
 end
 
 # Windows does not include zoneinfo files, so bundle the tzinfo-data gem
diff --git a/_config.yml b/_config.yml
index 5b8b3570064230e546639e0485dfd916d7642928..60b9b5990d9696eeab499db3e3ceb3bc8f953c47 100644
--- a/_config.yml
+++ b/_config.yml
@@ -54,6 +54,7 @@ theme: jekyll-theme-lcsb-default
 plugins:
   - jekyll-feed
   - jekyll-paginate-v2
+  - jekyll-redirect-from
 
 # These settings are used to display share link to howto.lcsb.uni.lu
 # The display logic itself is in the template
diff --git a/_includes/scripts.html b/_includes/scripts.html
new file mode 100644
index 0000000000000000000000000000000000000000..0571d7c86ecb70f8697deaa3f28b28b014c5c064
--- /dev/null
+++ b/_includes/scripts.html
@@ -0,0 +1,16 @@
+<!-- Matomo -->
+<script type="text/javascript">
+    var _paq = window._paq || [];
+    /* tracker methods like "setCustomDimension" should be called before "trackPageView" */
+    _paq.push(['trackPageView']);
+    _paq.push(['enableLinkTracking']);
+    (function() {
+      var u="https://howto-monitoring.lcsb.uni.lu/matomo/";
+      _paq.push(['setTrackerUrl', u+'matomo.php']);
+      _paq.push(['setSiteId', '2']);
+      var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
+      g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
+    })();
+</script>
+<noscript><p><img src="https://howto-monitoring.lcsb.uni.lu/matomo/matomo.php?idsite=2&amp;rec=1" style="border:0;" alt="" /></p></noscript>
+<!-- End Matomo Code -->
\ No newline at end of file
diff --git a/external/daisy/daisy.md b/external/daisy/daisy.md
index d6be7f59138a49194fb1b2df59d824563d9a8147..39ae96fad5b6385076ee450180d3d46af5581338 100644
--- a/external/daisy/daisy.md
+++ b/external/daisy/daisy.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/daisy/
+shortcut: gdpr:daisy
+redirect_from:
+  - /cards/gdpr:daisy
+  - /external/cards/gdpr:daisy
 
 ---
 # <a name="top"></a>DAISY User Guide
diff --git a/external/exchange-channels/exchange-channels.md b/external/exchange-channels/exchange-channels.md
index e621f2b6a5d4b6109b77785478b65ae3b3c9653a..4a6bd90054d0db4590cc608c4329886f0c455130 100644
--- a/external/exchange-channels/exchange-channels.md
+++ b/external/exchange-channels/exchange-channels.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/exchange-channels/
+shortcut: gdpr:exchange-channels
+redirect_from:
+  - /cards/gdpr:exchange-channels
+  - /external/cards/gdpr:exchange-channels
 ---
 # Exchanging Research Data with Collaborators
 {:.no_toc}
diff --git a/external/git-clients/git-clients.md b/external/git-clients/git-clients.md
index f86b164a3d0b00063d0332990e90d988c59d241a..df275ff9dd977b2d80298c64a61c5c4df6765abc 100644
--- a/external/git-clients/git-clients.md
+++ b/external/git-clients/git-clients.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/git-clients/
+shortcut: contribute:git-clients
+redirect_from:
+  - /cards/contribute:git-clients
+  - /external/cards/contribute:git-clients
 ---
 
 # Git clients
diff --git a/external/lums-passwords/lums-passwords.md b/external/lums-passwords/lums-passwords.md
index 4719ab2410aac77e35bdd6b6a3c7eb313da79668..32231652a8a638ffbdae4b58ee376c6aa4979fec 100644
--- a/external/lums-passwords/lums-passwords.md
+++ b/external/lums-passwords/lums-passwords.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/lums-passwords/
+shortcut: passwords:lums
+redirect_from:
+  - /cards/passwords:lums
+  - /external/cards/passwords:lums
 ---
 
 # LUMS account
diff --git a/external/markdown/markdown.md b/external/markdown/markdown.md
index 770581c73d2a520538dc7209f24b0533f43883be..291bc3759fd51de35cf9a82f468c56903811569e 100644
--- a/external/markdown/markdown.md
+++ b/external/markdown/markdown.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/markdown/
+shortcut: contribute:markdown
+redirect_from:
+  - /cards/contribute:markdown
+  - /external/cards/contribute:markdown
 ---
 
 # Markdown
diff --git a/external/passwords/mac-reset.md b/external/passwords/mac-reset.md
index 61e0a686166b0abfe41656d26c58985909f05a2b..ebe43f3a84f045edd3f255b1bc61b4f989317284 100644
--- a/external/passwords/mac-reset.md
+++ b/external/passwords/mac-reset.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/passwords/mac-reset
+shortcut: passwords:mac-reset
+redirect_from:
+  - /cards/passwords:mac-reset
+  - /external/cards/passwords:mac-reset
 ---
 
 # Tips when resetting University of Luxembourg Active Directory password on a Mac
diff --git a/external/passwords/passwords.md b/external/passwords/passwords.md
index bdc5c7e734e54b462411e16c1018c790c5acab15..69c9b9cb0b2e61dc9566a1c649d89439e9321fd3 100644
--- a/external/passwords/passwords.md
+++ b/external/passwords/passwords.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/passwords/
+shortcut: passwords
+redirect_from:
+  - /cards/passwords
+  - /external/cards/passwords
 ---
 
 # Managing your passwords
diff --git a/external/vpn-cerbere-access/vpn-cerbere-access.md b/external/vpn-cerbere-access/vpn-cerbere-access.md
index 2b4c94cdfdbf5cd549e145168559222caf4e8aef..f9a576f0d55a84b883a09a6111741884b15e0be8 100644
--- a/external/vpn-cerbere-access/vpn-cerbere-access.md
+++ b/external/vpn-cerbere-access/vpn-cerbere-access.md
@@ -1,6 +1,10 @@
 ---
 layout: page
 permalink: /external/vpn-cerbere-access/
+shortcut: passwords:vpn
+redirect_from:
+  - /cards/passwords:vpn
+  - /external/cards/passwords:vpn
 ---
 
 # VPN/CERBERE connection