{{ $label }}:
+-
+ {{- range . }}
+
- {{ .LinkTitle }} + {{- end }} +
From 49458f5ffd5a48c465117ec27f6437683f75acc1 Mon Sep 17 00:00:00 2001
From: Alexander Neonxp Kiryukhin
Date: Sat, 31 Jan 2026 20:38:50 +0300
Subject: initial
---
themes/neonxp/archetypes/default.md | 5 +
themes/neonxp/assets/css/main.css | 183 ++++++++++++++++++++++++
themes/neonxp/assets/css/paper.css | 161 +++++++++++++++++++++
themes/neonxp/hugo.yaml | 18 +++
themes/neonxp/layouts/_default/section.atom.xml | 23 +++
themes/neonxp/layouts/_partials/footer.html | 1 +
themes/neonxp/layouts/_partials/head.html | 12 ++
themes/neonxp/layouts/_partials/head/css.html | 27 ++++
themes/neonxp/layouts/_partials/head/js.html | 16 +++
themes/neonxp/layouts/_partials/header.html | 2 +
themes/neonxp/layouts/_partials/menu.html | 50 +++++++
themes/neonxp/layouts/_partials/terms.html | 27 ++++
themes/neonxp/layouts/baseof.html | 17 +++
themes/neonxp/layouts/home.html | 21 +++
themes/neonxp/layouts/page.html | 37 +++++
themes/neonxp/layouts/section.html | 26 ++++
themes/neonxp/layouts/taxonomy.html | 11 ++
themes/neonxp/layouts/term.html | 7 +
themes/neonxp/static/favicon.ico | Bin 0 -> 8772 bytes
19 files changed, 644 insertions(+)
create mode 100644 themes/neonxp/archetypes/default.md
create mode 100644 themes/neonxp/assets/css/main.css
create mode 100644 themes/neonxp/assets/css/paper.css
create mode 100644 themes/neonxp/hugo.yaml
create mode 100644 themes/neonxp/layouts/_default/section.atom.xml
create mode 100644 themes/neonxp/layouts/_partials/footer.html
create mode 100644 themes/neonxp/layouts/_partials/head.html
create mode 100644 themes/neonxp/layouts/_partials/head/css.html
create mode 100644 themes/neonxp/layouts/_partials/head/js.html
create mode 100644 themes/neonxp/layouts/_partials/header.html
create mode 100644 themes/neonxp/layouts/_partials/menu.html
create mode 100644 themes/neonxp/layouts/_partials/terms.html
create mode 100644 themes/neonxp/layouts/baseof.html
create mode 100644 themes/neonxp/layouts/home.html
create mode 100644 themes/neonxp/layouts/page.html
create mode 100644 themes/neonxp/layouts/section.html
create mode 100644 themes/neonxp/layouts/taxonomy.html
create mode 100644 themes/neonxp/layouts/term.html
create mode 100644 themes/neonxp/static/favicon.ico
(limited to 'themes')
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 ""| safeHTML }}
+{{ print ""| safeHTML }}
+
© 2007 — {{ now.Year }} Александр NeonXP Кирюхин. i@neonxp.ru
\ 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 @@ + + + +{{ partial "opengraph.html" . }} +{{$comment.comment}}
+