:root {
--width: 780px;
--font-scale-large: 1.6rem;
--font-scale-regular: 1.1rem;
--font-scale-small: 1rem;
--font-scale-very-large: 1.95rem;
--font-scale-very-small: 0.9rem;
--font-scale-very-very-large: 2.2rem;
--font-main: ui-serif, Rockwell, 'Rockwell Nova', 'Roboto Slab', 'DejaVu Serif', 'Sitka Small', serif;
--font-secondary: system-ui, sans-serif;
--font-scale: 1em;
--border-radius: 8px;
--magnification: 1.06;
--no-text-decoration: none;
--text-transform: lowercase;
--transition-duration: 0.6s;
}
/* Colors */
@media (prefers-color-scheme: light) {
:root {
--accent-color: #f4ede8;
--background-color: #faf4ed;
--heading-color: #907aa9;
--text-color: #575279;
--link-color: #f37375;
--visited-color: #f5978c;
--code-background-color: #fffaf3;
--code-color: #222;
--blockquote-color: #fffaf3;
}
}
@media (prefers-color-scheme: dark) {
:root {
--accent-color: #21202e;
--background-color: #191724;
--heading-color: #c4a7e7;
--text-color: #e0def4;
--link-color: #ebbcba;
--visited-color: #8b6fcb;
--code-background-color: #1f1d2e;
--code-color: #ddd;
--blockquote-color: #1f1d2e;
}
}
/* Global resets */
*,
*::before,
*::after {
box-sizing: border-box;
}
html {
-moz-text-size-adjust: none;
-webkit-text-size-adjust: none;
text-size-adjust: none;
-webkit-font-smoothing: antialiased;
}
/* Basic styles */
body {
margin: 10px auto;
padding: 5px;
width: var(--width);
max-width: 93%;
font-family: var(--font-main);
font-size: var(--font-scale-regular);
line-height: 1.5;
text-align: left;
color: var(--text-color);
background-color: var(--background-color);
word-wrap: break-word;
overflow-wrap: break-word;
}
/* Headings */
.title h1 {
display: flex;
margin: auto;
font-size: var(--font-scale-very-very-large);
font-weight: 800;
align-items: center;
}
/* .title h1::before {
margin: 0 12px 2px 0;
content: "";
background: url("INSERT URL HERE")
no-repeat;
width: 40px;
height: 40px;
background-size: 40px;
border-radius: var(--border-radius);
} */
h1,
h2,
h3,
h4,
h5,
h6 {
font-family: var(--font-main);
color: var(--heading-color);
text-transform: var(--text-transform);
}
h1 {
font-size: var(--font-scale-very-large);
font-weight: 800;
margin-top: 0;
}
h2 {
font-size: var(--font-scale-large);
font-weight: 800;
}
h3 {
font-size: var(--font-scale-large);
font-weight: 600;
}
strong,
b {
color: var(--heading-color);
}
.home h3 {
margin-bottom: -1.2em;
}
/* Links */
a,
main a {
color: var(--link-color);
text-decoration: var(--no-text-decoration);
}
a:hover,
main a:hover {
text-decoration: underline;
text-decoration-style: wavy;
}
a.title,
.title:hover {
color: var(--text-color);
text-decoration: var(--no-text-decoration);
}
.blog-posts a {
float: left;
white-space: nowrap;
}
.blog-posts a:visited,
.post main a:visited {
color: var(--visited-color);
}
.blog-posts li {
overflow: hidden;
}
/* Form elements */
input,
button,
textarea,
select {
margin: 2px 0 3px 0;
padding: 4px 8px 4px 6px;
font: inherit;
box-sizing: border-box;
color: var(--link-color);
background: var(--accent-color);
border: 2px solid var(--link-color);
border-radius: var(--border-radius);
}
button {
cursor: pointer;
transition: transform var(--transition-duration);
}
button:hover a {
text-decoration: var(--no-text-decoration);
}
button:hover {
transition: transform var(--transition-duration);
transform: scale(var(--magnification)) rotate(2deg);
}
button:active {
transform: scale(0.8);
}
legend {
margin: 20px 0;
font-weight: bold;
}
label {
display: block;
font-weight: bold;
}
input,
textarea {
margin: 0 0 10px;
padding: 5px 10px;
color: var(--text-color);
background: var(--accent-color);
}
input {
width: 55%;
}
textarea {
width: 95%;
}
input[type="button"],
input[type="submit"],
input[type="reset"],
input[type="email"] {
margin: 0 0 20px;
padding: 7px;
font-family: var(--font-secondary);
font-weight: bold;
color: var(--background-color);
background: var(--link-color);
border-radius: var(--border-radius);
cursor: pointer;
text-transform: var(--text-transform);
}
::placeholder {
color: var(--text-color);
opacity: 0.8;
text-transform: var(--text-transform);
}
/* Misc elements */
time {
font-family: var(--font-secondary);
font-style: normal;
font-size: var(--font-scale-small);
}
p time {
display: block;
margin: -15px 0 25px;
}
p time::before {
content: "🗓️";
}
hr {
border: 1px dashed var(--accent-color);
}
blockquote {
margin: 5px 0;
padding: 5px 25px;
background: var(--accent-color);
border-radius: var(--border-radius);
}
code {
background-color: var(--code-background-color);
}
/* Images */
img {
display: block;
margin: 0 auto 25px auto;
max-width: 100%;
max-height: 100%;
border-radius: var(--border-radius);
transition: transform var(--transition-duration);
}
img:hover {
transition: transform var(--transition-duration);
transform: scale(var(--magnification)) rotate(2deg);
}
img:active {
transform: scale(0.8);
}
/* Image Lightbox */
#lightbox {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.8);
display: flex;
justify-content: center;
align-items: center;
z-index: 9999;
visibility: hidden;
opacity: 0;
transition: transform var(--transition-duration);
}
#lightbox img {
max-width: 90%;
max-height: 90%;
}
#lightbox img:hover {
transform: none;
transition: transform var(--transition-duration);
}
#lightbox img:active {
transform: scale(0.8);
}
#lightbox:target {
visibility: visible;
opacity: 1;
}
/* Image Caption */
figcaption {
display: table;
width: auto;
margin: 0 auto 25px;
margin: 1em auto 2em;
padding: 5px 12px;
font-family: var(--font-secondary);
font-size: var(--font-scale-small);
color: var(--text-color);
opacity: 0.8;
text-align: center;
background: var(--accent-color);
border-radius: var(--border-radius);
}
/* Tags */
.tags {
font-size: var(--font-scale-small);
text-transform: var(--text-transform);
}
.tags a {
display: inline-block;
margin: 5px 5px 5px 0;
padding: 4px 10px;
text-decoration: var(--no-text-decoration);
background: var(--accent-color);
border-radius: var(--border-radius);
transition: transform var(--transition-duration);
}
.tags a:hover {
text-decoration: var(--no-text-decoration);
transform: scale(var(--magnification)) rotate(2deg);
}
.tags a:active {
transform: scale(0.8);
}
/* .tags a[href="/archive/?q=2025"],
.tags a[href="/archive/?q=2024"] {
display: none;
} */
/* Navigation */
nav {
margin: 5px 0 20px;
font-family: var(--font-main);
line-height: 2.3;
text-transform: var(--text-transform);
}
nav p {
display: inline;
}
nav a {
margin: 0 2px 5px 0;
padding: 6px 8px;
font-size: var(--font-scale-small);
font-weight: bold;
color: var(--link-color);
text-decoration: var(--no-text-decoration);
border: 2px solid var(--link-color);
border-radius: var(--border-radius);
}
nav a:hover {
text-decoration: var(--no-text-decoration);
background-color: var(--accent-color);
}
/* Highlight active menu item */
.home nav .nav-home a,
.blog nav .nav-blog a,
.contact nav .nav-contact a {
background: var(--accent-color);
}
/* Footer */
footer {
padding: 20px 0 !important;
font-family: var(--font-main);
font-size: var(--font-scale-small);
text-align: center;
}
footer a {
text-decoration: var(--no-text-decoration);
}
footer strong {
font-size: var(--font-scale-regular);
font-style: bold;
}
footer span:has(a[href="https://bearblog.dev"])
{
display: none;
}
/* Blog list and post */
ul.blog-posts {
list-style-type: none;
padding: 1.2em 0 0;
}
ul.blog-posts li {
display: flex;
}
ul.blog-posts li span {
overflow: hidden;
flex: 0 0 140px;
}
ul.blog-posts li a {
float: left;
margin-bottom: 0.5em;
text-decoration: var(--no-text-decoration);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
max-width: calc(100% - 110px);
}
ul.blog-posts li a:visited {
color: var(--visited-color);
}
ul.blog-posts li a:hover {
text-decoration: underline;
text-decoration-style: wavy;
}
ul.blog-posts li time {
font-size: var(--font-scale-regular);
}
.post main {
padding: 0.3em 0 0 0;
}
/* Misc styles */
.inline {
width: auto !important;
}
.code,
.highlight {
margin-block-start: 1em;
margin-block-end: 1em;
padding: 1px 15px;
overflow-x: auto;
background-color: var(--accent-color);
border-radius: var(--border-radius);
}
/* Upvote button */
.upvote-button svg {
display: none;
}
.upvote-button {
font-family: var(--font-main);
}
.upvote-button::before {
content: "🩷";
font-size: var(--font-scale-large);
color: var(--text-color);
}
.upvote-button[disabled] {
cursor: default;
}
.upvote-button[disabled]::before {
content: "💘";
font-size: var(--font-scale-large);
color: var(--link-color);
}
.upvote-button.upvoted {
color: var(--link-color) !important;
}
/* Tables */
table {
width: 100%;
font-family: var(--font-secondary);
color: var(--background-color);
text-align: left;
background-color: var(--link-color);
}
thead th,
tfoot th,
tfoot td {
padding: 3px 0 3px 7px;
}
td {
padding: 7px 0 7px 8px;
font-size: var(--font-scale-regular);
color: var(--text-color);
}
tbody tr:nth-child(odd) {
background-color: var(--accent-color);
}
tbody tr:nth-child(even) {
background-color: var(--background-color);
}
/* Print styles */
@media print {
body {
color: #000;
background: #fff;
}
h1,
h2,
h3 {
line-height: 1.3;
}
a,
main a {
color: #000;
text-decoration: none;
}
blockquote,
code {
margin: 0;
padding: 0 1.5em;
background: #fff;
border: none;
}
nav,
footer,
.tags,
.upvote-button {
display: none !important;
}
}
/* Addons */
/* Search */
#searchInput {
width: 80%;
margin: auto;
padding: 0.55em;
}
/* Announcement bar */
.bar {
overflow-wrap: break-word;
text-wrap: wrap;
margin: 20px 0;
padding: 15px;
font-size: var(--font-scale-small);
line-height: 1.5;
font-weight: 500;
color: var(--text-color);
text-align: center;
background: rgb(63, 94, 251);
background: radial-gradient(circle, var(--background-color) 0%, var(--accent-color) 100%);
border: 2px solid var(--accent-color);
border-radius: var(--border-radius);
text-transform: none;
}
.bar a {
margin: 0;
padding: 0;
font-size: inherit;
color: var(--link-color);
text-decoration: underline;
text-decoration-thickness: 1px;
text-underline-offset: 3px;
text-decoration-style: wavy;
border: none;
}
.bar a:hover {
background: none;
}
/* notion-like callouts */
.callout {
font-size: 95%;
border-radius: var(--border-radius);
padding: 1em;
}
@media (prefers-color-scheme: light) {
.disclaimer_callout {
background: rgb(251, 236, 221);
}
.note_callout {
background: rgb(251, 243, 219);
}
.eta_callout {
background: rgba(249, 238, 243, 0.8);
}
.important_callout {
background: rgb(253, 235, 236);
}
}
@media (prefers-color-scheme: dark) {
.disclaimer_callout {
background: rgb(71, 45, 1);
}
.note_callout {
background: rgba(240, 165, 15, 0.13);
}
.eta_callout {
background: rgba(225,71,174,.11);
}
.important_callout {
background: rgba(209, 46, 46, 0.11);
}
}
<!--Search-->
<!--<script src="https://cdn.jsdelivr.net/gh/hermanmartinus/bear-plugins/plugins/search-posts.js"></script>-->
<!--Paginated Posts Page-->
<!--<script src="https://cdn.jsdelivr.net/gh/hermanmartinus/bear-plugins/plugins/pagination.js"></script>-->
<!--Lightbox-->
<script>
// Immediately Invoked Function Expression (IIFE)
(function () {
// Check if the body has the class 'books'
if (document.body.classList.contains("books")) {
// Exit if the class 'books' is present
return;
}
// Create modal elements dynamically
const modal = document.createElement("div");
modal.style.display = "none";
modal.style.position = "fixed";
modal.style.zIndex = "1000";
modal.style.left = "0";
modal.style.top = "0";
modal.style.width = "100%";
modal.style.height = "100%";
modal.style.backgroundColor = "rgba(0, 0, 0, 0.8)";
modal.style.backdropFilter = "blur(5px)";
modal.style.overflow = "auto";
const modalImage = document.createElement("img");
modalImage.style.maxWidth = "90%";
modalImage.style.maxHeight = "90%";
modalImage.style.margin = "auto";
modalImage.style.display = "block";
modalImage.style.position = "absolute";
modalImage.style.top = "50%";
modalImage.style.left = "50%";
modalImage.style.transform = "translate(-50%, -50%)";
const closeButton = document.createElement("span");
closeButton.innerHTML = "×";
closeButton.style.position = "absolute";
closeButton.style.top = "20px";
closeButton.style.right = "30px";
closeButton.style.color = "white";
closeButton.style.fontSize = "40px";
closeButton.style.fontWeight = "bold";
closeButton.style.cursor = "pointer";
modal.appendChild(modalImage);
modal.appendChild(closeButton);
document.body.appendChild(modal);
// Function to open the image in a modal
function openImage(src) {
modal.style.display = "block";
modalImage.src = src;
}
// Function to close the modal
function closeImage() {
modal.style.display = "none";
}
// Automatically add click event to all images on the page
document.addEventListener("DOMContentLoaded", function () {
const images = document.querySelectorAll("img");
images.forEach((image) => {
image.addEventListener("click", function () {
openImage(this.src);
});
});
// Close modal when clicking the close button
closeButton.addEventListener("click", closeImage);
});
})();
</script>