improve the build system

This commit is contained in:
2025-04-14 19:11:59 +02:00
parent c17bea6cb2
commit 247dcbe817
24 changed files with 59 additions and 61 deletions

8
styles/icons.css Normal file
View File

@@ -0,0 +1,8 @@
:root {
--light-theme-switch-icon: url("./moon.svg");
--dark-theme-switch-icon: url("./sun.svg");
--light-narrow-layout-switch-icon: url("./wide_dark.svg");
--light-wide-layout-switch-icon: url("./narrow_dark.svg");
--dark-narrow-layout-switch-icon: url("./wide_light.svg");
--dark-wide-layout-switch-icon: url("./narrow_light.svg");
}

391
styles/styles.css Normal file
View File

@@ -0,0 +1,391 @@
:root {
--light-fg-color: black;
--light-bg-color: white;
--light-alt-bg-color: #FFFFD0;
--light-field-hover-bg-color: #F0F0F0;
--light-field-active-bg-color: #E0E0E0;
--light-link-idle-color: darkred;
--light-sep-color: gainsboro;
--dark-fg-color: white;
--dark-bg-color: #202020;
--dark-alt-bg-color: #101010;
--dark-field-hover-bg-color: #000000;
--dark-field-active-bg-color: #404040;
--dark-link-idle-color: #ff8e8e;
--dark-sep-color: #2e2e2e;
}
:root {
color-scheme: light dark;
--nav-fg-color: white;
--nav-bg-color: darkred;
--nav-bg-color-selected: #C00000;
--text-subtle-color: gray;
}
@media (prefers-color-scheme: light) {
:root {
--fg-color: var(--light-fg-color);
--bg-color: var(--light-bg-color);
--alt-bg-color: var(--light-alt-bg-color);
--field-hover-bg-color: var(--light-field-hover-bg-color);
--field-active-bg-color: var(--light-field-active-bg-color);
--link-idle-color: var(--light-link-idle-color);
--theme-switch-icon: var(--light-theme-switch-icon);
--narrow-layout-switch-icon: var(--light-narrow-layout-switch-icon);
--wide-layout-switch-icon: var(--light-wide-layout-switch-icon);
--fg-gnu-head: var(--dark-gnu-head);
--bg-gnu-head: var(--light-gnu-head);
--sep-color: var(--light-sep-color);
}
[data-color-scheme="invert"] {
--fg-color: var(--dark-fg-color);
--bg-color: var(--dark-bg-color);
--alt-bg-color: var(--dark-alt-bg-color);
--field-hover-bg-color: var(--dark-field-hover-bg-color);
--field-active-bg-color: var(--dark-field-active-bg-color);
--link-idle-color: var(--dark-link-idle-color);
--theme-switch-icon: var(--dark-theme-switch-icon);
--narrow-layout-switch-icon: var(--dark-narrow-layout-switch-icon);
--wide-layout-switch-icon: var(--dark-wide-layout-switch-icon);
--fg-gnu-head: var(--light-gnu-head);
--bg-gnu-head: var(--dark-gnu-head);
--sep-color: var(--dark-sep-color);
}
}
@media (prefers-color-scheme: dark) {
:root {
--fg-color: var(--dark-fg-color);
--bg-color: var(--dark-bg-color);
--alt-bg-color: var(--dark-alt-bg-color);
--field-hover-bg-color: var(--dark-field-hover-bg-color);
--field-active-bg-color: var(--dark-field-active-bg-color);
--link-idle-color: var(--dark-link-idle-color);
--theme-switch-icon: var(--dark-theme-switch-icon);
--narrow-layout-switch-icon: var(--dark-narrow-layout-switch-icon);
--wide-layout-switch-icon: var(--dark-wide-layout-switch-icon);
--fg-gnu-head: var(--light-gnu-head);
--bg-gnu-head: var(--dark-gnu-head);
--sep-color: var(--dark-sep-color);
}
[data-color-scheme="invert"] {
--fg-color: var(--light-fg-color);
--bg-color: var(--light-bg-color);
--alt-bg-color: var(--light-alt-bg-color);
--field-hover-bg-color: var(--light-field-hover-bg-color);
--field-active-bg-color: var(--light-field-active-bg-color);
--link-idle-color: var(--light-link-idle-color);
--theme-switch-icon: var(--light-theme-switch-icon);
--narrow-layout-switch-icon: var(--light-narrow-layout-switch-icon);
--wide-layout-switch-icon: var(--light-wide-layout-switch-icon);
--fg-gnu-head: var(--dark-gnu-head);
--bg-gnu-head: var(--light-gnu-head);
--sep-color: var(--light-sep-color);
}
}
:root {
--layout-switch-icon: var(--narrow-layout-switch-icon);
}
[data-layout="wide"] {
--layout-switch-icon: var(--wide-layout-switch-icon)
}
html {
background-color: var(--bg-color);
min-height: calc(100% - 32px);
margin: 0;
}
body {
font-family: "Noto Sans", sans-serif;
font-size: 16px;
display: flex;
flex-direction: column;
color: var(--fg-color);
background-color: var(--bg-color);
margin: 0;
}
header {
display: flex;
padding: 1.5em 0;
position: relative;
background-color: var(--bg-color);
align-items: center;
justify-content: space-between;
width: min(90%, 50em);
margin: auto;
}
[data-layout="wide"] header {
width: 90%;
}
header .buttons {
display: flex;
flex-direction: column;
align-items: center;
}
.light-dark-switch {
cursor: pointer;
content: var(--theme-switch-icon);
width: 20px;
}
.layout-switch {
cursor: pointer;
content: var(--layout-switch-icon);
width: 20px;
}
a {
color: var(--link-idle-color);
}
header * {
margin: 8px 0;
}
.header-title {
font-size: 2em;
font-weight: bold;
}
.header-subtitle {
color: var(--text-subtle-color);
font-size: 1.3em;
}
.full-width {
width: 100%;
}
.img-text-container {
position: relative;
}
.img-text {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
display: flex;
justify-content: center;
align-items: center;
opacity: 100%;
color: var(--fg-color);
z-index: 1;
pointer-events: none;
}
.countdown {
font-family: monospace;
font-weight: bold;
font-size: 48px;
text-align: center;
}
.countdown-bg {
opacity: 40%;
z-index: 0;
}
nav {
background-color: var(--nav-bg-color);
color: var(--nav-fg-color);
user-select: none;
}
nav div {
width: min(90%, 50em);
margin: auto;
}
[data-layout="wide"] nav div {
width: 90%;
}
main {
flex-grow: 1;
padding: 16px;
width: min(90%, 50em);
margin: auto;
}
[data-layout="wide"] main {
width: 90%;
}
.gnu-head {
content: var(--fg-gnu-head);
}
footer {
border-top: 1px solid var(--sep-color);
color: gray;
padding: 1em;
text-align: center;
}
footer>* {
margin: 8px 0;
}
h1 {
font-size: 1.5em;
}
h2 {
font-size: 1.25em;
}
h3 {
font-size: 1em;
}
table {
border-spacing: 0;
border: 1px solid var(--sep-color);
}
th, td {
background-color: var(--alt-bg-color);
border: 1px solid var(--sep-color);
padding: 4px;
}
ul li {
margin: 8px 0;
}
ol li {
margin: 8px 0;
}
@media (width >= 500px) {
figure.aside {
width: 200px;
margin: 0 0 16px 16px;
float: right;
}
}
figure img,svg,inserted-svg {
width: 100%;
height: auto;
}
figcaption {
font-style: italic;
}
nav ul {
width: 100%;
height: 100%;
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
margin: 0;
padding: 0;
list-style-type: none;
}
[data-layout="wide"] nav ul {
justify-content: left;
margin-left: -1em;
}
@media (width < 50rem) {
nav ul {
flex-direction: column;
}
nav ul li {
width: 100%;
}
}
nav ul li {
margin: 0;
}
nav ul li a {
display: block;
padding: .5em 1em;
text-align: center;
text-decoration: none;
color: var(--nav-fg-color);
font-weight: bold;
transition: background-color .3s;
}
nav ul li a:hover {
background-color: var(--nav-bg-color-selected);
color: var(--nav-fg-color);
}
nav ul li a:active {
color: var(--nav-fg-color);
}
nav ul li a:visited {
color: var(--nav-fg-color);
}
@media (width >= 50rem) {
:not([data-layout="wide"]) body {
margin: 0 auto;
}
[data-layout="wide"] body {
margin: 0;
}
}
@media (width < 50rem) {
body {
margin: 0;
}
.img-text {
position: relative;
margin-bottom: 32px;
}
.layout-switch {
display: none;
}
}
@media print {
.light-dark-switch {
display: none;
}
.layout-switch {
display: none;
}
nav {
display: none;
}
}