diff --git a/src/components/ui/badge/badge.svelte b/src/components/ui/badge/badge.svelte
new file mode 100644
index 0000000..dac8752
--- /dev/null
+++ b/src/components/ui/badge/badge.svelte
@@ -0,0 +1,35 @@
+
+
+
+
+
+ {@render children?.()}
+
diff --git a/src/components/ui/badge/badge.variants.ts b/src/components/ui/badge/badge.variants.ts
new file mode 100644
index 0000000..cbcf055
--- /dev/null
+++ b/src/components/ui/badge/badge.variants.ts
@@ -0,0 +1,34 @@
+import { tv } from "tailwind-variants";
+
+const badgeVariants = tv({
+ base: "inline-flex items-center cursor-default gap-1.5 font-medium rounded-full border transition-colors hover:text-black dark:hover:text-white ease-in-out",
+ variants: {
+ variant: {
+ default:
+ "bg-neutral-100 text-neutral-800 border-neutral-200 dark:bg-neutral-800 dark:text-neutral-100 dark:border-neutral-700",
+ primary:
+ "bg-neutral-800 text-neutral-50 border-neutral-700 dark:bg-neutral-700 dark:text-neutral-50 dark:border-neutral-600",
+ secondary:
+ "bg-neutral-200 text-neutral-700 border-neutral-300 dark:bg-neutral-700 dark:text-neutral-200 dark:border-neutral-600",
+ success:
+ "bg-green-100 text-green-800 border-green-200 dark:bg-green-900 dark:text-green-100 dark:border-green-800",
+ warning:
+ "bg-amber-100 text-amber-800 border-amber-200 dark:bg-amber-900 dark:text-amber-100 dark:border-amber-800",
+ danger:
+ "bg-red-100 text-red-800 border-red-200 dark:bg-red-900 dark:text-red-100 dark:border-red-800",
+ outline:
+ "bg-transparent border border-neutral-300 text-neutral-700 dark:border-neutral-700 dark:text-neutral-400",
+ },
+ size: {
+ sm: "text-xs px-2 py-0.5",
+ md: "text-sm px-2.5 py-0.5",
+ lg: "text-base px-3 py-1",
+ },
+ },
+ defaultVariants: {
+ variant: "default",
+ size: "sm",
+ },
+});
+
+export { badgeVariants };
diff --git a/src/components/ui/badge/index.ts b/src/components/ui/badge/index.ts
new file mode 100644
index 0000000..36c78f7
--- /dev/null
+++ b/src/components/ui/badge/index.ts
@@ -0,0 +1,2 @@
+export { default as Badge } from "./badge.svelte";
+export { badgeVariants } from "./badge.variants";