diff --git a/app/Http/Controllers/Public/LegalMentionsController.php b/app/Http/Controllers/Public/LegalMentionsController.php
new file mode 100644
index 0000000000000000000000000000000000000000..4098697920ba33c78d7742a818a9902af53125af
--- /dev/null
+++ b/app/Http/Controllers/Public/LegalMentionsController.php
@@ -0,0 +1,21 @@
+<?php
+
+namespace App\Http\Controllers\Public;
+
+use App\Http\Controllers\Controller;
+use App\Models\LegalMention;
+
+class LegalMentionsController extends Controller
+{
+    public function __invoke()
+    {
+        $activeLegalMentionsText = LegalMention::where('active', true)->first();
+
+        if (! $activeLegalMentionsText) {
+            abort(404);
+        }
+        $activeLegalMentionsText = $activeLegalMentionsText->contentTransKey->getTranslation();
+
+        return view('public.legal-mentions', compact('activeLegalMentionsText'));
+    }
+}
diff --git a/app/Http/Controllers/Public/TermsController.php b/app/Http/Controllers/Public/TermsController.php
new file mode 100644
index 0000000000000000000000000000000000000000..a20736b21e40f1970a758be6b82ebd599c7956b0
--- /dev/null
+++ b/app/Http/Controllers/Public/TermsController.php
@@ -0,0 +1,22 @@
+<?php
+
+namespace App\Http\Controllers\Public;
+
+use App\Http\Controllers\Controller;
+use App\Models\TermsSection;
+use Illuminate\View\View;
+
+class TermsController extends Controller
+{
+    public function __invoke(): View
+    {
+        $activeTermsText = TermsSection::where('active', true)->first();
+
+        if (! $activeTermsText) {
+            abort(404);
+        }
+        $activeTermsText = $activeTermsText->contentTranslationKey->getTranslation();
+
+        return view('public.terms', compact('activeTermsText'));
+    }
+}
diff --git a/lang/en/footer.php b/lang/en/footer.php
new file mode 100644
index 0000000000000000000000000000000000000000..8c46e83400e9f00b7abead2b34a3dd71c39d197e
--- /dev/null
+++ b/lang/en/footer.php
@@ -0,0 +1,14 @@
+<?php
+
+return [
+    'contact' => [
+        'title' => 'Excited to work with you!',
+        'desc' => 'Feel free to contact me if you need information, or if you just want to chat with me.',
+    ],
+    'links' => [
+        'title' => 'Stay in touch',
+    ],
+    'legals-infos' => [
+        'title' => 'Legal information',
+    ],
+];
diff --git a/lang/en/generic.php b/lang/en/generic.php
index 51de6fe9e666f20e6169dff894b319ce4b1416d9..a345a842c4e75dcc9747427837b12f5f10eb10f9 100644
--- a/lang/en/generic.php
+++ b/lang/en/generic.php
@@ -4,4 +4,6 @@
     'custom_needs' => 'A specific need?',
     'custom_needs_desc' => 'I am open to any proposal. Don’t hesitate to contact me!',
     'completed_in' => 'Completed in',
+    'legal_mentions' => 'Legal notices',
+    'terms' => 'Terms and conditions of sale',
 ];
diff --git a/lang/fr/footer.php b/lang/fr/footer.php
new file mode 100644
index 0000000000000000000000000000000000000000..0e7acdedfc7c68d0ae44642d3a24acba707dda0b
--- /dev/null
+++ b/lang/fr/footer.php
@@ -0,0 +1,14 @@
+<?php
+
+return [
+    'contact' => [
+        'title' => 'Hâte de travailler avec vous !',
+        'desc' => 'N’hésitez pas à me contacter si vous avez besoin de renseignements, ou que vous souhaitez simplement discuter avec moi.',
+    ],
+    'links' => [
+        'title' => 'Restons en contact',
+    ],
+    'legals-infos' => [
+        'title' => 'Informations légales',
+    ],
+];
diff --git a/lang/fr/generic.php b/lang/fr/generic.php
index 4b27032c33a73fb3c47194d9a0b8197c2d786f5d..0c369358497101f7f0bfffd75983290fdc6b7610 100644
--- a/lang/fr/generic.php
+++ b/lang/fr/generic.php
@@ -4,4 +4,6 @@
     'custom_needs' => 'Un besoin particulier ?',
     'custom_needs_desc' => 'Je suis ouverte à toute proposition. N’hésitez pas à me contacter !',
     'completed_in' => 'Réalisé en',
+    'legal_mentions' => 'Mentions légales',
+    'terms' => 'Conditions générales de vente',
 ];
diff --git a/resources/views/components/public/footer.blade.php b/resources/views/components/public/footer.blade.php
index 05142fdf514118c6824e2c1982921cb4f779788b..b49d55e59e1fa0ba91335832a7247dca42e76f63 100644
--- a/resources/views/components/public/footer.blade.php
+++ b/resources/views/components/public/footer.blade.php
@@ -8,20 +8,20 @@
                         <x-public.rann-logo height="4rem" role="image"/>
                     </div>
                     <div class="self-stretch flex-col justify-start items-start gap-2 flex">
-                        <div class="self-stretch text-2xl font-bold">Hâte de travailler avec vous !</div>
-                        <div class="self-stretch text-muted">N’hésitez pas à me contacter si vous avez besoin de
-                            renseignements, ou que vous souhaitez simplement discuter avec moi.
+                        <div class="self-stretch text-2xl font-bold">{{ __('footer.contact.title') }}</div>
+                        <div class="self-stretch text-muted">
+                            {{ __('footer.contact.desc') }}
                         </div>
                     </div>
                     <x-public.button size="medium" tag="a" href="#">
-                        <div class="text-xl font-bold">Me contacter</div>
+                        <div class="text-xl font-bold">{{ __('navbar.contact_me') }}</div>
                     </x-public.button>
                 </div>
             </div>
 
             <div class="w-full lg:w-auto items-start flex flex-col lg:flex-row gap-8 lg:gap-24">
                 <div class="w-full lg:w-56 flex-col gap-8 flex">
-                    <div class="self-stretch text-2xl font-bold">Restons en contact</div>
+                    <div class="self-stretch text-2xl font-bold">{{ __('footer.links.title') }}</div>
                     <ul class="flex flex-col gap-2">
                         @foreach(\App\Models\SocialMediaLink::all() as $socialMediaLink)
                             <li>
@@ -33,16 +33,15 @@
                     </ul>
                 </div>
                 <div class="w-full lg:w-56 flex-col gap-8 flex">
-                    <div class="self-stretch text-2xl font-bold">Informations légales</div>
+                    <div class="self-stretch text-2xl font-bold">{{ __('footer.legals-infos.title') }}</div>
                     <ul class="flex flex-col gap-2">
                         <li>
-                            <a href="#" class="text-muted hover:text-primary">Mentions légales</a>
+                            <a href="{{ route('legal-mentions') }}"
+                               class="text-muted hover:text-primary">{{ __('generic.legal_mentions') }}</a>
                         </li>
                         <li>
-                            <a href="#" class="text-muted hover:text-primary">Conditions générales de vente</a>
-                        </li>
-                        <li>
-                            <a href="#" class="text-muted hover:text-primary">Politique de confidentialité</a>
+                            <a href="{{ route('terms') }}"
+                               class="text-muted hover:text-primary">{{ __('generic.terms') }}</a>
                         </li>
                     </ul>
                 </div>
diff --git a/resources/views/components/public/generic-page-header.blade.php b/resources/views/components/public/generic-page-header.blade.php
index 7883746c0253491d0b38ca139d379b74f96a19ac..defaac73b1c21652eacf74dd4be847ddcc368361 100644
--- a/resources/views/components/public/generic-page-header.blade.php
+++ b/resources/views/components/public/generic-page-header.blade.php
@@ -1,6 +1,6 @@
 @props([
     'title' => 'Title',
-    'description' => 'Description',
+    'description' => '',
 ])
 
 <div {{ $attributes->class(['relative flex flex-col max-w-2xl gap-3']) }}>
diff --git a/resources/views/public/legal-mentions.blade.php b/resources/views/public/legal-mentions.blade.php
new file mode 100644
index 0000000000000000000000000000000000000000..65d3c5cc42d7c0a94a6e7782337eb2535d96c795
--- /dev/null
+++ b/resources/views/public/legal-mentions.blade.php
@@ -0,0 +1,16 @@
+@extends('layouts.public', ['title' => __('generic.legal_mentions')])
+
+@section('content')
+    <x-public.navbar class="container mx-auto px-4"/>
+
+    <div class="container mx-auto px-4 py-24 flex flex-col gap-16">
+        <x-public.generic-page-header title="{{ __('generic.legal_mentions') }}"/>
+        <div>
+            <x-markdown class="markdown">
+                {{ $activeLegalMentionsText }}
+            </x-markdown>
+        </div>
+    </div>
+
+    <x-public.footer/>
+@endsection
\ No newline at end of file
diff --git a/resources/views/public/terms.blade.php b/resources/views/public/terms.blade.php
new file mode 100644
index 0000000000000000000000000000000000000000..c7d919ab651ef56b0fc097ccca6d36e41e0cdc9d
--- /dev/null
+++ b/resources/views/public/terms.blade.php
@@ -0,0 +1,16 @@
+@extends('layouts.public', ['title' => __('generic.terms')])
+
+@section('content')
+    <x-public.navbar class="container mx-auto px-4"/>
+
+    <div class="container mx-auto px-4 py-24 flex flex-col gap-16">
+        <x-public.generic-page-header title="{{ __('generic.terms') }}"/>
+        <div>
+            <x-markdown class="markdown">
+                {{ $activeTermsText }}
+            </x-markdown>
+        </div>
+    </div>
+
+    <x-public.footer/>
+@endsection
\ No newline at end of file
diff --git a/routes/web.php b/routes/web.php
index aa637dc52583b1a3b5e1c9d22841990f31785ee2..3f72ca537dad8768b14793c321871478b4695110 100644
--- a/routes/web.php
+++ b/routes/web.php
@@ -11,8 +11,10 @@
 use App\Http\Controllers\Admin\SocialMediaLinksController;
 use App\Http\Controllers\Admin\TermsSectionController;
 use App\Http\Controllers\Public\IndexController;
+use App\Http\Controllers\Public\LegalMentionsController;
 use App\Http\Controllers\Public\PortfolioController;
 use App\Http\Controllers\Public\PrestationController as PublicPrestationController;
+use App\Http\Controllers\Public\TermsController;
 use App\Http\Middleware\CheckPrivateModeMiddleware;
 use App\Http\Middleware\RedirectIfUserExistsMiddleware;
 use Illuminate\Support\Facades\Route;
@@ -29,6 +31,8 @@
     Route::get('/portfolio/api', [PortfolioController::class, 'api'])->name('portfolio.api');
     Route::get('/portfolio/{slug}', [PortfolioController::class, 'show'])->name('portfolio.show');
     Route::get('/prestations/{slug}', [PublicPrestationController::class, 'index'])->name('prestations.show');
+    Route::get('/mentions-legales', LegalMentionsController::class)->name('legal-mentions');
+    Route::get('/conditions-generales-de-vente', TermsController::class)->name('terms');
 
     Route::view('/maintenance', 'public.maintenance')->name('maintenance');
 });