CONTENTS | UP | DARK | HOME

How to Design a Blog with Emacs and Org-Mode

From Internet Peasant to Land Chad

1. Website Design Philosophy

When it comes to media, I’ve always preferred a minimalist, mostly text-based design, similar to the kind advocated by the 1MB Club. Flashy image-loaded designs can’t communicate as much distilled, easy-to-digest information, and they also require extra web development and longer loading times. It took a lot of work to figure out how to design this website the way I did, so I wanted to document how I did everything. Hopefully this will help other people.

This website’s homepage is intended to be organized similarly to the Drudge Report, PhilosophyBasics.com, Craigslist, but with better and more modern HTML/CSS code. The homepage’s .html file was created by using this template that I found at joshcanhelp.com. I replaced all the old HTML4 code with HTML5 code, and customized it with my own style, formatting, and content.

Most blogs organize their posts by the date that the posts were published in reverse chronological order. That’s presumably because the people who habitually read the blogs every time a new post comes out will have already read most or all of the blog’s content, but this blog doesn’t do that. Instead, the home page and directory page organize all the links and posts into categories, with short descriptions, so that people who come to this site for the first time will be more likely to read the most important information first. The other reason why I don’t organize the posts in reverse chronological order is that I am continuously updating the posts whenever I come up with new ideas and I have time to write about them.

1.1. Advice For Writing Content

It can be tempting to immediately start writing content that you’ve been eagerly waiting to write (as I had done), but you will save time in the long run if you hold off from that and spend a few minutes to read and learn how to utilize good writing advice.

  • Every post should have a meaningful topic. It’s also helpful if everyone else writing about the topic is missing a key point or over-complicating simple things.
  • It’s important to plan and outline your content before writing it. Many bloggers just write whatever comes off the top of their heads, which causes their posts to lack structure and organization. I was guilty of this myself for some of my essays since I was so eager to put my ideas out there, until I restructured them.
  • Many people have a tendency to write long sentences with cohesive devices that place restrictions on how they write their sentences. For such people (including my former self), I recommend taking Scott Adam’s Writing Advice to heart.
  • Humans are psychologically attracted to reading lists for multiple reasons. Lists are also easier for people to read and follow, rather than reading paragraph after paragraph, if it’s possible to format the content that you want to write that way.
  • If you need to list a bunch of short ideas, reasons, or arguments in a section, it’s a good idea to use bulleted or numbered lists. Paragraphs require adding more cohesive devices and other fluff language compared to lists. As an example, some sections in my Overpopulation FAQs became more concise and easier to read when written as lists instead of paragraphs.
  • Wikipedia: Rule of three.
  • HTML Quotation Elements are a great way to quickly state opposing points of view before addressing them. I’ve made my Case Against Libertarianism essay and other works less wordy by using a related concept that I refer to as “opponent blocks”.
  • Wikimedia Commons provides millions of freely usable images that people can use in their works, provided that they respect the terms of the licenses. See my section for links for learning more about copyrighting and licensing.
  • If you can’t find or think of any images to add to your webpages, you should try using an AI image generator to generate images based on what the webpages are about. This will guarantee that every one of your webpages will have an image that fits the content and will attract more readers.
  • Lastly, taking at least an hour to learn good SEO practices can save you the trouble of rewriting your content later on, if you want to maximize your number of readers.
  • If you write, you should think about what you are writing. You should ask yourself:
    • “Is this useful for an LLM to learn?”
    • “If I knew for sure that a LLM could write or do this thing in 4 years, would I still be doing it now?”
  • Why You Should Start a Blog Right Now - Alex Guzey; This webpage gives encouragement for starting your own blog. It also argues against some common excuses why someone shouldn’t start a blog.
  • Let’s stop counting centuries – Dynomight Internet Newsletter.
  • In some cases, numerals are easier to read than number words. For example, “1 million” may be easier to read than “one million” in some texts, even if it is technically considered to be less formal by the norms of formal writing. In such cases, I think it’s people should use their best judgment regarding what would be best for their audience.
  • When writing about anything, it helps to think about the level of complexity of one’s pages. If you go too deep, then you’ll have to include everything to make everything feel complete. But if you go too shallow, then the work may just become a list of vague or unimportant ideas.
  • Good writing doesn’t happen by averaging what has been written, but rather by rejecting most available sentences. That’s why statistical AI sucks at it.
  • Tip: Turn on autocomplete. If it suggests what you were about to write, then don’t write it, because it is cliche.

1.2. Writing Books Or Not

I agree with many of the arguments that Gwern gives for writing webpages instead of books. However, it can make sense to write books if you plan strategically to avoid the potential drawbacks. In spite of all the drawbacks that Gwern noted, books still have many advantages that Gwern didn’t mention:

  • Books that are composed of shorts essays or concise expository books are probably the best examples of books that paid off (e.g. Lucifer’s Question, Debunking the Selfish Gene, Futurist Fantasies).
  • The nature and formatting of books encourage higher quality, more formal writing, and somewhat greater notability.
  • In my experience, people are more likely to cite books when recommending things people should read for learning or studying a topic than they are to cite blog posts.
  • Books can be archived in libraries if they’re printed out. If computers and the infrastructures that they rely on ever collapse, then libraries and printed books will be critical for archiving knowledge that may otherwise be gone forever.
  • Ebooks are quite popular these days. Their medium makes it easy for authors to update content for their readers, ebooks are easy to search and navigate, and their formatting enables readers to utilize hyperlinks created by the authors.
  • There are lower opportunity costs to writing books and revising when you know how to write well, and you know how to not fall for the sunk cost fallacy.
  • A combination of blogging and book writing can compliment each other well.
  • There are fewer drawbacks to writing books when you aren’t writing them for money, and are okay with not publicizing them much.
  • Books are one of the least censored channels for distributing information.
  • If the books are reasonably cheap, there’s little reason why people would avoid buying them.
  • If the books aren’t free, it makes sense for people to buy them as gifts to others.

1.3. Quality Versus Quantity

For most topics, I don’t understand bloggers who write posts every day. For one thing, there’s probably a finite amount of good ideas out there to discover, due to the physical materialist nature of the Universe. For another thing, it’s unusual for someone to observe or brainstorm something really interesting or noteworthy every single day that is worth writing an entire post about. Even if someone did write a blog post every day, the average quality of each post would have to be quite low since such a high frequency of content production would require espousing fewer good ideas in each post.

I don’t have the time to write a new post each day, but even if I did, eventually hundreds or even thousands of blog posts would accumulate over time. If someone came across such a blog for the first time, they would be lost and unsure of where to start reading since it would be difficult to navigate and determine which posts are worth reading.

1.4. Displaying Tables of Contents

Any book, essay, webpage, or work that’s worth writing ought to be accompanied with a table of contents (TOCs), unless the text is short enough to the point where adding a TOC doesn’t make sense. TOCs tend to improve reader comprehension, since they make it easier for readers to build mental models that summarize and compress the information inside of a written work.

Essays and books that have tables of contents are also more likely to be read by potential readers, since give onlookers a better idea about what content talks about, and can attract their interest in the first place.


On 2025 March 12, my website added a navigation bar that displays near the top of every page, which allows easy access to the TOC, without scrolling to the top of the page. While I could display the TOC to the left of the content at all times, this wouldn’t work on browser windows with small screen widths, and it would disrupt the symmetry of the webpages.

Additionally, many of the header names within the TOCs are too long to display neatly in the left hand side of webpages. I could write Javascript code to collapse the subsections that display in the TOCs with left arrow and down arrow buttons, similar to the Wikipedia Vector 2022 format, but this would add complexity to the pages, and may not be desirable.

Additionally, many <h2> headers on my webpages would still be too long to display comfortably in the left side bar, especially for the FAQs pages. It’s also more comfortable to read the TOCs when they are displayed in the center of the screen with the maximum readable page/content widths.


The main reason why I added the Javascript image gallery to my webpages was to make it easier for users to magnify images which may appear tiny on the webpages. I was aiming for an image gallery similar to the kind used on Substack.com, Wikipedia.org, Fandom.com, and Gwern.net.

I’ve done my best to simplify the webpage format and design as much as possible. This list aims to clarify how some less obvious features of the site work.

  • On every page, the navigation bar is displayed any time the user scrolls up.
  • When reading the webpages, the reader will often see quote blocks and opponent blocks.
    • Quote blocks are used for quoting text that I agree with that supports other text on the page. Quote blocks feature blue coloring on the left side of the block (for indenting the text).

      This is an example of a quote block.

    • Opponent blocks are used for stating arguments that I’m responding to and/or questions that I’m answering. Opponent blocks feature pink coloring on the left side of the block (for indenting the text).

      This is an example of an opponent block.

    • Opponent blocks may feel weird initially, but they make the writing more concise and easier to follow overall, once you’re used to them.
  • The image gallery displays on the content pages when clicking on an image file. The image gallery is useful for displaying images, magnifying images, navigating between images, and showing image captions and descriptions.
  • There are keyboard shortcuts that people can use:
    • “c” : Toggle between showing and hiding TOC.
    • “d” : Toggle between light and dark mode display.
    • When using the image viewer:
      • ← / → : Previous/Next image
      • Space : Reset image size/position
      • ESC : Close image viewer
  • There are often hatnotes and tail note hyperlinks at the beginning and ends of sections all over this site. The purpose of these links is to show additional webpages that readers may be interested in reading. This list shows the main types of hyperlink notes that may be shown across the site:
    • Pre-Reading:
    • See:
    • See Also:
    • Read:
    • Read More:
    • Video:
    • Related Video:
    • Related:
    • Relevant:
    • Further Reading:
    • Wikipedia:
  • Hovering over footnote reference numbers displays the corresponding footnotes as tooltips.
  • I prefer to use the logical (British) quotation style for quotes, whenever possible. Despite being an American, I hate the American quotation style.

1.7. Static Site Generators

Most people who want to start blogging and aren’t using a Content Management System like Wordpress or Blogger should consider downloading and using a static site generator (SSG). In my opinion, the main benefit to using SSGs is that they make it possible to use Markdown (or Org-Mode) instead of HTML to create webpages, but they also provide many other benefits.

Org-Mode wasn’t specifically designed to be a static site generator, but one can configure it to do many of the key features that a SSG can do. Thomas Ingram and Dennis Ogbe have written their own guides on how to use org-mode as a static site generator for websites. Their tutorials are more complex than mine, and their resulting websites have more features, like sitemap and RSS feed generators, blogging templates, more detailed headers and footers, etc. There are also other guides that show how to set up tagging systems for posts. However, I’m not experienced enough with Elisp and my website may not need those features, so some people may prefer my simpler tutorial here.


Since I already knew how to export my .org files to HTML webpages, I never used a different SSG when I created this website, and I still don’t. The reasons are complicated, but I encountered multiple problems when I last tried to switch to using a more full-fledged SSG in July 2023:

  • It would take too much time for me to learn how SSGs work, how to configure them, and how to use them. I already have a system for creating and publishing my webpages that works for me.
  • I’d have to program Emacs keybindings for operating the SSG, lest I would have to use my command terminal to operate the SSG instead, which is inconvenient because then I’d have to frequently switch between applications. This would be hard because I’m terrible at Elisp (and programming in general).
  • Most static site generators use Markdown instead of Org-Mode. Although Hugo is compatible with org-mode, there weren’t enough tutorials and documentation for showing how to use Hugo with org-mode when I tried to switch over. However, it’s possible that Hugo may develop better documentation for writing with org-mode in the future.
    • Hypothetically, I could switch to using Markdown to write my webpages, but that would take time, it could create confusion and syntax errors if I switch, and most importantly, I’d lose the ability to export my .org content to other formats, like .tex, .pdf, .txt, .odt, etc.

There are still some benefits for creating and publishing content that SSGs would provide compared to my current system:

  • SSGs could provide my website with better headers and footers.
  • SSGs provide tags for sorting webpages, which makes them easier to navigate.
  • SSGs have ways to prevent the website directories from displaying in the URLs.
  • It would be easier to create RSS feeds.
  • They provide templates for writing webpages.
  • They provide text summarizers for writing webpage descriptions and such.
  • They could create a search index that readers could use to search my website’s content. Thus, the search bar on my homepage wouldn’t have to use an external search engine like Yandex or DuckDuckGo.
  • They can create better image galleries.
  • There are many other plugins for SSGs that make it easier to create content.

However, even after considering all the benefits that I could potentially gain, I decided that it still wasn’t worth it for me to stop using my current setup. Another thing is that my website doesn’t really need some of these features (even if they’d be nice), and I have found other ways to get most of the benefits that other SSGs would provide, which I talk about in this article.

2. Using Org-Mode To Create Web Pages

2.1. Learning How To Use Org-Mode

2.2. Setting Up Org-Mode For Blogging

Hopefully, this guide will be detailed enough to show other people how to replicate the design process. It will assume that that the reader is already familiar with the basics of using Emacs. If the user has no interest in using org-mode or Emacs, then most of the CSS, SEO, and Recommended Tools sections of this article may still be of interest to the reader.

Org-mode variables control how the org-mode markup language will be exported to HTML and other formats. They can be set either within the file itself as file local variables, or within your .config/doom/config.el, (or ~/.emacs.d/init.el for non-Doom-Emacs users). For a complete list of variables controlling how org-mode exports files, see the following links from the Org-Mode Manual:

There are multiple reasons to set org variables with config.el instead of within file local variables:

  • It makes the compilation of your org files less prone to errors, assuming that you export a lot of them.
  • It ensures that all org files export the same way each time, aside from any customizations using local file org variables.
  • If you later decide to that you want to change something across all your .org files, it’s easier to just edit one file (config.el) instead of editing every single org file.
  • If you’re only going to export org file variables for one purpose or similar purposes, then you don’t have to copy as many local org file variables to each new file to do the same things, and the org files will collectively take up less file space. This also gives the beginnings of the org files a cleaner appearance.

I have the following settings configured for org-mode in my config.el. The user can learn more about what each variable does by pressing SPC h v in Doom-Emacs, or C-h v in regular Emacs.

(setq org-src-fontify-natively t)
(setq org-hide-emphasis-markers nil) ;; Don't hide the /, *, and _ font formatting characters.
(setq org-startup-folded t)
(setq org-startup-truncated nil)
(setq org-startup-with-inline-images nil)
(setq org-return-follows-link nil)
(setq org-structure-template-alist '(("a" . "export ascii") ("c" . "center") ("C" . "comment") ("e" . "example") ("E" . "export") ("h" . "export html") ("l" . "export latex") ("q" . "quote") ("s" . "src") ("v" . "verse") ("o" . "opponent")))

(setq org-html-doctype "html5")
(setq org-html-html5-fancy t)
(setq org-html-content-class "content")
(setq org-html-container-element "div")
(setq org-html-head-include-scripts nil)
(setq org-html-head-include-default-style nil)
(setq org-html-head-extra "<link rel=\"stylesheet\" type=\"text/css\" href=\"/style.css\"><script src=\"/script.js\"></script>")

;; Four-Button Navigation Bar: TOC, Top (UP), Dark/Light Mode, Home
(setq org-html-link-up "#\" id=\"TOC-link\">CONTENTS</a> | <a id=\"top-link\" href=\"#content")
(setq org-html-link-home "#\" id=\"theme-link\">DARK</a> | <a id=\"home-link\" href=\"/")

(setq org-export-with-author t)
(setq org-export-with-email nil)
(setq org-export-with-creator nil)
(setq org-html-metadata-timestamp-format "%Y %B %d, %H:%M")
(setq org-html-postamble t)
(setq org-html-postamble-format
 '(("en" "<p class=\"date\">Last Modified: %T</p>\n
          <p class=\"author\">Author: %a</p>"
  )))

The values set for the org-html-link-up and org-html-link-home variables look complicated, and that’s because they were never intended to be so complex by the creators of org-mode. Both variables were originally intended to only provide two navigation hyperlinks on every HTML exported page. However, I wanted to add hyperlinks/buttons for adding a TOC and light/dark mode toggling to every page.

I managed to make those variables add additional hyperlinks to each page by inserting multiple double quote escape (\“) characters. I also wrote CSS and JS code to customize #org-div-home-and-up so that it displays as a navigation bar on every page. Unfortunately, I can’t change the text of the <UP> hyperlink without writing more Javascript code, since it’s hardcoded into org-mode.


For some reason, the org-mode HTML exporter inserted role=“doc-backlink” instead of role=“doc-noteref” into the footnote reference links, so I had to create a function inside config.el that overrides the normal org-mode exporter behavior:

(defun my/org-html-footnote-reference (footnote-reference _contents info)
  "Custom footnote reference without role='doc-backlink'."
  (let ((n (org-export-get-footnote-number footnote-reference info)))
    (format "<a id=\"fnr.%d\" class=\"footref\" href=\"#fn.%d\" role=\"doc-noteref\">[%d]</a>" n n n)))
(advice-add 'org-html-footnote-reference :override #'my/org-html-footnote-reference)

2.3. Local Org-Mode Variables In Files

The following is the entirety of the org-mode keywords and values that I include at the beginning of every .org file for controlling the HTML code of my webpages:

#+title: The_Webpage_Title_That_Will_Be_Placed_In_Both_<title>_and_<h1>
#+subtitle: The_Webpage_Subtitle_That_Will_Be_Placed_In_<subtitle>
#+author: The Author Name
#+description: The webpage description (up to 160 characters long).
#+html_head: <meta property="og:url" content="[the canonical URL link for this article]">
#+html_head: <meta property="og:type" content="article">
#+html_head: <meta property="og:image" content="[Link to image file]">
#+options: ^:nil

Org-mode provides two different variables for adding code to the <head> section of HTML files, org-html-head and org-html-head-extra. They’re also written as #+html-head and #+html-head-extra, when used as local file variables written at the beginning of org files. The reason why there’s two different variables is because people will often want to embed a lot of code to <head>. If there were only one variable for adding code to <head>, someone had assigned a value to org-html-head inside their config.el, and they also tried assigning additional values with #+html-head in their local files, then the values written in the local files would overwrite the values for org-html-head inside their config.el so that they wouldn’t display at all. Fortunately, the two separate HTML head variables can be used strategically to prevent this. In my config.el, I have:

(setq org-html-head-extra "<link rel~\"stylesheet\" type~\"text/css\" href~\"/style.css\"><script src=\"/script.js\"></script>")

Meanwhile, my local file org variables add the following HTML <head> code to each file:

#+html_head: <meta property="og:url" content="[the canonical URL link for this article]">
#+html_head: <meta property="og:type" content="article">
#+html_head: <meta property="og:image" content="[Link to image file]">

These settings ensure that all the content that I want to be added to HTML <head> will get included.


Every time I want to re-export the HTML output from my org file to update my webpages, I press SPC m e h h in Doom-Emacs, which executes the command org-export-dispatch.

Note: As of 2024 December 15, I disabled Google Analytics from my site, since it didn’t really benefit me or my readers to keep using it. However, I will continue to show the Google Analytics lines above to help guide people who are interested. If you want to link a Javascript file to every HTML export, then adding the <script src="/script.js"></script> line to your org-mode files should do the trick.

2.4. Advice For Using Org-Mode

When creating links in org-mode, there are many options and they depend on what you’re linking to. Since I often want to link to sections of my website pages, I always insert the following org syntax under each section heading. Without the following syntax, the fragment identifiers will change every time the org-mode code is re-exported to .html, which is inconvenient.

:PROPERTIES:
:CUSTOM_ID: Name_Of_Fragment_Identifier
:END:

This syntax makes it possible to have consistent fragment identifiers once the webpages are published, and users can find them when clicking on links in each webpage’s table of contents, and copying the URL.

When writing paragraphs in org-mode, I prefer to place each sentence on a separate line (i.e. every line ends with a newline character). The text will not be displayed as separate paragraphs unless there are at least two newlines between each line. The advantage to this is that it makes it easier to easier to rearrange the sentences in my paragraphs, easier to merge and/or divide paragraphs, and easier to convert between paragraphs and bulleted lists (compared to keeping all of a paragraph’s sentences on just one line). This style for formatting paragraphs and sentences and the recommended minimalist writing advice both compliment each other quite well.

If an .org file contains content that I don’t want to publish just yet, I can temporarily comment that text out before exporting the .org files to .html. This facilitates the organization of all my files since I can organize all my ideas by file, without having to publish everything that I write.

I don’t usually export my org files to LaTeX, but I do so when I want to publish my works in PDF format. When exporting .org files to LaTeX, I include the following lines at the beginning of the .org file so that the page margins take up less space in the resulting .pdf file, and so that the output is displayed in a font that is easier to read.

#+latex_header: \makeatletter \@ifpackageloaded{geometry}{\geometry{margin=2.5cm}}{\usepackage[margin=2.5cm]{geometry}} \makeatother
#+latex_header: \usepackage{helvet}
#+latex_header: \renewcommand{\familydefault}{\sfdefault}
#+latex_header: \usepackage{parskip}

For people who create YouTube videos to accompany their blogs, W3 Schools has a page that details the HTML code for embedding YouTube videos into webpages. In org-mode, C-c C-, (or SPC m e h in Doom-Emacs) will execute the command org-export-dispatch, which will insert the lines for exporting the <iframe> HTML code:

#+begin_export html
<div align="center"><iframe width="360" height="261" allowfullscreen
src="https://www.youtube.com/embed/VIDEO_TAG_GOES_HERE"></iframe></div>
#+end_export

If you wish to create a custom, complex table in HTML, then I recommend using tablesgenerator.com. It provides a GUI for generating HTML/LaTeX/Text/MarkDown/MediaWiki code to create a table with however many rows and columns you want, merging and splitting cells, setting CSS of each table cell, and transposing the table with a single click. I personally think it’s much easier to create tables this way, rather than having to painstakingly perfect non-WYSIWYG code.

Occasionally Helpful: Org-Mode Manual: Org-Mode Escape Character.

3. Creating CSS For Webpages

I learned how to read and write HTML and CSS from the HyperText Markup Language Wikibook and the Cascading Style Sheets Wikibook. Those are free resources, however they’re not as comprehensive or up-to-date as others. Readers who want a more modern and comprehensive resource for CSS should probably read HTML & CSS by Jon Duckett. Other Notes:

  • I created the CSS file for my website articles by placing the CSS code embedded inside the .html template that I found into a separate .css file and modifying it. It can be overwhelming to create CSS files from scratch, but online templates can make everything easier.
  • Every time I had a CSS question that wasn’t answered by Wikibooks, I googled it. W3 Schools, GeeksForGeeks, MDN Web Docs, and StackExchange were the most helpful sites.
  • Other resources that may help for creating minimalist designs include the CSS Viewer browser extension for Firefox and 1MB Club’s Blog.
  • There are tools for removing unused CSS, that are worth looking into.
  • It’s also worth using a CSS Minifier to create the CSS sheet used by your webpages. It can help speed load times and reduce the data usage of one’s web server. It’s recommended to keep the easier-to-read CSS (containing all the whitespace and comments) within a separate file, and to run it through the minifier every time you want to change the CSS for your site. HTML Minifiers and Javascript Minifiers exist too, if you’d prefer to use one.
  • It’s worth looking into CSS reset rules and CSS reset files, which are necessary since every web browser has different CSS defaults for HTML elements, which may cause websites without reset rules to have unexpected displays on different web browsers.

3.1. CSS For Org-Mode HTML Exports

People who are using org-mode to create webpages can use the CSS Support section from the Org-Mode manual to inform them of all the ID attributes and classes that are available for tweaking a webpages’ CSS, using a separate CSS file. Alternatively, some users may prefer to use the default org-mode CSS with their files. If you wish to use it, you must have the following line in you config.el:

(setq org-html-head-include-default-style t)

Or you could set it with an org local variable by placing the following line in their org file:

#+options: html-style:t

However, the default org-mode CSS has a total of 7.0kB, and it will be included into every HTML file that you export where the html-style variable is turned on. It may also complicate or interfere with your own CSS customizations if you link a separate CSS file to your HTML exports. My advice is to write your own CSS file, and view the output of the default org-mode CSS and copy the useful parts of it that you want to keep for your own custom CSS file.


If you would like to overrule the default CSS alignment of the table columns, you can use ’<r>’, ’<c>’ or ’<l>’ in a special table cookies row of the table. You may also combine alignment and field width like this: ’<r10>’.


Org-mode makes it possible to create custom org-special-blocks. For all org-mode versions greater than 8.0, their functionality is built into org-mode, so you can start using them right away. org-special-blocks[1] have the form of #+begin_X and #+end_X. If you’d like to create a keybinding for automatically inserting them, you just need to edit the Emacs variable org-structure-template-alist to have the key binding and text that you want these blocks to have. In order to customize the CSS of these blocks, you just need to write a CSS class that is the same as the block, and include the CSS properties that you want the output to have. You can also write LaTeX code for customizing the LaTeX output of org-special-blocks.

In my case, I wanted to create an org-special-block to distinguish between: 1. text that I’m responding to and/or questions that I’m answering, and 2. text that I agree with and/or am quoting in my webpages. So I created the opponent block: #+begin_opponent and #+end_opponent, and I edited the CSS file used for all my webpages to control its output. For the latter case, I use the standard quote block that’s built into org-mode by default: #+begin_quote and #+end_quote, and it has slightly different CSS formatting.


The CSS file that I use to style my org-mode generated webpages is available under the CC BY 4.0 license. To download the template, just click the link below, and press “Ctrl + S” to save it.

  Download Zero Contradictions Org-Mode Essays CSS Template

Anyone can use this CSS template for their own creations as long as they keep the line that attributes me within the file and summarize what they changed (if anything).


The Javascript file that I use for each of my webpages can also be downloaded as well. It is available under the CC0 1.0 Universal public domain license. The script.js file was almost entirely generated by querying ClaudeAI and ChatGPT to create what I wanted, with my own edits mixed in for customization. The Javascript file provides light/dark mode, a more accessible TOC, an image gallery, a more convenient display of footnotes, and keyboard shortcuts.

  Download Zero Contradictions Javascript Template

3.2. Using Zero Contradictions’ Homepage Template

In the interest of creating a bloat-free Internet with aesthetic webpages and minimalist designs, I (Zero Contradictions) have decided to release an HTML template that replicates the layout, design, and functionality of my homepage under the CC BY 4.0 license. Other people may use this HTML template to create their own webpages if they wish, as long as they leave the attribution text to Zero Contradictions in the footer. To download the template, just click the link below, and press “Ctrl + S” to save it.

  Download Zero Contradictions Homepage Template

The following bullets are instructions for how to customize and build upon the template: Instructions For Customizing The Template:

  • Open the “homepage-template.html” file with a plain text editor, such as Notepad.
  • [​[double square brackets]] are placed around the text that needs to be changed in the file so it’s easy to find all the meta (unseen on the page) information. To add new links and change the information, you’ll want to have a bit of experience with HTML.
  • Start scanning for double brackets and fill in the information as needed. Make sure the <title> text has words that tell search engines what you’ve got going on the page. Fill out those meta tags too, for better SEO.
  • If you’ve chosen a logo or image to represent your website, use realfavicongenerator.net to generate all the favicons needed for this code to be useful. Place the favicons into the website’s root folder.
  • If you want to verify your website with Google Search Console, you should visit Google Search Console’s Welcome page, click URL prefix, enter your website’s URL, and follow the instructions for adding the verification meta tag to your homepage.
  • Likewise, if you want to add Google Analytics to this page, you should follow these instructions to setup a Google Analytics account and add the provided Javascript code within the page’s <head> tag.
  • Unless you’re familiar with CSS, just leave everything between the <style> and </style> tags alone. If you are familiar with CSS, go crazy!
  • For the link colors, I’ve left two different color schemes to choose from, and I’ve explained the pros and cons to both of them inside the template itself. If you want to switch to the other scheme, just uncomment the CSS for the other scheme, and comment out and the CSS for the Cretan color scheme.
    • Although the link colors are set up to mimic the functionality of the link colors on ZC’s website, you could give different purposes, as long as you change their names (blog-posts, videos) everywhere in the .html file to reflect those purposes.
  • Now, your header image. Just put the filename of the image you’re going to use after src=“ and make sure the image is placed in the same directory on your host as this file. Type in a description of the image as well while you’re at it. The image will resize to 160 pixels wide automatically. Or you can delete the whole img tag if you don’t want to use one.
  • Fill out the information for introducing the webpage as you please.
  • Next, within <nav> tag, you should fill out the category names for the links that you want to display. You may want to also edit the href attribute values in each <a> tag to help your users navigate the site. The text after each hashtag <#> will be displayed in your website’s URLs.
  • If you want to keep the Javascript code for searching your website site with DuckDuckGo, you should place the canonical URL for your website on the line with query.value = "site: ". Be sure to leave a space before the end quote so that DuckDuckGo can search your website correctly. It may take a few days (possibly weeks) after the website is up and running for DuckDuckGo to index your website, before the search bar works correctly.
  • Now, you’re ready to plug in your links. Each link is in its own <li> tag to keep them on their own line and to give a little space in between. Just replace the text after href=“ with the direct URL (including http://) and replace the next set of brackets with the text you want to appear on the page. You’ll notice that the first link in the left column has a paragraph right after it but before the closing tag. Make sure to follow this syntax to keep the spacing kosher.
  • Want to add another link? Just copy and paste one of those <li>…</li> rows wherever you want it to be. Deleting a link is the opposite.
    • I’ve provided many different format styles for the types of links that you may use for this page as you build from this template. There format styles vary across the categories, so just cut and paste which format types you want from the available links.
  • Add a new separating header with <h2>…</h2> or <h3>…</h3> tags wherever you’d like (but, of course, within one of the columns).
    • If you want to add new headers to the navigation bar, then be sure to add list items and links within the <nav> tag accordingly.
  • Want to add a separator line? Figure out where it should go and place an <hr> right there.
  • img tags can also be used in columns, just make sure they are in between the <li> and </li> tags. Style wise, it’s probably better to put img tags in between the <li> and the <a> tags.
  • Scroll down to the bottom for the footer links. Don’t want any? Just delete them all.
  • Other information and advice for customizing the template may be found within the template itself and the this blogging advice page.
  • If you plan to use this template as your homepage, or as the default webpage for a web directory, rename the file to “index.html” and place it in the home folder of your chosen web host.

And that’s it! To make it live, just copy index.html to a public folder on your web host and check it out. If you already have a website going, be careful where you put this so you don’t overwrite the main site file.

Although the terms in the Creative Commons license say that you have to explain what you’ve changed, it seems that most people outside of the Wikimedia project don’t do that in practice when they change content released under a CC license (although they should). For this HTML file, I will let that condition slide. Since this file is meant to be a template, it’s already easy to figure out what the changes to it were. Listing the changes would only make the template inconvenient to use, and the only thing that matters to me is that people attribute me if they decide to use it.


This template is based on the JoshCanHelp Drudge Report template, which is available in the public domain if you would prefer to create a webpage with a more simplistic design that does not require attributing the original author.

However, the Zero Contradictions Homepage Template has many advantages over the JoshCanHelp.com template:

  • Mobile-Friendly Column Layout
  • Navigation Bar
  • Search Bar
  • Light-Dark Mode
  • Link Color Scheme
  • Different templates for adding links
  • Links in Headers
  • Javascript “Last Updated” text
  • Relative em units are used instead of absolute px units
  • HTML5 instead of HTML4
  • Favicon Information
  • Modern CSS
  • Better And Modernized SEO

All of these features are free with the Zero Contradictions Homepage Template, as long as one follows the terms of the CC BY 4.0 license.

4. Copyrighting And Licensing

4.2. Creative Commons Licenses

The Creative Commons Licenses are a set of copyright licenses that allow creators to share their work with others while retaining certain rights and control over how their works are used. These licenses were designed to facilitate a flexible and legally sound way to grant permissions to the public for using creative works, such as text, images, music, and other intellectual property. Creative Commons licenses are widely used to promote collaboration, creativity, and the sharing of knowledge on the internet.

There are several different Creative Commons licenses, each with different permissions and conditions, represented by a combination of symbols and abbreviations. The primary components of these licenses include:

  • Attribution (BY): This is a common element of all Creative Commons licenses. It requires users to give appropriate credit to the original creator of the work. This credit should include the creator’s name or pseudonym and a link to the source if applicable.
  • Non-Commercial (NC): This element allows creators to specify that others can use their work, but not for commercial purposes. If the “NC” element is included, users cannot use the work for profit without obtaining separate permission.
  • No Derivatives (ND): Creators can choose to restrict others from creating derivative works based on their original work. If “ND” is included, users can share and redistribute the work but cannot make changes to it.
  • Share Alike (SA): This element permits others to use, modify, and distribute derivative works, but any new works must be released under the same license terms as the original work (or a compatible license). This is sometimes referred to as “copyleft” and encourages the creation of open and collaborative content.

The combination of these elements allows for the creation of various license options, such as:

  • CC BY: This is the most permissive Creative Commons license, allowing others to use, modify, and distribute the work for any purpose, as long as they provide proper attribution to the creator.
  • CC BY-SA: Similar to CC BY, but it also requires derivative works to be licensed under the same terms (Share Alike).
  • CC BY-NC: Allows others to use and modify the work but not for commercial purposes.
  • CC BY-NC-SA: Combines attribution, non-commercial use, and share-alike requirements.
  • CC BY-ND: Permits redistribution of the work as-is with proper attribution but without making derivative works.
  • CC BY-NC-ND: Permits redistribution of the work as-is with proper attribution but without making derivative works.
  • CC0: A public domain dedication tool that allows creators to waive all their copyright and related rights in a work.

The CC Deeds explain what the licenses allow for licensees and licensors in layman’s terms. But every creator and user should read the CC licenses’ legal terms, especially if they are unsure of what they can and cannot do with licensed content.

Every Creative Commons license requires people to attribute the originals creators of the work, and to state what they changed from the original work. The only exceptions are the ND licenses which forbid changes of any kind, and the CC0 license which releases works into the public domain. The main difference between the CC0 license and the CC BY 4.0 license is that the CC0 license doesn’t require users to attribute the authors or explain what they’ve changed from the original work (if anything).

More Info: Creative Commons FAQs

4.3. The Cons Of NC Licenses

I’d argue that CC BY-SA licenses are usually better than CC BY-SA-NC licenses for most purposes. Some additional problems that aren’t mentioned in that link include:

  • There is no clear boundary for what counts as “commercial” versus “non-commercial”, so this creates a lot of gray areas for using NC licenses. Does asking for donations, including ads, affiliate links, and/or other paid business relationships, etc count as “commercial” activity, or not?
  • Content released under NC licenses are incompatible with Wikipedia, other Wikimedia projects, and many other free content projects, large and small.
  • Content that is released under CC BY-SA-NC licenses instead of BY-SA licenses are not compatible with being re-released under GPLv3 licenses. For more info, see: The License Compatibility of CC BY-SA and CC BY-SA-NC Licenses.

In most cases, anyone who is actually trying to unfairly profit from your work is going to balk at the SA clause even if you don’t use the NC. Meanwhile, including NC gets some harmless sharing caught in the crossfire that could actually help promote you as a content creator.

4.4. The CC License Chooser

The Creative Commons License Chooser can help you choose a CC license. See: advantages to using the CC license chooser.

Before you license anything under CC licensing, you should first confirm that it’s appropriate:

  • [ ] I own or have authority to license the work.
  • [ ] have read and understand the terms of the license.
  • [ ] understand that CC licensing is not revocable.

The CC license chooser can help generate Creative Commons Rights Expression Language (CC REL) metadata that can be embedded into your online works, which can help search engines and such more easily identify the licensing of your content.

5. Search Engine Optimization (SEO)

Search Engine Optimization (SEO) is important if you want more people to discover your content via search engines. There are lots of webpages and websites out there about how to improve SEO, but in my opinion, none of them are as clear or as detailed as Google’s own SEO Documentation, in most cases. In hindsight, I wish I had used Google’s Developer Documentation as my go-to source for SEO questions.

More Advice for SEO:

Links For Uploading Sitemaps To Search Engines:

Footnotes:

1

I haven’t figured out how to control the formatting and syntax highlighting of the text shown in org-special-blocks in org-mode. If you know how, I would appreciate it if you contact me.

Last Modified: 2025 September 24, 12:29

Author: Zero Contradictions