"use client"; import { useLayoutEffect, useState } from "react"; const THEME_KEY = "novarix-theme"; type Theme = "light" | "dark"; function applyTheme(theme: Theme) { document.documentElement.dataset.theme = theme; document.documentElement.style.colorScheme = theme; } export default function ThemeToggle({ className = "", }: { className?: string; }) { const [theme, setTheme] = useState("light"); useLayoutEffect(() => { const current = document.documentElement.dataset.theme === "dark" ? "dark" : "light"; setTheme(current); }, []); function toggleTheme() { const nextTheme: Theme = theme === "dark" ? "light" : "dark"; setTheme(nextTheme); applyTheme(nextTheme); try { window.localStorage.setItem(THEME_KEY, nextTheme); } catch { /* storage unavailable — silently ignore */ } } return ( ); }