+ Hilbish is configured and scripted in the Lua programming language.
+ This removes all the old, ugly things about Shell script and introduces
+ everything good about Lua, including other languages (Moonscript & Fennel).
+
+ Hilbish offers a bunch of features to make your interactive
+ shell experience rich. Things like syntax highlighting and hinting
+ available via the Lua API.
+
+
* Command hints shown in photo are not default.
+
+
+
+
+
+
+
+
+
+
+
+
Why not just Lua?
+
+ Hilbish is your interactive shell as well as a just a Lua interpreter
+ and enhanced REPL.
+
+
+
Batteries included Lua runtime that's also your user shell!
+
Hilbish is easily cross platform. It has OS agnostic interfaces for easy cross platform Lua code.
+
+
+
+
+
Try It Today!
+
+ Hilbish is known to run on the 3 major platforms (Windows, MacOS, Linux)
+ but likely builds on other Unixes!
+
+ Windows doesn't work as well as it should, so if you're a Windows user,
+ say something!
+
+
diff --git a/website/content/docs/_index.md b/website/content/docs/_index.md
new file mode 100644
index 0000000..4f30ab3
--- /dev/null
+++ b/website/content/docs/_index.md
@@ -0,0 +1,19 @@
+---
+title: Introduction
+layout: doc
+weight: -1
+menu: docs
+---
+
+Here lies the documentation for Hilbish, the hyper extensible Lua shell.
+Hilbish provides you with a few quality of life features and useful
+functions to ensure you can make the shell fully yours.
+
+These features include:
+- Completion and history search menus
+- Hinting and syntax highlighting (scripted by user)
+
+# Installation
+Steps on installing Hilbish will be at the Install page in the navigation bar
+at the top. This also included getting development builds from the GitHub
+repository.
diff --git a/website/content/docs/faq.md b/website/content/docs/faq.md
new file mode 100644
index 0000000..d5cd1a2
--- /dev/null
+++ b/website/content/docs/faq.md
@@ -0,0 +1,25 @@
+---
+title: Frequently Asked Questions
+layout: doc
+weight: -20
+menu: docs
+---
+
+# Is Hilbish POSIX compliant?
+No, it is not. POSIX compliance is a non-goal. Perhaps in the future,
+someone would be able to write a native plugin to support shell scripting
+(which would be against it's main goal, but ....)
+
+# Windows Support?
+It compiles for Windows (CI ensures it does), but otherwise it is not
+directly supported. If you'd like to improve this situation,
+checkout [the discussion](https://github.com/Rosettea/Hilbish/discussions/165).
+
+# Where is the API documentation?
+The builtin `doc` command supplies all documentation of Hilbish provided
+APIs. This will be on the website in the near future.
+
+# Why?
+Hilbish emerged from the desire of a Lua configured shell.
+It was the initial reason that it was created, but now it's more:
+to be hyper extensible, simpler and more user friendly.
diff --git a/website/content/docs/features/_index.md b/website/content/docs/features/_index.md
new file mode 100644
index 0000000..0e14346
--- /dev/null
+++ b/website/content/docs/features/_index.md
@@ -0,0 +1,11 @@
+---
+title: Features
+layout: doc
+weight: -40
+menu: docs
+---
+
+Hilbish has a wide range of features to enhance the user's experience and
+is always adding new ones. If there is something missing here or something
+you would like to see, please [start a discussion](https://github.com/Rosettea/Hilbish/discussions)
+or comment on any existing ones which match your request.
diff --git a/website/content/docs/features/runner-mode.md b/website/content/docs/features/runner-mode.md
new file mode 100644
index 0000000..87ecc8b
--- /dev/null
+++ b/website/content/docs/features/runner-mode.md
@@ -0,0 +1,17 @@
+---
+title: Runner Mode
+description: Customize the interactive script/command runner.
+layout: doc
+menu:
+ docs:
+ parent: "Features"
+---
+
+Hilbish allows you to change how interactive text can be interpreted.
+This is mainly due to the fact that the default method Hilbish uses
+is that it runs Lua first and then falls back to shell script.
+
+In some cases, someone might want to switch to just shell script to avoid
+it while interactive but still have a Lua config, or go full Lua to use
+Hilbish as a REPL. This also allows users to add alternative languages,
+instead of either like Fennel.
diff --git a/website/content/docs/getting-started.md b/website/content/docs/getting-started.md
new file mode 100644
index 0000000..f0fe56d
--- /dev/null
+++ b/website/content/docs/getting-started.md
@@ -0,0 +1,59 @@
+---
+title: Getting Started
+layout: doc
+weight: -10
+menu: docs
+---
+
+To start Hilbish, open a terminal. If Hilbish has been installed and is not the
+default shell, you can simply run `hilbish` to start it. This will launch
+a normal interactive session.
+To exit, you can either run the `exit` command or hit Ctrl+D.
+
+# Setting as Default
+## Login shell
+There are a few ways to make Hilbish your default shell. A simple way is
+to make it your user/login shell.
+
+{{< warning `It is not recommended to set Hilbish as your login shell. That is expected to be a
+POSIX compliant shell, which Hilbish is not. At most, there will just be a
+few variables missing in your environment` >}}
+
+To do that, simply run `chsh -s /usr/bin/hilbish`.
+Some distros (namely Fedora) might have `lchsh` instead, which is used like `lchsh `.
+When prompted, you can put the path for Hilbish.
+
+## Default with terminal
+The simpler way is to set the default shell for your terminal. The way of
+doing this depends on how your terminal settings are configured.
+
+## Run after login shell
+Some shells (like zsh) have an rc file, like `.zlogin`, which is ran when the shell session
+is a login shell. In that file, you can run Hilbish. Example:
+
+```
+exec hilbish -S -l
+```
+
+This will replace the shell with Hilbish, set $SHELL to Hilbish and launch it as a login shell.
+
+# Configuration
+Once installation and setup has been done, you can then configure Hilbish.
+It is configured and scripted via Lua, so the config file is a Lua file.
+You can use any pure Lua library to do whatever you want.
+
+Hilbish's sample configuration is usually located in `hilbish.dataDir .. '/.hilbishrc.lua'`.
+You can print that path via Lua to see what it is: `print(hilbish.dataDir .. '/.hilbishrc.lua')`.
+As an example, it will usually will result in `/usr/share/hilbish/.hilbishrc.lua` on Linux.
+
+To edit your user configuration, you can copy that file to `hilbish.userDir.config .. '/hilbish/init.lua'`,
+which follows XDG on Linux and MacOS, and is located in %APPDATA% on Windows.
+
+As the directory is usually `~/.config` on Linux, you can run this command to copy it:
+`cp /usr/share/hilbish/.hilbishrc.lua ~/.config/hilbish/init.lua`
+
+Now you can get to editing it. Since it's just a Lua file, having basic
+knowledge of Lua would help. All of Lua's standard libraries and functions
+from Lua 5.4 are available. Hilbish has some custom and modules that are
+available. To see them, you can run the `doc` command. This also works as
+general documentation for other things.
diff --git a/website/content/install.md b/website/content/install.md
new file mode 100644
index 0000000..731b8c0
--- /dev/null
+++ b/website/content/install.md
@@ -0,0 +1,38 @@
+---
+title: Install
+description: Steps on how to install Hilbish on all the OSes and distros supported.
+layout: page
+---
+
+## Official Binaries
+The best way to get Hilbish is to get a build directly from GitHub.
+At any time, there are 2 versions of Hilbish recommended for download:
+the latest stable release, and development builds from the master branch.
+
+You can download both at any time, but note that the development builds may
+have breaking changes.
+
+For the latest **stable release**, check here: https://github.com/Rosettea/Hilbish/releases/latest
+For a **development build**: https://nightly.link/Rosettea/Hilbish/workflows/build/master
+
+## Package Repositories
+### Arch Linux (AUR)
+Hilbish is on the AUR. Setup an AUR helper, and install.
+Example with yay:
+
+```
+yay -S hilbish
+```
+
+Or, from master branch:
+```
+yay -S hilbish-git
+```
+
+### Alpine Linux
+Hilbish is currentlty in the testing/edge repository for Alpine.
+Follow the steps [here](https://wiki.alpinelinux.org/wiki/Enable_Community_Repository)
+(Using testing repositories) and install:
+```
+apk add hilbish
+```
diff --git a/website/static/hilbish-flower.png b/website/static/hilbish-flower.png
new file mode 100644
index 0000000..b4fb0f7
Binary files /dev/null and b/website/static/hilbish-flower.png differ
diff --git a/website/themes/hsh/LICENSE b/website/themes/hsh/LICENSE
new file mode 100644
index 0000000..da3c8c1
--- /dev/null
+++ b/website/themes/hsh/LICENSE
@@ -0,0 +1,21 @@
+MIT License
+
+Copyright (c) 2022 Rosettea
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
diff --git a/website/themes/hsh/archetypes/default.md b/website/themes/hsh/archetypes/default.md
new file mode 100644
index 0000000..ac36e06
--- /dev/null
+++ b/website/themes/hsh/archetypes/default.md
@@ -0,0 +1,2 @@
++++
++++
diff --git a/website/themes/hsh/layouts/404.html b/website/themes/hsh/layouts/404.html
new file mode 100644
index 0000000..06b3561
--- /dev/null
+++ b/website/themes/hsh/layouts/404.html
@@ -0,0 +1,7 @@
+{{ define "main"}}
+
+