Blowfish is designed to be a powerful, lightweight theme for Hugo. It's built using Tailwind CSS with a clean and minimalist design that prioritises to your content. The theme is a fork of Congo.
🌏 Demo site
📑 Theme documentation
💎 Merch Store
🐛 Bug reports & issues
💡 Questions & feature requests
- Fully responsive layout built with Tailwind CSS 3.0
- Multiple colour schemes (or fully customise your own)
- Dark mode (forced on/off or auto-switching with user toggle)
- Highly customisable configuration
- Firebase integration to support dynamic data
- Views count & like mechanism
- Related articles
- Multiple homepage layouts
- Multiple authors
- Series of articles
- Flexible with any content types, taxonomies and menus
- Header and footer menus
- Nested menus & sub-navigation menu
- Multilingual content support inlcuding support for RTL languages
- Ability to link to posts on third-party websites
- Support for several shortcodes like Gallery, Timeline, GitHub cards, and Carousels
- Buymeacoffee integration
- Client-side site search powered by Fuse.js
- Diagrams and visualisations using Mermaid
- Charts using Chart.js
- TypeIt integration
- Mathematical notation using KaTeX
- SVG icons from FontAwesome 6
- Automatic image resizing using Hugo Pipes
- Heading anchors, Tables of Contents, Code copy, Buttons, Badges and more
- HTML and Emoji support in articles 🎉
- SEO friendly with links for sharing to social media
- Fathom Analytics and Google Analytics support
- RSS feeds, Favicons and comments support
- Advanced customisation using simple Tailwind colour definitions and styles
- Optimised for performance and accessibility with perfect Lighthouse scores
- Fully documented with regular updates
Blowfish has extensive documentation that covers all aspects of the theme. Be sure to read the docs to learn more about how to use the theme and its features.
Blowfish supports several installation methods - as a git submodule, a Hugo Module, or as a completely manual install.
Detailed instructions for each method can be found in the Installation docs. You should consult the documentation for the simplest setup experience. Below is a quick start guide using submodules if you are using git, or Hugo modules if you're already confident installing Hugo themes.
Note: Ensure you have Git, Go, and Hugo installed, and that you have created a new Hugo project before proceeding.
-
From your project directory, initialise git:
git init
-
Configure Blowfish as a git submodule:
git submodule add -b main https://github.com/nunocoracao/blowfish.git themes/blowfish
-
In the root folder of your website, delete the
config.toml
file that was generated by Hugo. Copy the*.toml
config files from the theme into yourconfig/_default/
folder.You will find these theme config files in the Hugo cache directory, or download a copy from GitHub.
-
Follow the Getting Started instructions to configure your website.
Note: Ensure you have Go and Hugo installed, and that you have created a new Hugo project before proceeding.
-
From your project directory, initialise Hugo Modules:
hugo mod init github.com/<username>/<repo-name>
-
Create
config/_default/module.toml
and add the following:[[imports]] path = "github.com/nunocoracao/blowfish/v2"
-
Start your server using
hugo server
and the theme will be downloaded automatically. -
In the root folder of your website, delete the
config.toml
file that was generated by Hugo. Copy the*.toml
config files from the theme into yourconfig/_default/
folder.Note: Do not overwrite the
module.toml
file you created above!You will find these theme config files in the Hugo cache directory, or download a copy from GitHub.
-
Follow the Getting Started instructions to configure your website.
As new releases are posted, you can update the theme using Hugo. Simply run hugo mod get -u
from your project directory and the theme will automatically update to the latest release.
Detailed update instructions are available in the docs.
Blowfish is expected to evolve over time. I intend to keep adding features and making changes as required.
Feel free to get in touch with any issues or suggestions for new features you'd like to see.
- 🐛 Bug reports & issues: Use GitHub Issues
- 💡 Ideas for new features: Open a discussion on GitHub Discussions
- 🙋♀️ General questions: Head to GitHub Discussions
If you're able to fix a bug or implement a new feature, I welcome PRs for this purpose. Learn more in the contributing guidelines.