diff --git a/README.md b/README.md
index e215bc4..08e6c51 100644
--- a/README.md
+++ b/README.md
@@ -1,8 +1,31 @@
-This is a [Next.js](https://nextjs.org) project bootstrapped with [`create-next-app`](https://nextjs.org/docs/app/api-reference/cli/create-next-app).
+# Nicholai's website
-## Getting Started
+This is my personal website built with Next.js 15, Tailwind CSS, and TypeScript.
-First, run the development server:
+## Tech Stack
+
+Next.js 15, Tailwind CSS, Cabin font family, Turbopack, Typescript.
+
+### Prerequisites
+
+- Node.js 18+ installed (node modules: densest thing in the known universe.)
+- npm, yarn, pnpm, whatever honestly.
+
+### Installation
+
+1. Clone the repository:
+```bash
+git clone https://git.biohazardvfx.com/Nicholai/nicholais-website.git
+```
+
+2. Install dependencies:
+```bash
+npm install
+```
+
+### Development
+
+Run the development server:
```bash
npm run dev
@@ -16,21 +39,21 @@ bun dev
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
-You can start editing the page by modifying `app/page.tsx`. The page auto-updates as you edit the file.
+### Building for Production
-This project uses [`next/font`](https://nextjs.org/docs/app/building-your-application/optimizing/fonts) to automatically optimize and load [Geist](https://vercel.com/font), a new font family for Vercel.
+```bash
+npm run build
+```
-## Learn More
+### Deployment
-To learn more about Next.js, take a look at the following resources:
+## License
-- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
-- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
+This project is open source, take it. I don't give a fuck. I am not your dad.
-You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js) - your feedback and contributions are welcome!
+## Author
-## Deploy on Vercel
-
-The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js.
-
-Check out our [Next.js deployment documentation](https://nextjs.org/docs/app/building-your-application/deploying) for more details.
+Nicholai - VFX Supervisor & Developer
+- Website: [nicholai.work](https://nicholai.work)
+- Email: nicholai@biohazardvfx.com
+- Instagram: [@nicholai.exe](https://www.instagram.com/nicholai.exe/)
diff --git a/app/components/dotbackground.tsx b/app/components/dotbackground.tsx
new file mode 100644
index 0000000..2f70476
--- /dev/null
+++ b/app/components/dotbackground.tsx
@@ -0,0 +1,21 @@
+import { cn } from "@/lib/utils"
+
+export function DotBackground({ className }: { className?: string }) {
+ return (
+
+
+ {/* Radial gradient for the container to give a faded look */}
+
+
+
+ )
}
diff --git a/components/ui/flip-words.tsx b/components/ui/flip-words.tsx
new file mode 100644
index 0000000..4b347d2
--- /dev/null
+++ b/components/ui/flip-words.tsx
@@ -0,0 +1,98 @@
+"use client";
+import React, { useCallback, useEffect, useState } from "react";
+import { AnimatePresence, motion } from "motion/react";
+import { cn } from "@/lib/utils";
+
+export const FlipWords = ({
+ words,
+ duration = 3000,
+ className,
+}: {
+ words: string[];
+ duration?: number;
+ className?: string;
+}) => {
+ const [currentWord, setCurrentWord] = useState(words[0]);
+ const [isAnimating, setIsAnimating] = useState(false);
+
+ // thanks for the fix Julian - https://github.com/Julian-AT
+ const startAnimation = useCallback(() => {
+ const word = words[words.indexOf(currentWord) + 1] || words[0];
+ setCurrentWord(word);
+ setIsAnimating(true);
+ }, [currentWord, words]);
+
+ useEffect(() => {
+ if (!isAnimating)
+ setTimeout(() => {
+ startAnimation();
+ }, duration);
+ }, [isAnimating, duration, startAnimation]);
+
+ return (
+ {
+ setIsAnimating(false);
+ }}
+ >
+
+ {/* edit suggested by Sajal: https://x.com/DewanganSajal */}
+ {currentWord.split(" ").map((word, wordIndex) => (
+
+ {word.split("").map((letter, letterIndex) => (
+
+ {letter}
+
+ ))}
+
+
+ ))}
+
+
+ );
+};
diff --git a/lib/utils.ts b/lib/utils.ts
new file mode 100644
index 0000000..cec6ac9
--- /dev/null
+++ b/lib/utils.ts
@@ -0,0 +1,6 @@
+import { ClassValue, clsx } from "clsx";
+import { twMerge } from "tailwind-merge";
+
+export function cn(...inputs: ClassValue[]) {
+ return twMerge(clsx(inputs));
+}
diff --git a/package-lock.json b/package-lock.json
index 8b4afd4..54a785b 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -8,9 +8,12 @@
"name": "framer-nextjs-example",
"version": "0.1.0",
"dependencies": {
+ "clsx": "^2.1.1",
+ "motion": "^12.23.12",
"next": "15.5.2",
"react": "19.1.0",
- "react-dom": "19.1.0"
+ "react-dom": "19.1.0",
+ "tailwind-merge": "^3.3.1"
},
"devDependencies": {
"@eslint/eslintrc": "^3",
@@ -2297,6 +2300,15 @@
"integrity": "sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA==",
"license": "MIT"
},
+ "node_modules/clsx": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz",
+ "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
"node_modules/color": {
"version": "4.2.3",
"resolved": "https://registry.npmjs.org/color/-/color-4.2.3.tgz",
@@ -3309,6 +3321,33 @@
"url": "https://github.com/sponsors/ljharb"
}
},
+ "node_modules/framer-motion": {
+ "version": "12.23.12",
+ "resolved": "https://registry.npmjs.org/framer-motion/-/framer-motion-12.23.12.tgz",
+ "integrity": "sha512-6e78rdVtnBvlEVgu6eFEAgG9v3wLnYEboM8I5O5EXvfKC8gxGQB8wXJdhkMy10iVcn05jl6CNw7/HTsTCfwcWg==",
+ "license": "MIT",
+ "dependencies": {
+ "motion-dom": "^12.23.12",
+ "motion-utils": "^12.23.6",
+ "tslib": "^2.4.0"
+ },
+ "peerDependencies": {
+ "@emotion/is-prop-valid": "*",
+ "react": "^18.0.0 || ^19.0.0",
+ "react-dom": "^18.0.0 || ^19.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@emotion/is-prop-valid": {
+ "optional": true
+ },
+ "react": {
+ "optional": true
+ },
+ "react-dom": {
+ "optional": true
+ }
+ }
+ },
"node_modules/function-bind": {
"version": "1.1.2",
"resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
@@ -4581,6 +4620,47 @@
"url": "https://github.com/sponsors/isaacs"
}
},
+ "node_modules/motion": {
+ "version": "12.23.12",
+ "resolved": "https://registry.npmjs.org/motion/-/motion-12.23.12.tgz",
+ "integrity": "sha512-8jCD8uW5GD1csOoqh1WhH1A6j5APHVE15nuBkFeRiMzYBdRwyAHmSP/oXSuW0WJPZRXTFdBoG4hY9TFWNhhwng==",
+ "license": "MIT",
+ "dependencies": {
+ "framer-motion": "^12.23.12",
+ "tslib": "^2.4.0"
+ },
+ "peerDependencies": {
+ "@emotion/is-prop-valid": "*",
+ "react": "^18.0.0 || ^19.0.0",
+ "react-dom": "^18.0.0 || ^19.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@emotion/is-prop-valid": {
+ "optional": true
+ },
+ "react": {
+ "optional": true
+ },
+ "react-dom": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/motion-dom": {
+ "version": "12.23.12",
+ "resolved": "https://registry.npmjs.org/motion-dom/-/motion-dom-12.23.12.tgz",
+ "integrity": "sha512-RcR4fvMCTESQBD/uKQe49D5RUeDOokkGRmz4ceaJKDBgHYtZtntC/s2vLvY38gqGaytinij/yi3hMcWVcEF5Kw==",
+ "license": "MIT",
+ "dependencies": {
+ "motion-utils": "^12.23.6"
+ }
+ },
+ "node_modules/motion-utils": {
+ "version": "12.23.6",
+ "resolved": "https://registry.npmjs.org/motion-utils/-/motion-utils-12.23.6.tgz",
+ "integrity": "sha512-eAWoPgr4eFEOFfg2WjIsMoqJTW6Z8MTUCgn/GZ3VRpClWBdnbjryiA3ZSNLyxCTmCQx4RmYX6jX1iWHbenUPNQ==",
+ "license": "MIT"
+ },
"node_modules/ms": {
"version": "2.1.3",
"resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
@@ -5689,6 +5769,16 @@
"url": "https://github.com/sponsors/ljharb"
}
},
+ "node_modules/tailwind-merge": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/tailwind-merge/-/tailwind-merge-3.3.1.tgz",
+ "integrity": "sha512-gBXpgUm/3rp1lMZZrM/w7D8GKqshif0zAymAhbCyIt8KMe+0v9DQ7cdYLR4FHH/cKpdTXb+A/tKKU3eolfsI+g==",
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/dcastil"
+ }
+ },
"node_modules/tailwindcss": {
"version": "4.1.13",
"resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-4.1.13.tgz",
diff --git a/package.json b/package.json
index 23935d0..9548f93 100644
--- a/package.json
+++ b/package.json
@@ -9,19 +9,22 @@
"lint": "eslint"
},
"dependencies": {
+ "clsx": "^2.1.1",
+ "motion": "^12.23.12",
+ "next": "15.5.2",
"react": "19.1.0",
"react-dom": "19.1.0",
- "next": "15.5.2"
+ "tailwind-merge": "^3.3.1"
},
"devDependencies": {
- "typescript": "^5",
+ "@eslint/eslintrc": "^3",
+ "@tailwindcss/postcss": "^4",
"@types/node": "^20",
"@types/react": "^19",
"@types/react-dom": "^19",
- "@tailwindcss/postcss": "^4",
- "tailwindcss": "^4",
"eslint": "^9",
"eslint-config-next": "15.5.2",
- "@eslint/eslintrc": "^3"
+ "tailwindcss": "^4",
+ "typescript": "^5"
}
}
diff --git a/public/Fonts/Cabin-Italic-VariableFont_wdth,wght.ttf b/public/Fonts/Cabin-Italic-VariableFont_wdth,wght.ttf
new file mode 100644
index 0000000..a87333f
Binary files /dev/null and b/public/Fonts/Cabin-Italic-VariableFont_wdth,wght.ttf differ
diff --git a/public/Fonts/Cabin-VariableFont_wdth,wght.ttf b/public/Fonts/Cabin-VariableFont_wdth,wght.ttf
new file mode 100644
index 0000000..0558964
Binary files /dev/null and b/public/Fonts/Cabin-VariableFont_wdth,wght.ttf differ
diff --git a/public/Fonts/OFL.txt b/public/Fonts/OFL.txt
new file mode 100644
index 0000000..a1023c0
--- /dev/null
+++ b/public/Fonts/OFL.txt
@@ -0,0 +1,93 @@
+Copyright 2018 The Cabin Project Authors (https://github.com/impallari/Cabin.git)
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+https://openfontlicense.org
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/public/Fonts/README.txt b/public/Fonts/README.txt
new file mode 100644
index 0000000..13696d7
--- /dev/null
+++ b/public/Fonts/README.txt
@@ -0,0 +1,88 @@
+Cabin Variable Font
+===================
+
+This download contains Cabin as both variable fonts and static fonts.
+
+Cabin is a variable font with these axes:
+ wdth
+ wght
+
+This means all the styles are contained in these files:
+ Cabin-VariableFont_wdth,wght.ttf
+ Cabin-Italic-VariableFont_wdth,wght.ttf
+
+If your app fully supports variable fonts, you can now pick intermediate styles
+that aren’t available as static fonts. Not all apps support variable fonts, and
+in those cases you can use the static font files for Cabin:
+ static/Cabin_Condensed-Regular.ttf
+ static/Cabin_Condensed-Medium.ttf
+ static/Cabin_Condensed-SemiBold.ttf
+ static/Cabin_Condensed-Bold.ttf
+ static/Cabin_SemiCondensed-Regular.ttf
+ static/Cabin_SemiCondensed-Medium.ttf
+ static/Cabin_SemiCondensed-SemiBold.ttf
+ static/Cabin_SemiCondensed-Bold.ttf
+ static/Cabin-Regular.ttf
+ static/Cabin-Medium.ttf
+ static/Cabin-SemiBold.ttf
+ static/Cabin-Bold.ttf
+ static/Cabin_Condensed-Italic.ttf
+ static/Cabin_Condensed-MediumItalic.ttf
+ static/Cabin_Condensed-SemiBoldItalic.ttf
+ static/Cabin_Condensed-BoldItalic.ttf
+ static/Cabin_SemiCondensed-Italic.ttf
+ static/Cabin_SemiCondensed-MediumItalic.ttf
+ static/Cabin_SemiCondensed-SemiBoldItalic.ttf
+ static/Cabin_SemiCondensed-BoldItalic.ttf
+ static/Cabin-Italic.ttf
+ static/Cabin-MediumItalic.ttf
+ static/Cabin-SemiBoldItalic.ttf
+ static/Cabin-BoldItalic.ttf
+
+Get started
+-----------
+
+1. Install the font files you want to use
+
+2. Use your app's font picker to view the font family and all the
+available styles
+
+Learn more about variable fonts
+-------------------------------
+
+ https://developers.google.com/web/fundamentals/design-and-ux/typography/variable-fonts
+ https://variablefonts.typenetwork.com
+ https://medium.com/variable-fonts
+
+In desktop apps
+
+ https://theblog.adobe.com/can-variable-fonts-illustrator-cc
+ https://helpx.adobe.com/nz/photoshop/using/fonts.html#variable_fonts
+
+Online
+
+ https://developers.google.com/fonts/docs/getting_started
+ https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Fonts/Variable_Fonts_Guide
+ https://developer.microsoft.com/en-us/microsoft-edge/testdrive/demos/variable-fonts
+
+Installing fonts
+
+ MacOS: https://support.apple.com/en-us/HT201749
+ Linux: https://www.google.com/search?q=how+to+install+a+font+on+gnu%2Blinux
+ Windows: https://support.microsoft.com/en-us/help/314960/how-to-install-or-remove-a-font-in-windows
+
+Android Apps
+
+ https://developers.google.com/fonts/docs/android
+ https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts
+
+License
+-------
+Please read the full license text (OFL.txt) to understand the permissions,
+restrictions and requirements for usage, redistribution, and modification.
+
+You can use them in your products & projects – print or digital,
+commercial or otherwise.
+
+This isn't legal advice, please consider consulting a lawyer and see the full
+license for all details.
diff --git a/public/Fonts/static/Cabin-Bold.ttf b/public/Fonts/static/Cabin-Bold.ttf
new file mode 100644
index 0000000..212cbf0
Binary files /dev/null and b/public/Fonts/static/Cabin-Bold.ttf differ
diff --git a/public/Fonts/static/Cabin-BoldItalic.ttf b/public/Fonts/static/Cabin-BoldItalic.ttf
new file mode 100644
index 0000000..fda655a
Binary files /dev/null and b/public/Fonts/static/Cabin-BoldItalic.ttf differ
diff --git a/public/Fonts/static/Cabin-Italic.ttf b/public/Fonts/static/Cabin-Italic.ttf
new file mode 100644
index 0000000..1c4223f
Binary files /dev/null and b/public/Fonts/static/Cabin-Italic.ttf differ
diff --git a/public/Fonts/static/Cabin-Medium.ttf b/public/Fonts/static/Cabin-Medium.ttf
new file mode 100644
index 0000000..875f483
Binary files /dev/null and b/public/Fonts/static/Cabin-Medium.ttf differ
diff --git a/public/Fonts/static/Cabin-MediumItalic.ttf b/public/Fonts/static/Cabin-MediumItalic.ttf
new file mode 100644
index 0000000..de731aa
Binary files /dev/null and b/public/Fonts/static/Cabin-MediumItalic.ttf differ
diff --git a/public/Fonts/static/Cabin-Regular.ttf b/public/Fonts/static/Cabin-Regular.ttf
new file mode 100644
index 0000000..b56dba9
Binary files /dev/null and b/public/Fonts/static/Cabin-Regular.ttf differ
diff --git a/public/Fonts/static/Cabin-SemiBold.ttf b/public/Fonts/static/Cabin-SemiBold.ttf
new file mode 100644
index 0000000..ec8c764
Binary files /dev/null and b/public/Fonts/static/Cabin-SemiBold.ttf differ
diff --git a/public/Fonts/static/Cabin-SemiBoldItalic.ttf b/public/Fonts/static/Cabin-SemiBoldItalic.ttf
new file mode 100644
index 0000000..24f6d84
Binary files /dev/null and b/public/Fonts/static/Cabin-SemiBoldItalic.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-Bold.ttf b/public/Fonts/static/Cabin_Condensed-Bold.ttf
new file mode 100644
index 0000000..a3f85d6
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-Bold.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-BoldItalic.ttf b/public/Fonts/static/Cabin_Condensed-BoldItalic.ttf
new file mode 100644
index 0000000..fb515c3
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-BoldItalic.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-Italic.ttf b/public/Fonts/static/Cabin_Condensed-Italic.ttf
new file mode 100644
index 0000000..c70cf5a
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-Italic.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-Medium.ttf b/public/Fonts/static/Cabin_Condensed-Medium.ttf
new file mode 100644
index 0000000..90664c6
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-Medium.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-MediumItalic.ttf b/public/Fonts/static/Cabin_Condensed-MediumItalic.ttf
new file mode 100644
index 0000000..eb3b6a2
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-MediumItalic.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-Regular.ttf b/public/Fonts/static/Cabin_Condensed-Regular.ttf
new file mode 100644
index 0000000..3d4c802
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-Regular.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-SemiBold.ttf b/public/Fonts/static/Cabin_Condensed-SemiBold.ttf
new file mode 100644
index 0000000..de849d4
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-SemiBold.ttf differ
diff --git a/public/Fonts/static/Cabin_Condensed-SemiBoldItalic.ttf b/public/Fonts/static/Cabin_Condensed-SemiBoldItalic.ttf
new file mode 100644
index 0000000..3cebb4b
Binary files /dev/null and b/public/Fonts/static/Cabin_Condensed-SemiBoldItalic.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-Bold.ttf b/public/Fonts/static/Cabin_SemiCondensed-Bold.ttf
new file mode 100644
index 0000000..27b9795
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-Bold.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-BoldItalic.ttf b/public/Fonts/static/Cabin_SemiCondensed-BoldItalic.ttf
new file mode 100644
index 0000000..48dfd54
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-BoldItalic.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-Italic.ttf b/public/Fonts/static/Cabin_SemiCondensed-Italic.ttf
new file mode 100644
index 0000000..17ed9c7
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-Italic.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-Medium.ttf b/public/Fonts/static/Cabin_SemiCondensed-Medium.ttf
new file mode 100644
index 0000000..6cabe31
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-Medium.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-MediumItalic.ttf b/public/Fonts/static/Cabin_SemiCondensed-MediumItalic.ttf
new file mode 100644
index 0000000..3559303
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-MediumItalic.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-Regular.ttf b/public/Fonts/static/Cabin_SemiCondensed-Regular.ttf
new file mode 100644
index 0000000..440d345
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-Regular.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-SemiBold.ttf b/public/Fonts/static/Cabin_SemiCondensed-SemiBold.ttf
new file mode 100644
index 0000000..e3eccd2
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-SemiBold.ttf differ
diff --git a/public/Fonts/static/Cabin_SemiCondensed-SemiBoldItalic.ttf b/public/Fonts/static/Cabin_SemiCondensed-SemiBoldItalic.ttf
new file mode 100644
index 0000000..a7fb87d
Binary files /dev/null and b/public/Fonts/static/Cabin_SemiCondensed-SemiBoldItalic.ttf differ
diff --git a/public/favicon.ico b/public/favicon.ico
new file mode 100644
index 0000000..3faac08
Binary files /dev/null and b/public/favicon.ico differ
diff --git a/public/favicon.ico~ b/public/favicon.ico~
new file mode 100644
index 0000000..b466f8d
Binary files /dev/null and b/public/favicon.ico~ differ
diff --git a/public/file.svg b/public/file.svg
deleted file mode 100644
index 004145c..0000000
--- a/public/file.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/public/globe.svg b/public/globe.svg
deleted file mode 100644
index 567f17b..0000000
--- a/public/globe.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/public/images/profile.jpg b/public/images/profile.jpg
new file mode 100644
index 0000000..79ab0b5
Binary files /dev/null and b/public/images/profile.jpg differ
diff --git a/public/next.svg b/public/next.svg
deleted file mode 100644
index 5174b28..0000000
--- a/public/next.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/public/vercel.svg b/public/vercel.svg
deleted file mode 100644
index 7705396..0000000
--- a/public/vercel.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/public/window.svg b/public/window.svg
deleted file mode 100644
index b2b2a44..0000000
--- a/public/window.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file