<!DOCTYPE html> <html lang="en" dir="ltr" id="top"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="theme-color" content="#3d2163"> <meta property="og:title" content="Changelogs"> <link rel="canonical" href="https://leilukin.com/changelogs/"> <meta name="generator" content="Eleventy v3.0.0"> <meta name="author" content="Leilukin"> <meta name="description" content="Changelogs of my website."> <meta name="fediverse:creator" content="@Leilukin@dragonscave.space"> <meta property="og:site_name" content="Leilukin's Hub"> <meta property="og:type" content="article"> <meta property="og:description" content="Changelogs of my website."> <meta property="og:url" content="https://leilukin.com/changelogs/"> <meta property="og:locale" content="en_MY"> <link rel="alternate" type="application/rss+xml" title="Leilukin's Hub" href="/feed.xml"> <link rel="preload" href="/assets/fonts/lexend/lexend-v19-latin-regular.woff2" as="font" type="font/woff2" crossorigin=""> <link rel="preload" href="/assets/fonts/lexend/lexend-v19-latin-700.woff2" as="font" type="font/woff2" crossorigin=""> <style> @font-face { font-display: swap; font-family: 'Lexend'; font-style: normal; font-weight: 400; src: url('/assets/fonts/lexend/lexend-v19-latin-regular.woff2') format('woff2'); } @font-face { font-display: swap; font-family: 'Lexend'; font-style: normal; font-weight: 700; src: url('/assets/fonts/lexend/lexend-v19-latin-700.woff2') format('woff2'); } </style> <link rel="stylesheet" href="/assets/fonts/fonts.css"> <link rel="stylesheet" href="/assets/css/global.css"><link rel="stylesheet" href="/assets/css/general.css"><link rel="stylesheet" href="/assets/css/content.css"><link rel="stylesheet" href="/assets/css/plugins.css"><link rel="stylesheet" href="/assets/css/components.css"><link rel="stylesheet" href="/assets/css/a11y-syntax-highlighting-dark.css"><link rel="stylesheet" href="/assets/css/pridesymbols.css"><link rel="stylesheet" href="/assets/css/utility.css"> <style>.pagination__wrapper { display: grid; place-content: center; margin-top: 3em; } .pagination { list-style-type: ""; padding: 0; margin: 0; display: flex; gap: 0.5em; flex-wrap: wrap; justify-content: center; } .pagination li { text-align: center; padding: 0.3em 0.7em; color: var(--clr-title-border); background-color: var(--clr-code-bg); } .pagination li:has(a) { background-color: var(--clr-title-border); } .pagination li:has(a):hover { cursor: pointer; background-color: var(--clr-link-hover); } .pagination li:has(a):focus-within { outline: 0.2em solid var(--clr-title-border); outline-offset: 0.15em; } .pagination li a { color: var(--clr-link-btn-hover); text-decoration: none; } .pagination li a:focus { outline: none; } * + h2, * + h3 { margin-top: 1.5em; } .changelog__nav, .changelog__nav--links { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; } .changelog__nav { flex-direction: column; gap: 0.2em; align-self: center; font-weight: 700; gap: 0.5em; } .changelog__nav--links li { text-align: center; align-self: center; } .changelog__nav--links [aria-current="page"] { text-decoration: none; color: var(--clr-bold-txt); } @media (min-width: 640px) { .changelog__nav { flex-direction: row; gap: 1em; } } .breadcrumbs { list-style-type: ""; padding: 0; margin: 0 0 0.7em 0; display: flex; gap: 0.5em; flex-wrap: wrap; justify-content: center; } .breadcrumbs li::after { content: '➔'; padding-left: 0.3em; } .blog__post--pagination { padding-top: 1em; margin-block-start: 2.5em; border-top: 0.1em solid var(--clr-title-border); } .blog__post--nextprev { list-style-type: ""; padding: 0; margin: 0; display: grid; gap: 0.7em; grid-template-columns: repeat(2, 1fr); grid-template-areas: 'prev next'; } .blog__post--prev { grid-area: prev; } .blog__post--next { grid-area: next; } .hero img { filter: drop-shadow(0.1rem 0.1rem 0.2rem black) drop-shadow(0.1rem 0.1rem 0.2rem rgba(30, 30, 30, 0.8)) ; } .hero { width: 100%; background-color: var(--clr-hero-bg); display: flex; flex-direction: column; justify-content: center; text-align: center; } .hero__top-bar { background: var(--clr-navbar-bg); width: 100%; padding: 0.5em 0.7em; } .hero__img { display: grid; place-content: center; } .hero img { object-fit: contain; overflow: hidden; max-height: 16rem; } .navbar { background: var(--clr-navbar-bg); width: 100%; z-index: 998; position: sticky; top: 0; padding: 0.6em; } .navbar__menu { list-style-type: ""; margin: 0; padding: 0; display: flex; gap: 1em; flex-wrap: wrap; text-align: center; } .navbar__menu a { color: var(--clr-navbar-link); text-decoration: none; font-weight: 700; cursor: pointer; display: inline-block; } .navbar__menu a:hover { color: var(--clr-link-hover); } .navbar__menu a:focus { outline-offset: 0.2em; } .navbar__links { display: flex; flex-wrap: wrap; justify-content: space-evenly; gap: 0.5em; } .navbar__toggle { background-color: inherit; color: var(--clr-navbar-link); border: none; padding: 0; font-size: 1.25rem; font-weight: 700; display: none; align-items: center; gap: 0.3em; } .navbar__toggle svg { fill: currentColor; } .navbar__toggle:focus, .navbar__menu a:focus { outline-offset: 0.1em; } .navbar__toggle:focus, .navbar__menu a:focus { outline: 0.15em solid var(--clr-navbar-link); } .navbar__popover { background: var(--clr-navbar-bg); border: 0.15em solid var(--clr-navbar-link); padding: 1.5em; max-width: 85%; } .navbar__popover::backdrop { background-color: black; opacity: 0.5; } @supports selector([popover]) { .navbar__toggle { display: flex; } .navbar__links { display: none; } } /* Tablet screen size */ @media only screen and (min-width: 43.75rem) { .navbar { padding: 1em 0.6em; } .navbar__toggle, .navbar__popover { display: none; } .navbar__links { display: flex; } } .top-btn, .top-btn:hover { color: var(--clr-top-btn-txt); text-decoration: none; font-weight: 700; } .top-btn { position: fixed; bottom: 0.5rem; right: 0.5rem; z-index: 999; background-color: var(--clr-top-btn-bg); display: flex; align-items: center; border-radius: 50em; padding: 0.3em 0.5em; gap: 0.2em; } .top-btn:focus { outline: 0.25em solid var(--clr-top-btn-bg); outline-offset: 0.15em; } .top-btn__arrow { display: inline-block; width: 1em; aspect-ratio: 1 / 1; stroke-width: 0; stroke: currentColor; fill: currentColor; } :root { --footer-gap: 0.5em; } .footer { margin-top: auto; width: 100%; background: var(--clr-main-footer-bg); padding: 1.5rem 1rem clamp(1.5rem, calc(100% - 1.5rem), 3.5rem); text-align: center; display: grid; gap: var(--footer-gap); } .footer__links, .footer__shrines { display: flex; flex-wrap: wrap; justify-content: center; column-gap: var(--footer-gap); } .footer__links { justify-self: center; } .footer__shrines { align-self: center; }</style> <link rel="icon" sizes="32x32" href="/favicon.ico"> <link rel="icon" type="image/svg+xml" href="/assets/favicon/leilukin-bee-favicon.svg"> <link rel="apple-touch-icon" sizes="180x180" href="/assets/favicon/apple-touch-icon.png"> <link rel="manifest" href="/assets/favicon/site.webmanifest"> <link rel="me" href="mailto:contact@leilukin.com"> <link rel="me" href="https://dragonscave.space/@Leilukin"> <link rel="me" href="https://github.com/Leilukin"> <link rel="authorization_endpoint" href="https://indieauth.com/auth"> <script src="/assets/js/D968lGk6J8.js" defer=""></script> <title> Changelogs | Leilukin's Hub </title> </head> <body> <div class="skip-btn"><a href="#content">Skip to content</a></div> <header class="hero"> <div class="hero__top-bar hidden"></div> <div class="hero__img"> <img fetchpriority="high" src="/assets/leilukin/Leilukins-Hub-website-banner.avif" alt="Banner of Leilukin's Hub" width="900" height="300"> </div> </header> <nav class="navbar" aria-labelledby="top-level-nav-title"> <h2 class="visually-hidden" id="top-level-nav-title">Top Level</h2> <ul class="navbar__menu navbar__links"> <li> <a href="/">Home</a> </li> <li> <a href="/about/">About</a> </li> <li> <a href="/now/">Now</a> </li> <li> <a href="/blog/">Blog</a> </li> <li> <a href="/articles/">Articles</a> </li> <li> <a href="/projects/">Projects</a> </li> <li> <a href="/shrines/">Shrines</a> </li> <li> <a href="/adoptables/">Adoptables</a> </li> <li> <a href="/links/">Links</a> </li> <li> <a href="/guestbook/">Guestbook</a> </li> </ul> <button class="navbar__toggle" popovertarget="nav-menu" aria-label="Toggle navigation menu"> <svg aria-hidden="true" focusable="false" width="1em" height="1em" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--!Font Awesome Free 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M0 96C0 78.3 14.3 64 32 64l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 128C14.3 128 0 113.7 0 96zM0 256c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 288c-17.7 0-32-14.3-32-32zM448 416c0 17.7-14.3 32-32 32L32 448c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z"></path></svg> Navigation </button> </nav> <div popover="" id="nav-menu" class="navbar__popover"> <ul class="navbar__menu"> <li> <a href="/">Home</a> </li> <li> <a href="/about/">About</a> </li> <li> <a href="/now/">Now</a> </li> <li> <a href="/blog/">Blog</a> </li> <li> <a href="/articles/">Articles</a> </li> <li> <a href="/projects/">Projects</a> </li> <li> <a href="/shrines/">Shrines</a> </li> <li> <a href="/adoptables/">Adoptables</a> </li> <li> <a href="/links/">Links</a> </li> <li> <a href="/guestbook/">Guestbook</a> </li> </ul> </div> <main id="content"> <header class="main__header"> <h1>Website Changelogs</h1> <p>Changelogs of my website.</p> </header> <content-wrapper> <article class="content"> <nav class="changelog__nav" aria-labelledby="changelog-nav-title"> <p class="changelog__nav--title" id="changelog-nav-title">Changelog Archive:</p> <ul class="inline-nav changelog__nav--links"> <li><a aria-current="page" href="/changelogs">Latest</a></li> <li><a href="/changelogs/2024/">2024</a></li> <li><a href="/changelogs/2023/">2023</a></li> <li><a href="/changelogs/2022/">2022</a></li> <li><a href="/changelogs/layouts/">Website Layouts</a></li> </ul> </nav> <p>To get notified of the updates on this website, you can subscribe to its <a href="/feed.xml"><svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--!Font Awesome Free 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M0 64C0 46.3 14.3 32 32 32c229.8 0 416 186.2 416 416c0 17.7-14.3 32-32 32s-32-14.3-32-32C384 253.6 226.4 96 32 96C14.3 96 0 81.7 0 64zM0 416a64 64 0 1 1 128 0A64 64 0 1 1 0 416zM32 160c159.1 0 288 128.9 288 288c0 17.7-14.3 32-32 32s-32-14.3-32-32c0-123.7-100.3-224-224-224c-17.7 0-32-14.3-32-32s14.3-32 32-32z"></path></svg>RSS feed</a>, which contains new articles, blog posts and website changelogs.</p> <h2>Latest Changelogs</h2> <h3 class="date-style"><time datetime="Tue Dec 10 2024 10:25:01 GMT+0000 (Coordinated Universal Time)">10 December 2024</time></h3> <ul> <li>Obfuscate my email address with CSS and HTTP redirects. (Credit to Spencer Mortensen's article, <a href="https://spencermortensen.com/articles/email-obfuscation/">"Email obfuscation: What works in 2024?"</a>)</li> </ul> <h3 class="date-style"><time datetime="Mon Dec 09 2024 05:07:05 GMT+0000 (Coordinated Universal Time)">9 December 2024</time></h3> <ul> <li>Add table of contents to each tab section of the <a href="/links">Links</a> page.</li> <li>Add link to my <a href="https://www.pixelcatsend.com/profile&id=24121">Pixel Cat's End profile</a> to my <a href="/adoptables">Adoptables</a> page. Free free to check out my not-cats!</li> </ul> <h3 class="date-style"><time datetime="Tue Dec 03 2024 15:53:36 GMT+0000 (Coordinated Universal Time)">3 December 2024</time></h3> <ul> <li>Improve footnotes by enlarging the target area of reference links and footntoe backlinks.</li> <li>Update article <a href="/articles/accessible-footnotes/#update-3-december-2024-enlarge-link-target-area">"How I (Tried to) Implement Accessible Footnotes"</a> with information about improving footnote links' target area.</li> </ul> <h3 class="date-style"><time datetime="Sun Dec 01 2024 05:01:33 GMT+0000 (Coordinated Universal Time)">1 December 2024</time></h3> <ul> <li>New blog post: <a href="/blog/posts/2024-12-01-indieweb-carnival-november-2024-impact">IndieWeb Carnival November 2024: Impact</a></li> </ul> <h3 class="date-style"><time datetime="Wed Nov 20 2024 16:55:40 GMT+0000 (Coordinated Universal Time)">20 November 2024</time></h3> <ul> <li>Officially launch my <a href="/shrines/pokemonoras"><cite>Pokémon Omega Ruby</cite> and <cite>Alpha Sapphire</cite> shrine</a> to celebrate the 10th anniversary of the games' release.</li> </ul> <h3 class="date-style"><time datetime="Tue Nov 19 2024 14:19:00 GMT+0000 (Coordinated Universal Time)">19 November 2024</time></h3> <ul> <li>Expand the home page of my <a href="/shrines/cassettebeasts"><cite>Cassette Beasts</cite> shrine</a> by adding a <a href="/shrines/cassettebeasts/#cassette-beasts-my-ultimate-comfort-media">"<cite>Cassette Beasts</cite> — My Ultimate Comfort Media"</a> section.</li> </ul> <h3 class="date-style"><time datetime="Mon Oct 28 2024 09:17:22 GMT+0000 (Coordinated Universal Time)">28 October 2024</time></h3> <ul> <li>New blog post: <a href="/blog/posts/2024-10-28-re-social-media-personal-blog">"Re: Social Media Hasn't Killed the Personal Blog Just Yet"</a></li> </ul> <h3 class="date-style"><time datetime="Tue Sep 17 2024 05:58:34 GMT+0000 (Coordinated Universal Time)">17 September 2024</time></h3> <ul> <li>Add <a href="/adoptables/#Pantson-Color-Club">Pantson Color Club section</a> to my <a href="/adoptables">adoptables page</a>, including my own colour card for the pixel club.</li> </ul> <h3 class="date-style"><time datetime="Fri Sep 06 2024 15:16:00 GMT+0000 (Coordinated Universal Time)">6 September 2024</time></h3> <ul> <li>Replace the estimated reading time of articles and blog posts with word count, by using the <a href="https://www.npmjs.com/package/eleventy-plugin-wordcount-extended">eleventy-plugin-wordcount-extended</a> plugin.</li> <li>Create 200×40 pixel size version of Leilukin's Hub site button.</li> </ul> <h3 class="date-style"><time datetime="Sun Aug 18 2024 12:33:42 GMT+0000 (Coordinated Universal Time)">18 August 2024</time></h3> <ul> <li>New blog post about me officially becoming a professional web developer, <a href="/blog/posts/2024-08-18-from-hobbyist-to-professional-web-developer">"From Hobbyist to Professional Web Developer"</a>.</li> </ul> <h3 class="date-style"><time datetime="Sun Aug 11 2024 14:46:00 GMT+0000 (Coordinated Universal Time)">11 August 2024</time></h3> <ul> <li>Improve the site's <a href="/feed.xml">RSS feed</a>: <ul> <li>Make RSS feeds <a href="https://blog.jim-nielsen.com/2021/automatically-discoverable-rss-feeds/">automatically discoverable</a> by feed readers</li> <li>Use time and time zone to make feed items' timestamps accurate</li> </ul> </li> </ul> <h3 class="date-style"><time datetime="Tue Aug 06 2024 13:20:00 GMT+0000 (Coordinated Universal Time)">6 August 2024</time></h3> <ul> <li>New article: <a href="/articles/accessible-footnotes">"How I (Tried to) Implement Accessible Footnotes"</a>, which is also my entry for <a href="https://32bit.cafe/">32-Bit Cafe</a>'s <a href="https://32bit.cafe/~xandra/events/codejam5/">Community Code Jam #5: Back to School</a>.</li> </ul> <h3 class="date-style"><time datetime="Fri Aug 02 2024 07:42:00 GMT+0000 (Coordinated Universal Time)">2 August 2024</time></h3> <ul> <li>Added my first publicly released code snippet on this website: <a href="/projects/snippets/disability-pride-flag-background">Responsive Disability Pride Flag CSS Background</a>.</li> </ul> <h3 class="date-style"><time datetime="Fri Jul 26 2024 16:32:00 GMT+0000 (Coordinated Universal Time)">26 July 2024</time></h3> <ul> <li>Leilukin's Hub and all its subsites have been migrated to <a href="https://www.hostinger.my/">Hostinger</a></li> <li>New blog post: <a href="/blog/posts/2024-07-27-hostinger-migration-leilukins-hub">Leilukin's Hub Has Migrated to Hostinger</a></li> <li>Change the theme of <a href="https://tumbleblog.leilukin.com/">Leilukin's Hub Tumbleblog</a> to a custom theme based on the Umbra theme from Chyrp Lite</li> <li>Add a link to contact me via email to the website's footer</li> </ul> <h3 class="date-style"><time datetime="Mon Jul 22 2024 01:35:00 GMT+0000 (Coordinated Universal Time)">22 July 2024</time></h3> <ul> <li>Add a <a href="https://zine.kalechips.net/index">Salad Magazine</a> section to my <a href="/adoptables">Adoptables pages</a>.</li> </ul> <h3 class="date-style"><time datetime="Sun Jul 21 2024 11:24:00 GMT+0000 (Coordinated Universal Time)">21 July 2024</time></h3> <ul> <li>Add a section for the <a href="https://divergentrays.com/kitty">Kitty Friends Pixel Club</a> to my <a href="/adoptables">Adoptables page</a>, including my kitty friends!</li> </ul> <h3 class="date-style"><time datetime="Sat Jul 20 2024 06:35:00 GMT+0000 (Coordinated Universal Time)">20 July 2024</time></h3> <ul> <li>Remake the mobile version of navigation menu by using the HTML <a href="https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/popover"><code>popover</code></a> attirbutes, allowing the navigation menu to be dismissed without JavaScript</li> </ul> <h3 class="date-style"><time datetime="Thu Jul 18 2024 04:55:00 GMT+0000 (Coordinated Universal Time)">18 July 2024</time></h3> <ul> <li>Add list of web cliques I joined to the home page</li> <li>Add pixel cliques I joined to the <a href="/adoptables">Adoptables page</a></li> <li>Add a <a href="/links/#joined">Joined</a> tab to the <a href="/links">Links page</a> to list the web cliques and widgets of web rings I joined, as well as linking to my fanlisting collective.</li> <li>Upgrade Eleventy to version 3.0</li> <li>Bundle page-specific CSS and JavaScript in the <code><head></code> element with Eleventy 3.0's <a href="https://github.com/11ty/eleventy-plugin-bundle">built-in bundle plugin</a></li> </ul> <h3 class="date-style"><time datetime="Sat Jul 13 2024 12:47:00 GMT+0000 (Coordinated Universal Time)">13 July 2024</time></h3> <ul> <li>Add an inline SVG icon to external links</li> <li>Use inline SVG for Font Awesome icons to remove the need of hosting Font Awesome assets</li> <li>Add dark mode support for <a href="/shrines/cassettebeasts"><cite>Cassette Beasts</cite> shrine</a> based on user preference in system setting</li> </ul> <h3 class="date-style"><time datetime="Sat Jul 06 2024 10:45:00 GMT+0000 (Coordinated Universal Time)">6 July 2024</time></h3> <ul> <li>Implement accessible tooltips that meet Web Content Accessibility Guidelines (WCAG) 2.2 success criterion for <a href="https://www.w3.org/WAI/WCAG22/Understanding/content-on-hover-or-focus.html">1.4.13: Content on Hover or Focus (Level AA)</a>, by utilising <a href="https://github.com/scottaohara/a11y_tooltips">Scott O'Hara's ARIA Tooltips</a> script. (Thank you <a href="https://www.groundedwren.com/">Vera</a> for your feedback on my previous implementation of the tooltips)</li> </ul> <nav aria-labelledby="pagination-title" class="pagination__wrapper"> <h2 class="visually-hidden" id="pagination-title">Pagination</h2> <ul class="pagination"> <li> <a href="/changelogs/"> <svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--!Font Awesome Free 6.5.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M41.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 256 246.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-160 160zm352-160l-160 160c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L301.3 256 438.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0z"></path></svg> Newest </a> </li> <li> <svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512"><!--!Font Awesome Free 6.5.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M41.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 256 246.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-160 160z"></path></svg> Newer </li> <li> <a href=" /changelogs/page/2/"> Older <svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512"><!--!Font Awesome Free 6.5.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M278.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-160 160c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L210.7 256 73.4 118.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l160 160z"></path></svg> </a> </li> <li> <a href=" /changelogs/page/7/"> Oldest <svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--!Font Awesome Free 6.5.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M470.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L402.7 256 265.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160zm-352 160l160-160c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L210.7 256 73.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0z"></path></svg> </a> </li> </ul> </nav> </article> </content-wrapper> </main> <footer class="footer"> <p> <svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--!Font Awesome Free 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4L236.8 313.6c11.4 8.5 27 8.5 38.4 0L492.8 150.4c12.1-9.1 19.2-23.3 19.2-38.4c0-26.5-21.5-48-48-48L48 64zM0 176L0 384c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-208L294.4 339.2c-22.8 17.1-54 17.1-76.8 0L0 176z"></path></svg> <a rel="nofollow, noindex" href="/emailme">Contact me by email</a> (<a href="https://useplaintext.email/">plain text email</a> encouraged) </p> <h2 class="visually-hidden">Footer Navigation:</h2> <ul class="inline-nav footer__links"> <li> <a href="/feed.xml"><svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--!Font Awesome Free 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M0 64C0 46.3 14.3 32 32 32c229.8 0 416 186.2 416 416c0 17.7-14.3 32-32 32s-32-14.3-32-32C384 253.6 226.4 96 32 96C14.3 96 0 81.7 0 64zM0 416a64 64 0 1 1 128 0A64 64 0 1 1 0 416zM32 160c159.1 0 288 128.9 288 288c0 17.7-14.3 32-32 32s-32-14.3-32-32c0-123.7-100.3-224-224-224c-17.7 0-32-14.3-32-32s14.3-32 32-32z"></path></svg>RSS Feed</a> </li> <li><a href="/sitemap/ ">Site Map</a></li><li><a aria-current="page" href="/changelogs/">Changelogs</a></li><li><a href="/accessibility/">Accessibility</a></li><li><a href="/colophon/">Colophon</a></li></ul> <p>Made with ♥ by Leilukin since 11 September 2022</p> <p> <svg class="inline-icon" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 640 512"><!--!Font Awesome Free 6.6.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--><path d="M96 64c0-17.7 14.3-32 32-32l320 0 64 0c70.7 0 128 57.3 128 128s-57.3 128-128 128l-32 0c0 53-43 96-96 96l-192 0c-53 0-96-43-96-96L96 64zM480 224l32 0c35.3 0 64-28.7 64-64s-28.7-64-64-64l-32 0 0 128zM32 416l512 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32z"></path></svg> <a href="https://ko-fi.com/leilukin">Support me on Ko-Fi</a> </p><div class="h-card hidden"> <span class="p-name p-nickname">Leilukin</span> <a href="/" class="u-url">Home page</a> <img src="https://i.postimg.cc/RZJgS6tY/leilukin-bee.avif" alt="Leilukin" class="u-photo" loading="lazy"> <span class="p-country-name">Malaysia</span> <span class="p-note">They/she. A proudly queer and autistic <span class="p-gender-identity">non-binary</span> lesbian from Malaysia.</span> </div><a href="#top" class="top-btn"> <svg class="top-btn__arrow" focusable="false" aria-hidden="true" viewBox="0 0 26 28"> <path d="M25.172 15.172c0 0.531-0.219 1.031-0.578 1.406l-1.172 1.172c-0.375 0.375-0.891 0.594-1.422 0.594s-1.047-0.219-1.406-0.594l-4.594-4.578v11c0 1.125-0.938 1.828-2 1.828h-2c-1.062 0-2-0.703-2-1.828v-11l-4.594 4.578c-0.359 0.375-0.875 0.594-1.406 0.594s-1.047-0.219-1.406-0.594l-1.172-1.172c-0.375-0.375-0.594-0.875-0.594-1.406s0.219-1.047 0.594-1.422l10.172-10.172c0.359-0.375 0.875-0.578 1.406-0.578s1.047 0.203 1.422 0.578l10.172 10.172c0.359 0.375 0.578 0.891 0.578 1.422z"></path> </svg> Back to Top </a> </footer> </body> </html>