Building a dark/light theme toggle in Astro
CSS custom properties, localStorage persistence, and no flash of wrong theme
How this blog's theme toggle works — a data-theme attribute on the root element, CSS custom properties for every colour, an icon-triggered dropdown for System/Light/Dark selection, and a synchronous inline script to prevent the flash of wrong theme on load.
Read Post