diff --git a/app/[locale]/page.tsx b/app/[locale]/page.tsx
index e972950..6d46aef 100644
--- a/app/[locale]/page.tsx
+++ b/app/[locale]/page.tsx
@@ -1,6 +1,32 @@
+import { useTranslations } from "next-intl";
+import { TypographyH1, TypographyLead } from "../../components/ui/typography";
+import { Badge } from "../../components/ui/badge";
+import { MapPin } from "lucide-react";
+import Image from "next/image";
+
export default function Home() {
+ const t = useTranslations();
+
return (
-
+
+
+ {t('landingPage.title')}
+ {t('landingPage.subtitle')}
+
+
+ {t('landingPage.location')}
+
+
+
);
}
diff --git a/components/ui/badge.tsx b/components/ui/badge.tsx
new file mode 100644
index 0000000..f428bc5
--- /dev/null
+++ b/components/ui/badge.tsx
@@ -0,0 +1,49 @@
+import * as React from "react"
+import { cva, type VariantProps } from "class-variance-authority"
+import { Slot } from "radix-ui"
+
+import { cn } from "@/lib/utils"
+
+const badgeVariants = cva(
+ "group/badge inline-flex h-5 w-fit shrink-0 items-center justify-center gap-1 overflow-hidden rounded-4xl border border-transparent px-2 py-0.5 text-xs font-medium whitespace-nowrap transition-all focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 has-data-[icon=inline-end]:pr-1.5 has-data-[icon=inline-start]:pl-1.5 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 [&>svg]:pointer-events-none [&>svg]:size-3!",
+ {
+ variants: {
+ variant: {
+ default: "bg-primary text-primary-foreground [a]:hover:bg-primary/80",
+ secondary:
+ "bg-secondary text-secondary-foreground [a]:hover:bg-secondary/80",
+ destructive:
+ "bg-destructive/10 text-destructive focus-visible:ring-destructive/20 dark:bg-destructive/20 dark:focus-visible:ring-destructive/40 [a]:hover:bg-destructive/20",
+ outline:
+ "border-border bg-input/30 text-foreground [a]:hover:bg-muted [a]:hover:text-muted-foreground",
+ ghost:
+ "hover:bg-muted hover:text-muted-foreground dark:hover:bg-muted/50",
+ link: "text-primary underline-offset-4 hover:underline",
+ },
+ },
+ defaultVariants: {
+ variant: "default",
+ },
+ }
+)
+
+function Badge({
+ className,
+ variant = "default",
+ asChild = false,
+ ...props
+}: React.ComponentProps<"span"> &
+ VariantProps
& { asChild?: boolean }) {
+ const Comp = asChild ? Slot.Root : "span"
+
+ return (
+
+ )
+}
+
+export { Badge, badgeVariants }
diff --git a/components/ui/typography.tsx b/components/ui/typography.tsx
new file mode 100644
index 0000000..9955d87
--- /dev/null
+++ b/components/ui/typography.tsx
@@ -0,0 +1,25 @@
+import React from "react";
+
+export function TypographyH1({children}: { children: React.ReactNode}) {
+ return (
+
+ {children}
+
+ )
+}
+
+export function TypographyH3({children}: { children: React.ReactNode}) {
+ return (
+
+ {children}
+
+ )
+}
+
+export function TypographyLead({children}: { children: React.ReactNode}) {
+ return (
+
+ {children}
+
+ )
+}
\ No newline at end of file
diff --git a/messages/de.json b/messages/de.json
index 88cfa4a..7404256 100644
--- a/messages/de.json
+++ b/messages/de.json
@@ -12,5 +12,10 @@
"light": "Hell",
"dark": "Dunkel",
"system": "System"
+ },
+ "landingPage": {
+ "title": "Hi, ich bin Nico Haider.",
+ "subtitle": "Softwareentwickler für Webseiten, Web-Apps, Mobile-Apps, Desktop-Apps und vieles mehr.",
+ "location": "Dobersberg, Niederösterreich"
}
}
diff --git a/public/me.png b/public/me.png
new file mode 100644
index 0000000..9dc1ad1
Binary files /dev/null and b/public/me.png differ