import { useEffect, useState } from "react"; /** * Responsive breakpoint hook. Returns true when the media query matches. * SSR-safe: defaults to false if window is undefined. */ export function useMediaQuery(query: string): boolean { const [matches, setMatches] = useState(() => { if (typeof window === "undefined") return false; return window.matchMedia(query).matches; }); useEffect(() => { if (typeof window === "undefined") return; const mediaQueryList = window.matchMedia(query); setMatches(mediaQueryList.matches); const handler = (event: MediaQueryListEvent) => { setMatches(event.matches); }; mediaQueryList.addEventListener("change", handler); return () => { mediaQueryList.removeEventListener("change", handler); }; }, [query]); return matches; }