styles.css

  1/*
  2 * SPDX-FileCopyrightText: Amolith <amolith@secluded.site>
  3 *
  4 * SPDX-License-Identifier: CC0-1.0
  5 */
  6
  7@font-face {
  8	font-family: 'Atkinson Hyperlegible';
  9	font-weight: normal;
 10	font-style: normal;
 11	font-display: swap;
 12	src: url("/static/fonts/regular-102a.woff2") format("woff2");
 13}
 14
 15@font-face {
 16	font-family: 'Atkinson Hyperlegible';
 17	font-weight: normal;
 18	font-style: italic;
 19	font-display: swap;
 20	src: url("/static/fonts/regular-102a.woff2") format("woff2");
 21}
 22
 23@font-face {
 24	font-family: 'Atkinson Hyperlegible';
 25	font-weight: bold;
 26	font-style: normal;
 27	font-display: swap;
 28	src: url("/static/fonts/bold-102a.woff2") format("woff2");
 29}
 30
 31@font-face {
 32	font-family: 'Atkinson Hyperlegible';
 33	font-weight: bold;
 34	font-style: italic;
 35	font-display: swap;
 36	src: url("/static/fonts/bolditalic-102a.woff2") format("woff2");
 37}
 38
 39html {
 40	margin: auto auto;
 41	color: var(--text);
 42	background: var(--page-background);
 43	font-family: 'Atkinson Hyperlegible', sans-serif;
 44	scroll-behavior: smooth;
 45}
 46
 47a {
 48	color: var(--link);
 49}
 50
 51a:visited {
 52	color: var(--link);
 53}
 54
 55/* Grid layout */
 56body {
 57	width: auto;
 58	min-height: 100vh;
 59}
 60
 61@supports (display: grid) {
 62	body {
 63		display: grid;
 64		grid-template-rows: [header] auto [main] 1fr [footer] auto;
 65	}
 66
 67	body>header,
 68	body>main,
 69	body>footer {
 70		display: grid;
 71		grid-template-columns:
 72			[page-start] minmax(1em, 1fr) [content] minmax(240px, 100ch) [page-end] minmax(1em, 1fr);
 73	}
 74
 75	body>main {
 76		grid-template-rows: [top-gutter] 1em [content] 1fr [bottom-gutter] 1em;
 77	}
 78
 79	body>footer {
 80		grid-template-rows: [top-gutter] 2em [content] 1fr [bottom-gutter] 0.5em;
 81	}
 82
 83	body>header {
 84		grid-template-rows: [top-gutter] 0.5em [content] 1fr [bottom-gutter] 0.5em;
 85	}
 86
 87	header .wrapper,
 88	main .wrapper,
 89	footer .wrapper {
 90		grid-row: content;
 91		grid-column: content;
 92	}
 93}
 94
 95/* End grid layout */
 96
 97h3 {
 98	margin-block: 1rem 0.5rem;
 99}
100
101h2,
102p {
103	margin-block-start: 0;
104	margin-block-end: 1rem;
105}
106
107.wrapper h2 {
108  margin: 0 0 1rem 0;
109}
110
111.wrapper h2:first-child {
112  margin-top: 0;
113}
114
115.two_column {
116	display: block;
117}
118
119.projects-grid {
120  display: grid;
121  grid-template-columns: repeat(2, 1fr);
122  gap: 1rem;
123  margin-bottom: 4rem;
124}
125
126.project.card {
127  height: 100%;
128  display: flex;
129  flex-direction: column;
130}
131
132.projects {
133	width: 100%;
134}
135
136.release_note.card:not(:target),
137.release_note.card:target,
138.return_to_project {
139	display: none;
140}
141
142.card {
143	position: relative;
144	border: 2px solid var(--card-border);
145	background: var(--card-background);
146	border-radius: 5px;
147	margin: 20px 0;
148	padding: 20px 20px 0 20px;
149	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
150}
151
152.card>h3 {
153	margin-top: 0;
154}
155
156.card>p:first-of-type {
157	margin-bottom: 16px;
158}
159
160.card>p:last-of-type {
161	margin-bottom: 16px;
162}
163
164.delete {
165	float: right;
166	font-size: 12px;
167}
168
169.close {
170	position: absolute;
171	top: 2px;
172	right: 3px;
173}
174
175.close>a {
176	font-size: 1em;
177	text-decoration: none;
178	color: var(--card-border);
179}
180
181@media (prefers-color-scheme: dark) {
182	.close>a {
183		color: var(--text);
184	}
185}
186
187.card>pre,
188.card>div>pre {
189	overflow: scroll;
190}
191
192header .wrapper {
193	display: flex;
194	flex-wrap: wrap;
195	justify-content: space-between;
196	align-content: center;
197}
198
199header h1 {
200	margin-block: 1.2rem;
201	color: var(--link);
202}
203
204header h1 a {
205	text-decoration: none;
206}
207
208header h1 a:hover {
209	border-bottom: 4px solid var(--link);
210}
211
212header nav {
213	display: flex;
214	justify-content: flex-end;
215	align-content: baseline;
216	flex: 1 1 auto;
217	margin-block: 1.2rem;
218}
219
220header nav a,
221header nav a:visited {
222	display: block;
223	text-decoration: underline;
224	color: var(--text);
225	font-size: 1.2rem;
226	font-weight: bold;
227	line-height: 1;
228	border-radius: 0.5rem;
229	padding: 0.6rem 0.5rem 0.4rem;
230}
231
232header nav a+a {
233	margin-inline-start: 1rem;
234}
235
236header nav a:last-of-type {
237	padding-inline-end: 0;
238}
239
240header nav a[href="/new"],
241header nav a[href="/new"]:visited {
242	text-decoration: none;
243	color: var(--action);
244	border-color: var(--action);
245	background-color: transparent;
246	border: 1px solid var(--action);
247}
248
249footer .wrapper {
250	display: flex;
251	flex-wrap: wrap;
252	justify-content: space-between;
253	align-content: center;
254}
255
256.release-notes-btn {
257	background: none;
258	border: none;
259	color: var(--link);
260	cursor: pointer;
261	text-decoration: underline;
262	padding: 0;
263	font: inherit;
264}
265
266[popover] {
267	margin: auto;
268	width: min(800px, 90vw);
269	max-height: 90vh;
270	border: 2px solid var(--card-border);
271	border-radius: 5px;
272	padding: 0;
273	background: var(--card-background);
274	color: var(--text);
275	overflow-y: auto;
276}
277
278[popover]:not(:popover-open) {
279	display: none;
280}
281
282.popover-content {
283	padding: 20px;
284}
285
286button[popovertarget] {
287	padding: 6px 12px;
288	background-color: var(--card-background);
289	border: 1px solid var(--card-border);
290	border-radius: 4px;
291	color: var(--text);
292	width: fit-content;
293	margin: auto 0;
294}
295
296button[popovertarget]:hover {
297	background-color: var(--card-border);
298}
299
300[popover]::backdrop {
301	background: rgba(0, 0, 0, 0.5);
302	backdrop-filter: blur(3px);
303}
304
305/* Mobile responsiveness */
306@media only screen and (max-width: 1000px) {
307	[popover] {
308		width: 95vw;
309	}
310
311	div[id] {
312		display: block;
313	}
314}
315
316@media (max-width: 850px) {
317  .projects-grid {
318    grid-template-columns: 1fr;
319  }
320}
321
322/* Forms */
323form {
324	width: 100%;
325	max-width: 50ch;
326	margin: 0 auto;
327	display: flex;
328	flex-direction: column;
329}
330
331form label {
332	font-weight: bold;
333	padding-block-end: 0.2rem;
334}
335
336fieldset {
337	position: relative;
338	border: 0 none;
339	background-color: var(--card-background);
340	margin-inline: -1px;
341	/* Line up with input boxes */
342	margin-block-start: 1rem;
343	padding-inline: 1rem;
344}
345
346fieldset legend {
347	position: absolute;
348	top: -1.5rem;
349	left: 0;
350	margin-inline: 1px;
351	padding: 0;
352	font-weight: bold;
353}
354
355fieldset h4 {
356	margin-inline-start: 0.25rem;
357	margin-block: 0.5rem;
358}
359
360.input {
361	display: flex;
362	flex-direction: column;
363	margin-block-end: 1rem;
364}
365
366.input-wrapper label {
367	padding-inline-start: 0.5rem;
368}
369
370.select-release .input {
371	display: block;
372}
373
374.button {
375	line-height: 1;
376	padding: 0.6rem 0.5rem 0.4rem;
377	font-weight: bold;
378	font-size: 1.2rem;
379	color: var(--action);
380	background-color: var(--page-background);
381	border: 1px solid var(--action);
382	border-radius: 0.5rem;
383	cursor: pointer;
384}
385
386form.login .button {
387	margin-block-start: 0.75rem;
388}
389
390/* End Forms */
391
392@media (prefers-reduced-motion) {
393
394	*,
395	*::before,
396	*::after {
397		animation-duration: 0s !important;
398		transition: none !important;
399		scroll-behavior: auto !important;
400	}
401}