summaryrefslogtreecommitdiff
path: root/themes
diff options
context:
space:
mode:
author2026-01-31 20:38:50 +0300
committer2026-01-31 23:38:53 +0300
commit49458f5ffd5a48c465117ec27f6437683f75acc1 (patch)
treea99ee68116d10c2b2e5a70c442cdadec95ba793c /themes
downloadblog-49458f5ffd5a48c465117ec27f6437683f75acc1.tar.gz
blog-49458f5ffd5a48c465117ec27f6437683f75acc1.tar.bz2
blog-49458f5ffd5a48c465117ec27f6437683f75acc1.tar.xz
blog-49458f5ffd5a48c465117ec27f6437683f75acc1.zip
initial
Diffstat (limited to 'themes')
-rw-r--r--themes/neonxp/archetypes/default.md5
-rw-r--r--themes/neonxp/assets/css/main.css183
-rw-r--r--themes/neonxp/assets/css/paper.css161
-rw-r--r--themes/neonxp/hugo.yaml18
-rw-r--r--themes/neonxp/layouts/_default/section.atom.xml23
-rw-r--r--themes/neonxp/layouts/_partials/footer.html1
-rw-r--r--themes/neonxp/layouts/_partials/head.html12
-rw-r--r--themes/neonxp/layouts/_partials/head/css.html27
-rw-r--r--themes/neonxp/layouts/_partials/head/js.html16
-rw-r--r--themes/neonxp/layouts/_partials/header.html2
-rw-r--r--themes/neonxp/layouts/_partials/menu.html50
-rw-r--r--themes/neonxp/layouts/_partials/terms.html27
-rw-r--r--themes/neonxp/layouts/baseof.html17
-rw-r--r--themes/neonxp/layouts/home.html21
-rw-r--r--themes/neonxp/layouts/page.html37
-rw-r--r--themes/neonxp/layouts/section.html26
-rw-r--r--themes/neonxp/layouts/taxonomy.html11
-rw-r--r--themes/neonxp/layouts/term.html7
-rw-r--r--themes/neonxp/static/favicon.icobin0 -> 8772 bytes
19 files changed, 644 insertions, 0 deletions
diff --git a/themes/neonxp/archetypes/default.md b/themes/neonxp/archetypes/default.md
new file mode 100644
index 0000000..25b6752
--- /dev/null
+++ b/themes/neonxp/archetypes/default.md
@@ -0,0 +1,5 @@
++++
+date = '{{ .Date }}'
+draft = true
+title = '{{ replace .File.ContentBaseName "-" " " | title }}'
++++
diff --git a/themes/neonxp/assets/css/main.css b/themes/neonxp/assets/css/main.css
new file mode 100644
index 0000000..6778acd
--- /dev/null
+++ b/themes/neonxp/assets/css/main.css
@@ -0,0 +1,183 @@
+:root {
+ --border-radius: 4px;
+ --shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
+}
+
+@media (prefers-color-scheme: dark) {
+ :root {
+ --shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
+ }
+}
+
+nav {
+ margin-top: 1rem;
+}
+
+nav ul {
+ display: flex;
+ padding: 0;
+ margin: 0;
+}
+
+nav ul li {
+ list-style: none;
+}
+
+nav ul li a {
+ padding: 0.5rem 1rem;
+ margin: 0 1rem;
+ border: 0.1px solid var(--link-color);
+ border-radius: var(--border-radius);
+ text-decoration: none;
+}
+
+nav ul li a:hover {
+ background-color: color-mix(in srgb, var(--link-color) 10%, transparent);
+}
+
+nav ul li:first-child a {
+ margin-left: 0;
+}
+
+@media (max-width: 900px) {
+ nav ul {
+ display: block;
+ }
+
+
+ nav ul li a {
+ margin: 0rem 0rem !important;
+ display: block;
+ border-radius: 0;
+ }
+
+ nav ul li:first-child a {
+ border-top-left-radius: var(--border-radius);
+ border-top-right-radius: var(--border-radius);
+ }
+
+ nav ul li:last-child a {
+ border-bottom-left-radius: var(--border-radius);
+ border-bottom-right-radius: var(--border-radius);
+ }
+}
+
+@media (max-width: 480px) {
+
+ header,
+ footer {
+ padding: 1rem !important;
+ }
+
+ nav ul {
+ display: block;
+ }
+
+ nav ul li a {
+ margin: 0rem 0rem !important;
+ display: block;
+ border-radius: 0;
+ }
+
+ nav ul li:first-child a {
+ border-top-left-radius: var(--border-radius);
+ border-top-right-radius: var(--border-radius);
+ }
+
+ nav ul li:last-child a {
+ border-bottom-left-radius: var(--border-radius);
+ border-bottom-right-radius: var(--border-radius);
+ }
+}
+
+ul.taxonomy {
+ display: flex;
+ padding: 0;
+ margin: 0.5rem 0;
+}
+
+ul.taxonomy li {
+ list-style: none;
+}
+
+ul.taxonomy li a {
+ padding: 0.5rem 1rem;
+ margin: 0 1rem;
+ border: 0.1px solid var(--link-color);
+ border-radius: var(--border-radius);
+ text-decoration: none;
+}
+
+ul.taxonomy li a:hover {
+ background-color: color-mix(in srgb, var(--link-color) 10%, transparent);
+}
+
+ul.taxonomy li:first-child a {
+ margin-left: 0;
+}
+
+
+ul.pagination {
+ display: flex;
+ padding: 0;
+ margin: 0.5rem 0;
+}
+
+ul.pagination li {
+ list-style: none;
+}
+
+ul.pagination li.active a {
+ background-color: color-mix(in srgb, var(--link-color) 10%, transparent);
+}
+
+ul.pagination li a {
+ padding: 0.5rem 1rem;
+ margin: 0 1rem;
+ border: 0.1px solid var(--link-color);
+ border-radius: var(--border-radius);
+ text-decoration: none;
+}
+
+ul.pagination li a:hover {
+ background-color: color-mix(in srgb, var(--link-color) 10%, transparent);
+}
+
+ul.pagination li:first-child a {
+ margin-left: 0;
+}
+
+pre {
+ border-radius: var(--border-radius);
+ border: 0.1px solid var(--border);
+ box-shadow: var(--shadow);
+ padding: 0.5rem;
+}
+
+article {
+ border-radius: var(--border-radius);
+ box-shadow: var(--shadow);
+}
+
+img {
+ border-radius: var(--border-radius);
+}
+
+.menu-icon {
+ height: 16px;
+ width: 16px;
+ border-radius: 0;
+}
+
+a.btn-primary {
+ display: inline-block;
+ padding: 0.5rem 1rem;
+ margin: 1rem 0;
+ border: 0.1px solid var(--link-color);
+ border-radius: var(--border-radius);
+ text-decoration: none;
+}
+
+a.btn-primary:hover {
+ background-color: color-mix(in srgb, var(--link-color) 10%, transparent);
+} \ No newline at end of file
diff --git a/themes/neonxp/assets/css/paper.css b/themes/neonxp/assets/css/paper.css
new file mode 100644
index 0000000..91d9eef
--- /dev/null
+++ b/themes/neonxp/assets/css/paper.css
@@ -0,0 +1,161 @@
+html,
+body {
+ padding: 0px;
+ margin: 0px;
+ border: none;
+}
+
+*,
+*::before,
+*::after {
+ box-sizing: border-box;
+}
+
+h1,
+h2,
+h3,
+h4,
+h5,
+h6 {
+ margin: 0;
+ /* line-height: 1; */
+}
+
+:root {
+ --bg: #ffffff;
+ --surface: #f8f9fa;
+ --border: #e3e3e3;
+ --text: #2e2e2e;
+ --text-secondary: #6c757d;
+ --link-color: rgb(40, 117, 251);
+}
+
+@media (prefers-color-scheme: dark) {
+ :root {
+ --bg: #1e1e1e;
+ --surface: #262626;
+ --border: #3a3a3a;
+ --text: #e0e0e0;
+ --text-secondary: #a8a8a8;
+ --shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
+ --link-color: rgb(103, 158, 254);
+ }
+}
+
+@media print {
+
+ *,
+ *:before,
+ *:after,
+ *:first-letter,
+ p:first-line,
+ div:first-line,
+ blockquote:first-line,
+ li:first-line {
+ background: transparent !important;
+ color: #000 !important;
+ box-shadow: none !important;
+ text-shadow: none !important;
+ }
+
+ :root {
+ --main-color: #000;
+ --background-color: #fff;
+ --main-background-color: #fff;
+ }
+
+ main {
+ font-size: 12pt !important;
+ line-height: 1.4 !important;
+ --background-color: #fff !important;
+ }
+
+ header {
+ display: none;
+ }
+
+ footer {
+ display: none;
+ }
+
+ article {
+ page-break-after: always;
+ border: 0 !important;
+ padding: 0 !important;
+ }
+
+ a[href] {
+ color: #000;
+ }
+}
+
+html {
+ background-color: var(--bg);
+ display: flex;
+ justify-content: center;
+ flex-direction: row;
+}
+
+body {
+ color: var(--text);
+ font-family: Arial,
+ Helvetica,
+ sans-serif;
+ line-height: 1.5;
+ width: 100%;
+ max-width: 1200px;
+}
+
+a {
+ color: var(--link-color);
+}
+
+header,
+footer {
+ padding: 0 2rem;
+}
+
+main {
+ padding: 0 2rem;
+}
+
+article {
+ background-color: var(--surface);
+ padding: 1.5em 2em;
+ margin: 1em 0;
+ border: 0.1px solid var(--border);
+}
+
+
+
+p {
+ orphans: 3;
+ widows: 4;
+}
+
+img {
+ max-width: 100%;
+}
+
+@media (max-width: 900px) {
+ main {
+ font-size: 15px;
+ line-height: 1.5;
+ padding: 0 2em;
+ }
+}
+
+@media (max-width: 480px) {
+ main {
+ font-size: 14px;
+ line-height: 1.4;
+ padding: 0 1em;
+ }
+}
+
+
+pre,
+code {
+ max-width: 100%;
+ overflow-x: scroll;
+} \ No newline at end of file
diff --git a/themes/neonxp/hugo.yaml b/themes/neonxp/hugo.yaml
new file mode 100644
index 0000000..4177323
--- /dev/null
+++ b/themes/neonxp/hugo.yaml
@@ -0,0 +1,18 @@
+baseURL: https://example.org/
+languageCode: en-US
+title: My New Hugo Site
+menus:
+ main:
+ - name: Home
+ pageRef: /
+ weight: 10
+ - name: Posts
+ pageRef: /posts
+ weight: 20
+ - name: Tags
+ pageRef: /tags
+ weight: 30
+module:
+ hugoVersion:
+ extended: false
+ min: 0.146.0
diff --git a/themes/neonxp/layouts/_default/section.atom.xml b/themes/neonxp/layouts/_default/section.atom.xml
new file mode 100644
index 0000000..9ddb7d2
--- /dev/null
+++ b/themes/neonxp/layouts/_default/section.atom.xml
@@ -0,0 +1,23 @@
+{{ print "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\" ?>"| safeHTML }}
+{{ print "<?xml-stylesheet type=\"text/css\" href=\"/css/atom.css\" ?>"| safeHTML }}
+<feed xmlns="http://www.w3.org/2005/Atom">
+ <title>{{ with .Title }}{{.}} on {{ end }}{{ .Site.Title }}</title>
+ <link rel="self" href="{{ .Permalink }}"/>
+ <updated>{{ .Date.Format "2006-01-02T15:04:05-0700" | safeHTML }}</updated>
+ <author>
+ <name>Alexander NeonXP Kiryukhin</name>
+ <email>i@neonxp.ru</email>
+ <uri>https://neonxp.ru/</uri>
+ </author>
+ <id>{{ .Permalink }}</id>
+ {{ range first 15 .Data.Pages }}
+ <entry>
+ <title>{{ .Title }}</title>
+ <link rel="alternate" href="{{ .Permalink }}"/>
+ <id>{{ .Permalink }}</id>
+ <published>{{ .Date.Format "2006-01-02T15:04:05-0700" | safeHTML }}</published>
+ <updated>{{ .Lastmod.Format "2006-01-02T15:04:05-0700" | safeHTML }}</updated>
+ <summary>{{ .Content | html }}</summary>
+ </entry>
+ {{ end }}
+</feed>
diff --git a/themes/neonxp/layouts/_partials/footer.html b/themes/neonxp/layouts/_partials/footer.html
new file mode 100644
index 0000000..2c30eaa
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/footer.html
@@ -0,0 +1 @@
+<p>&copy; 2007 — {{ now.Year }} Александр NeonXP Кирюхин. <a href="mailto:i@neonxp.ru">i@neonxp.ru</a></p> \ No newline at end of file
diff --git a/themes/neonxp/layouts/_partials/head.html b/themes/neonxp/layouts/_partials/head.html
new file mode 100644
index 0000000..7826e2a
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/head.html
@@ -0,0 +1,12 @@
+<meta charset="utf-8" />
+<meta name="viewport" content="width=device-width, initial-scale=1" />
+<link rel="icon" href="/favicon.ico" type="image/x-icon">
+{{ partial "opengraph.html" . }}
+<title>
+ {{ if .IsHome }}
+ {{ site.Title }}
+ {{ else }}
+ {{ printf "%s | %s" .Title site.Title }}
+ {{ end }}
+</title>
+{{ partialCached "head/css.html" . }} {{ partialCached "head/js.html" . }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/_partials/head/css.html b/themes/neonxp/layouts/_partials/head/css.html
new file mode 100644
index 0000000..9324758
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/head/css.html
@@ -0,0 +1,27 @@
+{{- with resources.Get "css/reset.css" }}
+{{- if hugo.IsDevelopment }}
+<link rel="stylesheet" href="{{ .RelPermalink }}">
+{{- else }}
+{{- with . | minify | fingerprint }}
+<link rel="stylesheet" href="{{ .RelPermalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous">
+{{- end }}
+{{- end }}
+{{- end }}
+{{- with resources.Get "css/paper.css" }}
+{{- if hugo.IsDevelopment }}
+<link rel="stylesheet" href="{{ .RelPermalink }}">
+{{- else }}
+{{- with . | minify | fingerprint }}
+<link rel="stylesheet" href="{{ .RelPermalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous">
+{{- end }}
+{{- end }}
+{{- end }}
+{{- with resources.Get "css/main.css" }}
+{{- if hugo.IsDevelopment }}
+<link rel="stylesheet" href="{{ .RelPermalink }}">
+{{- else }}
+{{- with . | minify | fingerprint }}
+<link rel="stylesheet" href="{{ .RelPermalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous">
+{{- end }}
+{{- end }}
+{{- end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/_partials/head/js.html b/themes/neonxp/layouts/_partials/head/js.html
new file mode 100644
index 0000000..1b7c18e
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/head/js.html
@@ -0,0 +1,16 @@
+<!-- {{- with resources.Get "js/main.js" }}
+ {{- $opts := dict
+ "minify" (not hugo.IsDevelopment)
+ "sourceMap" (cond hugo.IsDevelopment "external" "")
+ "targetPath" "js/main.js"
+ }}
+ {{- with . | js.Build $opts }}
+ {{- if hugo.IsDevelopment }}
+ <script src="{{ .RelPermalink }}"></script>
+ {{- else }}
+ {{- with . | fingerprint }}
+ <script src="{{ .RelPermalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script>
+ {{- end }}
+ {{- end }}
+ {{- end }}
+{{- end }} --> \ No newline at end of file
diff --git a/themes/neonxp/layouts/_partials/header.html b/themes/neonxp/layouts/_partials/header.html
new file mode 100644
index 0000000..7980a00
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/header.html
@@ -0,0 +1,2 @@
+<h1>{{ site.Title }}</h1>
+{{ partial "menu.html" (dict "menuID" "main" "page" .) }}
diff --git a/themes/neonxp/layouts/_partials/menu.html b/themes/neonxp/layouts/_partials/menu.html
new file mode 100644
index 0000000..ebad53f
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/menu.html
@@ -0,0 +1,50 @@
+{{- /*
+Renders a menu for the given menu ID.
+
+@context {page} page The current page.
+@context {string} menuID The menu ID.
+
+@example: {{ partial "menu.html" (dict "menuID" "main" "page" .) }}
+*/}}
+
+{{- $page := .page }}
+{{- $menuID := .menuID }}
+
+{{- with index site.Menus $menuID }}
+<nav>
+ <ul>
+ {{- partial "inline/menu/walk.html" (dict "page" $page "menuEntries" .) }}
+ </ul>
+</nav>
+{{- end }}
+
+{{- define "_partials/inline/menu/walk.html" }}
+{{- $page := .page }}
+{{- range .menuEntries }}
+{{- $attrs := dict "href" .URL }}
+{{- if $page.IsMenuCurrent .Menu . }}
+{{- $attrs = merge $attrs (dict "class" "active" "aria-current" "page") }}
+{{- else if $page.HasMenuCurrent .Menu .}}
+{{- $attrs = merge $attrs (dict "class" "ancestor" "aria-current" "true") }}
+{{- end }}
+{{- $name := .Name }}
+{{- with .Identifier }}
+{{- with T . }}
+{{- $name = . }}
+{{- end }}
+{{- end }}
+<li>
+ <a {{- range $k, $v :=$attrs }} {{- with $v }} {{- printf " %s=%q" $k $v | safeHTMLAttr }} {{- end }} {{- end -}}>
+ {{if .Pre}}
+ {{.Pre}}
+ {{end}}
+ {{ $name }}
+ </a>
+ {{- with .Children }}
+ <ul>
+ {{- partial "inline/menu/walk.html" (dict "page" $page "menuEntries" .) }}
+ </ul>
+ {{- end }}
+</li>
+{{- end }}
+{{- end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/_partials/terms.html b/themes/neonxp/layouts/_partials/terms.html
new file mode 100644
index 0000000..f826abb
--- /dev/null
+++ b/themes/neonxp/layouts/_partials/terms.html
@@ -0,0 +1,27 @@
+{{- /*
+For a given taxonomy, renders a list of terms assigned to the page.
+
+@context {page} page The current page.
+@context {string} taxonomy The taxonomy.
+
+@example: {{ partial "terms.html" (dict "taxonomy" "tags" "page" .) }}
+*/}}
+
+{{- $page := .page }}
+{{- $taxonomy := .taxonomy }}
+
+{{- with $page.GetTerms $taxonomy }}
+{{- if . }}
+<article>
+ {{- $label := (index . 0).Parent.LinkTitle }}
+ <div>
+ <h3>{{ $label }}:</h3>
+ <ul class="taxonomy">
+ {{- range . }}
+ <li><a href="{{ .RelPermalink }}">{{ .LinkTitle }}</a></li>
+ {{- end }}
+ </ul>
+ </div>
+ {{- end }}
+</article>
+{{- end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/baseof.html b/themes/neonxp/layouts/baseof.html
new file mode 100644
index 0000000..39dcbec
--- /dev/null
+++ b/themes/neonxp/layouts/baseof.html
@@ -0,0 +1,17 @@
+<!DOCTYPE html>
+<html lang="{{ site.Language.LanguageCode }}" dir="{{ or site.Language.LanguageDirection `ltr` }}">
+<head>
+ {{ partial "head.html" . }}
+</head>
+<body>
+ <header>
+ {{ partial "header.html" . }}
+ </header>
+ <main>
+ {{ block "main" . }}{{ end }}
+ </main>
+ <footer>
+ {{ partial "footer.html" . }}
+ </footer>
+</body>
+</html>
diff --git a/themes/neonxp/layouts/home.html b/themes/neonxp/layouts/home.html
new file mode 100644
index 0000000..1f26b97
--- /dev/null
+++ b/themes/neonxp/layouts/home.html
@@ -0,0 +1,21 @@
+{{ define "main" }}
+<article>
+ <h1>{{ .Title }}</h1>
+ {{ .Content }}
+</article>
+<div class="h-feed">
+ {{ range .Pages }}
+ <article class="h-entry">
+ <h2 class="p-name"><a class="u-url" href="{{ .RelPermalink }}">{{ .LinkTitle }}</a></h2>
+ {{if .Date }}
+ {{ $dateMachine := .Date | time.Format "2006-01-02 15:04:05-07:00" }}
+ {{ $dateHuman := .Date | time.Format ":date_long" }}
+ <time class="dt-published" datetime="{{ $dateMachine }}">{{ $dateHuman }}</time>
+ {{end}}
+ <div class="p-summary">
+ {{ .Summary }}
+ </div>
+ </article>
+ {{ end }}
+</div>
+{{ end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/page.html b/themes/neonxp/layouts/page.html
new file mode 100644
index 0000000..506b56a
--- /dev/null
+++ b/themes/neonxp/layouts/page.html
@@ -0,0 +1,37 @@
+{{ define "main" }}
+<div class="h-entry">
+ <article>
+ <h1 class="p-name">{{ .Title }}</h1>
+ {{if .Date }}
+ {{ $dateMachine := .Date | time.Format "2006-01-02T15:04:05-07:00" }}
+ {{ $dateHuman := .Date | time.Format ":date_long" }}
+ <time class="dt-published" datetime="{{ $dateMachine }}">{{ $dateHuman }}</time>
+ {{end}}
+ </article>
+ <article class="e-content">
+ {{ .Content }}
+ </article>
+ {{ partial "terms.html" (dict "taxonomy" "tags" "page" .) }}
+ {{if .Param "comments"}}
+ <h2>Комментарии</h2>
+ {{ range $key, $comment := where .Site.Data.comments "url" "eq" .Page.Path }}
+ <article>
+ <b>{{$comment.from}}:</b>
+ <p>{{$comment.comment}}</p>
+ </article>
+ {{ else }}
+ <article>Комментариев пока нет.</article>
+ {{ end }}
+
+ <article>
+ {{ $comment := (print "mailto:blog@neonxp.ru?subject=" .Page.Permalink | safeHTML) }}
+ Для отправки комментария достаточно отправить e-mail со своим комментарием
+ на адрес
+ <a href={{$comment}}>blog@neonxp.ru</a>, в теме нужно указать ссылку на
+ пост.<br />
+ Или просто нажать кнопку ниже. Всё очень просто :)<br />
+ <a class="btn-primary" href={{$comment}}>Написать комментарий</a>
+ </article>
+ {{end}}
+</div>
+{{ end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/section.html b/themes/neonxp/layouts/section.html
new file mode 100644
index 0000000..a330f20
--- /dev/null
+++ b/themes/neonxp/layouts/section.html
@@ -0,0 +1,26 @@
+{{ define "main" }}
+<article>
+ <h1>{{ .Title }}</h1>
+ {{ .Content }}
+</article>
+<div class="h-feed">
+
+ {{ range .Paginator.Pages }}
+ <article class="h-entry">
+ <h2 class="p-name"><a class="u-url" href="{{ .RelPermalink }}">{{ .LinkTitle }}</a></h2>
+ {{if .Date }}
+ {{ $dateMachine := .Date | time.Format "2006-01-02 15:04:05-07:00" }}
+ {{ $dateHuman := .Date | time.Format ":date_long" }}
+ <time class="dt-published" datetime="{{ $dateMachine }}">{{ $dateHuman }}</time>
+ {{end}}
+ <div class="p-summary">
+ {{ .Summary }}
+ </div>
+ <a class="btn-primary" href="{{ .RelPermalink }}">Читать дальше...</a>
+ </article>
+ {{ end }}
+ <article>
+ {{ partial "pagination.html" . }}
+ </article>
+</div>
+{{ end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/taxonomy.html b/themes/neonxp/layouts/taxonomy.html
new file mode 100644
index 0000000..ff8e552
--- /dev/null
+++ b/themes/neonxp/layouts/taxonomy.html
@@ -0,0 +1,11 @@
+{{ define "main" }}
+<article>
+ <h1>{{ .Title }}</h1>
+ {{ .Content }}
+</article>
+<article>
+ {{ range .Pages }}
+ <h2><a href="{{ .RelPermalink }}">{{ .LinkTitle }}</a></h2>
+ {{ end }}
+</article>
+{{ end }} \ No newline at end of file
diff --git a/themes/neonxp/layouts/term.html b/themes/neonxp/layouts/term.html
new file mode 100644
index 0000000..c2e7875
--- /dev/null
+++ b/themes/neonxp/layouts/term.html
@@ -0,0 +1,7 @@
+{{ define "main" }}
+ <h1>{{ .Title }}</h1>
+ {{ .Content }}
+ {{ range .Pages }}
+ <h2><a href="{{ .RelPermalink }}">{{ .LinkTitle }}</a></h2>
+ {{ end }}
+{{ end }}
diff --git a/themes/neonxp/static/favicon.ico b/themes/neonxp/static/favicon.ico
new file mode 100644
index 0000000..da16cb8
--- /dev/null
+++ b/themes/neonxp/static/favicon.ico
Binary files differ