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 */
56.container {
57 width: auto;
58 min-height: 100vh;
59}
60
61@supports (display: grid) {
62 .container {
63 display: grid;
64 grid-template-rows: [header] auto [main] 1fr [footer] auto;
65 }
66
67 .container > header,
68 .container > main,
69 .container > footer {
70 display: grid;
71 grid-template-columns:
72 [page-start] minmax(1em, 1fr) [content] minmax(240px, 92ch) [page-end] minmax(1em, 1fr);
73 }
74
75 .container > main {
76 grid-template-rows: [top-gutter] 1em [content] 1fr [bottom-gutter] 1em;
77 }
78
79 .container > footer {
80 grid-template-rows: [top-gutter] 2em [content] 1fr [bottom-gutter] 0.5em;
81 }
82
83 .container > 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
97.two_column {
98 display: flex;
99 gap: 20px;
100 flex-direction: row;
101}
102
103.two_column > * > * {
104 margin: 20px 0;
105}
106
107.projects, .release_notes {
108 flex: 1 1 50%;
109}
110
111.release_note.card:not(:target) { display: none; }
112.release_note.card:target { display: block; }
113
114.return_to_project {
115 display: none;
116}
117
118.card {
119 border: 2px solid var(--card-border);
120 background: var(--card-background);
121 border-radius: 5px;
122 margin: 20px 0;
123 padding: 20px 20px 0 20px;
124 box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2),0 6px 20px 0 rgba(0,0,0,0.19);
125}
126
127.card > h3 {
128 margin-top: 0;
129}
130
131.card > p:first-of-type {
132 margin-bottom: 16px;
133}
134
135.card > p:last-of-type {
136 margin-bottom: 16px;
137}
138
139.close, .delete { float: right; }
140.delete { font-size: 12px; }
141.close > a {
142 text-decoration: none;
143 color: var(--card-border);
144}
145@media (prefers-color-scheme: dark) {
146 .close > a {
147 color: var(--text);
148 }
149}
150
151.card > pre, .card > div > pre { overflow: scroll; }
152
153.old-wrapper { /* used on non-home pages */
154 max-width: 500px;
155 margin: auto auto;
156}
157
158header .wrapper {
159 display: flex;
160 flex-wrap: wrap;
161 justify-content: space-between;
162 align-content: center;
163}
164
165header h1 {
166 margin-block: 1.2rem;
167}
168
169header nav {
170 display: flex;
171 justify-content: flex-end;
172 align-content: baseline;
173 flex: 1 1 auto;
174 margin-block: 1.2rem;
175}
176
177header nav a,
178header nav a:visited {
179 display: block;
180 text-decoration: underline;
181 color: var(--text);
182 font-size: 1.2rem;
183 font-weight: bold;
184 line-height: 1;
185 border-radius: 0.5rem;
186 padding: 0.6rem 0.5rem 0.4rem;
187}
188
189header nav a + a {
190 margin-inline-start: 1rem;
191}
192
193header nav a:last-of-type {
194 padding-inline-end: 0;
195}
196
197header nav a[href="/new"],
198header nav a[href="/new"]:visited {
199 text-decoration: none;
200 color: var(--action);
201 border-color: var(--action);
202 background-color: transparent;
203 border: 1px solid var(--action);
204}
205
206
207footer .wrapper {
208 display: flex;
209 flex-wrap: wrap;
210 justify-content: space-between;
211 align-content: center;
212}
213
214@media only screen and (max-width: 1000px) {
215 div[id] {
216 display: block;
217 }
218
219 .two_column {
220 flex-direction: column;
221 }
222
223 .projects, .release_notes {
224 overflow: visible;
225 flex: 1 1 100%;
226 }
227
228 .return_to_project {
229 display: block;
230 }
231
232 .close {
233 display: none;
234 }
235}
236