<!DOCTYPE html>
<html lang="en" dir="auto">
<head><meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta name="robots" content="index, follow">
<title>404 Page not found | fplanque.net [FR]</title>
<meta name="keywords" content="">
<meta name="description" content="François Planque's English Archive">
<meta name="author" content="François Planque">
<link rel="canonical" href="https://www.fplanque.net/404.html">
<link crossorigin="anonymous" href="/assets/css/stylesheet.3d4ff0e1bafdf719c39d769832c5c97757e05e394dd7bffb42e08f163d46612e.css" integrity="sha256-PU/w4br99xnDnXaYMsXJd1fgXjlN17/7QuCPFj1GYS4=" rel="preload stylesheet" as="style">
<link rel="icon" href="https://www.fplanque.net/favicon/fp.ico">
<link rel="icon" type="image/png" sizes="16x16" href="https://www.fplanque.net/favicon/fp-16.png">
<link rel="icon" type="image/png" sizes="32x32" href="https://www.fplanque.net/favicon/fp-32.png">
<link rel="apple-touch-icon" href="https://www.fplanque.net/favicon/fp-64.png">
<link rel="mask-icon" href="https://www.fplanque.net/favicon/fp-64.png">
<meta name="theme-color" content="#2e2e33">
<meta name="msapplication-TileColor" content="#2e2e33">
<link rel="alternate" hreflang="en" href="https://www.fplanque.net/404.html">
<noscript>
<style>
#theme-toggle,
.top-link {
display: none;
}
</style>
<style>
@media (prefers-color-scheme: dark) {
:root {
--theme: rgb(29, 30, 32);
--entry: rgb(46, 46, 51);
--primary: rgb(218, 218, 219);
--secondary: rgb(155, 156, 157);
--tertiary: rgb(65, 66, 68);
--content: rgb(196, 196, 197);
--code-block-bg: rgb(46, 46, 51);
--code-bg: rgb(55, 56, 62);
--border: rgb(51, 51, 51);
}
.list {
background: var(--theme);
}
.list:not(.dark)::-webkit-scrollbar-track {
background: 0 0;
}
.list:not(.dark)::-webkit-scrollbar-thumb {
border-color: var(--theme);
}
}
</style>
</noscript>
<script async src="https://www.googletagmanager.com/gtag/js?id=G-TD8TDLBJBW"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-TD8TDLBJBW');
</script><meta property="og:title" content="404 Page not found" />
<meta property="og:description" content="François Planque's English Archive" />
<meta property="og:type" content="website" />
<meta property="og:url" content="https://www.fplanque.net/404.html" />
<meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="404 Page not found"/>
<meta name="twitter:description" content="François Planque's English Archive"/>
<meta name="twitter:site" content="@fplanque"/>
</head>
<body class="list" id="top">
<script>
if (localStorage.getItem("pref-theme") === "dark") {
document.body.classList.add('dark');
} else if (localStorage.getItem("pref-theme") === "light") {
document.body.classList.remove('dark')
} else if (window.matchMedia('(prefers-color-scheme: dark)').matches) {
document.body.classList.add('dark');
}
</script>
<header class="header">
<nav class="nav">
<div class="logo">
<a href="https://www.fplanque.net/" accesskey="h" title="fplanque.net [FR] (Alt + H)">fplanque.net [FR]</a>
<div class="logo-switches">
<button id="theme-toggle" accesskey="t" title="(Alt + T)">
<svg id="moon" xmlns="http://www.w3.org/2000/svg" width="24" height="18" viewBox="0 0 24 24"
fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"
stroke-linejoin="round">
<path d="M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z"></path>
</svg>
<svg id="sun" xmlns="http://www.w3.org/2000/svg" width="24" height="18" viewBox="0 0 24 24"
fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"
stroke-linejoin="round">
<circle cx="12" cy="12" r="5"></circle>
<line x1="12" y1="1" x2="12" y2="3"></line>
<line x1="12" y1="21" x2="12" y2="23"></line>
<line x1="4.22" y1="4.22" x2="5.64" y2="5.64"></line>
<line x1="18.36" y1="18.36" x2="19.78" y2="19.78"></line>
<line x1="1" y1="12" x2="3" y2="12"></line>
<line x1="21" y1="12" x2="23" y2="12"></line>
<line x1="4.22" y1="19.78" x2="5.64" y2="18.36"></line>
<line x1="18.36" y1="5.64" x2="19.78" y2="4.22"></line>
</svg>
</button>
</div>
</div>
<ul id="menu">
<li>
<a href="https://www.fplanque.net/tech/" title="Tech">
<span>Tech</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/open-source/" title="Open Source">
<span>Open Source</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/work/" title="Pro">
<span>Pro</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/softculture/" title="Divers">
<span>Divers</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/credit-finance/" title="Capitalisme">
<span>Capitalisme</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/about/" title="About">
<span>About</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/tags/" title="Tags">
<span>Tags</span>
</a>
</li>
<li>
<a href="https://www.fplanque.net/search/" title="Search (Alt + /)" accesskey=/>
<span>Search</span>
</a>
</li>
</ul>
</nav>
</header>
<main class="main">
<div class="not-found">404</div>
</main>
<footer class="footer">
<span>© 2024 <a href="https://www.fplanque.net/">fplanque.net [FR]</a></span>
- <a href="/about/contact/">Contact</a>
</footer>
<a href="#top" aria-label="go to top" title="Go to Top (Alt + G)" class="top-link" id="top-link" accesskey="g">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12 6" fill="currentColor">
<path d="M12 6H0l6-6z" />
</svg>
</a>
<script>
let menu = document.getElementById('menu')
if (menu) {
menu.scrollLeft = localStorage.getItem("menu-scroll-position");
menu.onscroll = function () {
localStorage.setItem("menu-scroll-position", menu.scrollLeft);
}
}
document.querySelectorAll('a[href^="#"]').forEach(anchor => {
anchor.addEventListener("click", function (e) {
e.preventDefault();
var id = this.getAttribute("href").substr(1);
if (!window.matchMedia('(prefers-reduced-motion: reduce)').matches) {
document.querySelector(`[id='${decodeURIComponent(id)}']`).scrollIntoView({
behavior: "smooth"
});
} else {
document.querySelector(`[id='${decodeURIComponent(id)}']`).scrollIntoView();
}
if (id === "top") {
history.replaceState(null, null, " ");
} else {
history.pushState(null, null, `#${id}`);
}
});
});
</script>
<script>
var mybutton = document.getElementById("top-link");
window.onscroll = function () {
if (document.body.scrollTop > 800 || document.documentElement.scrollTop > 800) {
mybutton.style.visibility = "visible";
mybutton.style.opacity = "1";
} else {
mybutton.style.visibility = "hidden";
mybutton.style.opacity = "0";
}
};
</script>
<script>
document.getElementById("theme-toggle").addEventListener("click", () => {
if (document.body.className.includes("dark")) {
document.body.classList.remove('dark');
localStorage.setItem("pref-theme", 'light');
} else {
document.body.classList.add('dark');
localStorage.setItem("pref-theme", 'dark');
}
})
</script>
</body>
</html>