diff --git a/assets/styles/base.scss b/assets/styles/base.scss
index 4d03a06a3..3b2801bfc 100644
--- a/assets/styles/base.scss
+++ b/assets/styles/base.scss
@@ -12,6 +12,19 @@ h1, h2, h3, h4, h5, h6, ol, ul, thead {
font-weight: revert;
margin: revert;
padding: revert;
+
+ &:hover > .hanchor {
+ opacity: 1;
+ }
+}
+
+.hanchor {
+ font-family: Inter;
+ margin-left: -1em;
+ opacity: 0.3;
+ transition: opacity 0.3s ease;
+ color: var(--secondary);
+
}
p, ul, text {
diff --git a/layouts/partials/textprocessing.html b/layouts/partials/textprocessing.html
index 2312aa461..8e8c99917 100644
--- a/layouts/partials/textprocessing.html
+++ b/layouts/partials/textprocessing.html
@@ -53,4 +53,8 @@
{{end}}
{{end}}
{{end}}
+
+{{/* Add copyable anchors */}}
+{{ $content = $content | replaceRE "()(.+)()" `${1}# ${3}${4}` }}
+
{{ $content | safeHTML }}