import { Outlet, Link, createRootRoute, HeadContent, Scripts } from "@tanstack/react-router";
import { SITE } from "@/lib/site";
import appCss from "../styles.css?url";

function NotFoundComponent() {
  return (
    <div className="flex min-h-screen items-center justify-center bg-background px-4">
      <div className="max-w-md text-center">
        <h1 className="text-7xl font-bold text-foreground">404</h1>
        <h2 className="mt-4 text-xl font-semibold">Page not found</h2>
        <p className="mt-2 text-sm text-muted-foreground">
          The page you're looking for doesn't exist or has been moved.
        </p>
        <Link
          to="/"
          className="mt-6 inline-flex items-center justify-center rounded-md bg-gradient-emerald px-4 py-2 text-sm font-semibold text-navy-deep"
        >
          Back home
        </Link>
      </div>
    </div>
  );
}

const description = "WordPress emergency experts. Malware removal, hacked site recovery, bug fixing, speed optimization & maintenance. 5+ years, 100+ sites fixed. Reply in 30 mins.";

export const Route = createRootRoute({
  head: () => ({
    meta: [
      { charSet: "utf-8" },
      { name: "viewport", content: "width=device-width, initial-scale=1" },
      { title: `${SITE.name} — WordPress Malware Removal, Bug Fixing & Speed Experts` },
      { name: "description", content: description },
      { name: "author", content: SITE.legalName },
      { name: "theme-color", content: "#0F1B3D" },
      { property: "og:site_name", content: SITE.name },
      { property: "og:type", content: "website" },
      { property: "og:title", content: `${SITE.name} — Fix Your WordPress Site Fast` },
      { property: "og:description", content: description },
      { name: "twitter:card", content: "summary_large_image" },
      { name: "twitter:title", content: `${SITE.name} — Fix Your WordPress Site Fast` },
      { name: "twitter:description", content: description },
      { title: "Lovable App" },
      { property: "og:title", content: "Lovable App" },
      { name: "twitter:title", content: "Lovable App" },
      { name: "description", content: "Fix WordPress issues with expert services for malware removal, bug fixing, and site recovery." },
      { property: "og:description", content: "Fix WordPress issues with expert services for malware removal, bug fixing, and site recovery." },
      { name: "twitter:description", content: "Fix WordPress issues with expert services for malware removal, bug fixing, and site recovery." },
      { property: "og:image", content: "https://pub-bb2e103a32db4e198524a2e9ed8f35b4.r2.dev/767345c3-f5ab-4e8e-b253-0ebf64486a5c/id-preview-cdb0bb2b--31e1a33b-88b4-4a02-b72d-93ea584ffb33.lovable.app-1777440848972.png" },
      { name: "twitter:image", content: "https://pub-bb2e103a32db4e198524a2e9ed8f35b4.r2.dev/767345c3-f5ab-4e8e-b253-0ebf64486a5c/id-preview-cdb0bb2b--31e1a33b-88b4-4a02-b72d-93ea584ffb33.lovable.app-1777440848972.png" },
    ],
    links: [
      { rel: "stylesheet", href: appCss },
      { rel: "preconnect", href: "https://fonts.googleapis.com" },
      { rel: "preconnect", href: "https://fonts.gstatic.com", crossOrigin: "anonymous" },
      {
        rel: "stylesheet",
        href: "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap",
      },
      { rel: "canonical", href: SITE.url },
    ],
  }),
  shellComponent: RootShell,
  component: RootComponent,
  notFoundComponent: NotFoundComponent,
});

function RootShell({ children }: { children: React.ReactNode }) {
  return (
    <html lang="en">
      <head>
        <HeadContent />
      </head>
      <body>
        {children}
        <Scripts />
      </body>
    </html>
  );
}

function RootComponent() {
  return <Outlet />;
}
