views/style.css (view raw)
1:root {
2 --bg-page: #f4f4f4;
3 --bg-dark: #ccc;
4 --bg-limited: #e4e4e4;
5 --hover: #ddd;
6 --fg: #222;
7 --fg-subtle: #6a6a6a;
8 --fg-limited: #777;
9 --hl: #ddd;
10 --header: #f4f4f4;
11 --header-fg: var(--fg);
12}
13
14::selection {
15 background: var(--fg-limited);
16 color: white;
17}
18
19@media (prefers-color-scheme: dark) {
20 :root {
21 --bg-page: #111;
22 --bg-dark: #222;
23 --fg: #ccc;
24 --hl: #444;
25 --fg-subtle: #ccc;
26 --fg-limited: #509c93;
27 --bg-limited: #333;
28 --header: #509c93;
29 --header-fg: #111;
30 --hover: (--bg-limited);
31 }
32}
33
34* {
35 font-size: 1rem !important;
36}
37
38body {
39 padding: 0px;
40 margin: 0px;
41 background: var(--bg-page);
42 color: var(--fg);
43 font-size: 1rem !important;
44 word-wrap: break-word;
45 font-family: "InterVar", -apple-system, sans-serif, "Noto Color Emoji";
46 line-height: 1.2;
47 overscroll-behavior-y: contain;
48 overflow: overlay;
49}
50pre, code {
51 white-space: pre-wrap;
52}
53blockquote {
54 margin-left: 0em;
55 margin-bottom: 0em;
56 padding-left: 0.5em;
57 border-left: 1px solid var(--fg-subtle);
58}
59cite {
60 margin-left: 2em;
61}
62table {
63 display: block;
64 max-width: 100%;
65 overflow-x: auto;
66}
67
68form, input, textarea {
69 font-family: "InterVar", -apple-system, sans-serif, "Noto Color Emoji";
70}
71p {
72 margin-top: 1em;
73 margin-bottom: 1em;
74}
75input {
76 background: var(--bg-page);
77 color: var(--fg);
78 font-size: 1.0em;
79 line-height: 1.2em;
80 padding: 0.4em;
81 border: 1px solid var(--hl);
82}
83#honkform input {
84 font-size: 0.8em;
85}
86body > header {
87 background: var(--header);
88 max-width: 100%;
89 max-height: 100%;
90 margin: 0px;
91 padding: 1em 0em 2em 0em;
92 font-size: 1.5em;
93 color: var(--header-fg);
94}
95body > header span {
96 margin-left: 2em;
97}
98
99.easylinks a {
100 text-decoration: none !important;
101 color: var(--header-fg);
102}
103
104header > details {
105 padding: 1em 1em 1em 1em;
106 color: var(--header-fg);
107 position: absolute;
108 top: 0;
109 left: 0;
110 display: inline;
111 overflow: auto;
112 opacity: 1;
113 overscroll-behavior: contain;
114 z-index: 2;
115}
116header > details[open] {
117 color: var(--fg);
118 padding: 1em 1em 0em 1em;
119 background: var(--bg-dark);
120 margin-bottom: 1em;
121 opacity: 1.0;
122}
123header > details summary span {
124 display: none;
125}
126header > details[open] summary span {
127 display: inline;
128}
129header > details li {
130 margin: 1em 0em 1em 0em;
131}
132details summary {
133 cursor: pointer;
134}
135main {
136 max-width: 655px;
137 margin: auto;
138 font-size: 1.5em;
139}
140hr {
141 border-color: var(--hl);
142}
143.info {
144 background: var(--bg-page);
145 border: 1px solid var(--hl);
146 margin-bottom: 1em;
147 padding: 0em 1em 0em 1em;
148 margin-top: 1em;
149}
150.info div {
151 margin-top: 1em;
152 margin-bottom: 1em;
153}
154label {
155 font-size: 0.8em;
156}
157label.button, button, select {
158 border: none;
159 font-size: 1rem;
160 font-family: "InterVar", -apple-system, sans-serif, "Noto Color Emoji";
161 color: var(--fg);
162 padding: 0.2em;
163 background: var(--bg-dark);
164 white-space: nowrap;
165}
166
167button:hover {
168 background: var(--hover);
169}
170
171.buttonarray {
172 margin-top: -2.0em;
173}
174.buttonarray button, .buttonarray > span {
175 margin-top: 2.0em;
176 display: inline-block;
177}
178button a {
179 text-decoration: none;
180}
181button {
182 cursor: pointer;
183}
184form {
185 margin-top: 1em;
186}
187textarea {
188 border: 1px solid var(--hl);
189 padding: 0.5em;
190 font-size: 1em;
191 background: var(--bg-page);
192 color: var(--fg);
193 width: 600px;
194 height: 4em;
195 margin-bottom: 0.5em;
196 box-sizing: border-box;
197 max-width: 100%;
198}
199textarea#honknoise {
200 height: 10em;
201}
202input[type="checkbox"] {
203 position: fixed;
204 top: -9999px;
205}
206input[type="checkbox"] + span:after {
207 content: "no";
208}
209input[type="checkbox"]:checked + span:after {
210 content: "yes";
211}
212input[type="checkbox"]:focus + span:after {
213 outline: 1px solid var(--hl);
214}
215input[type=file] {
216 display: none;
217}
218
219.glow {
220 box-shadow: 0px 0px 16px var(--hl);
221}
222.honk {
223 margin: auto;
224 background: var(--bg-page);
225 /*border-top: 1px solid var(--hl);
226 border-left: 1px solid var(--hl);
227 border-right: 1px solid var(--hl);*/
228 padding-left: 1em;
229 padding-right: 1em;
230 padding-top: 0;
231 overflow: hidden;
232}
233
234.level1 {
235 margin-left: 0.7em;
236 border-left: 1px solid var(--hl);
237}
238
239
240.level2 {
241 margin-left: 1.4em;
242 border-left: 1px solid var(--hl);
243}
244
245.level3 {
246 margin-left: 2.1em;
247 border-left: 1px solid var(--hl);
248}
249
250.level4 {
251 margin-left: 2.8em;
252 border-left: 1px solid var(--hl);
253}
254
255#honksonpage article:last-child {
256 border-bottom: 1px solid var(--hl);
257}
258
259.chat {
260 border-bottom: 0.5px solid var(--fg-subtle);
261 padding-left: 1em;
262}
263.chat p {
264 margin-top: 0.2em;
265 margin-bottom: 0.2em;
266}
267.chattarget {
268 border-bottom: 1px solid var(--fg-subtle);
269}
270.chatstamp {
271 margin-left: -1em;
272}
273
274.honk #honkform {
275 padding: 1em;
276 border: 1px solid var(--fg);
277}
278.honk a {
279 color: var(--fg);
280}
281.honk header {
282 white-space: nowrap;
283 overflow: hidden;
284 text-overflow: ellipsis;
285 font-size: 0.8em;
286 line-height: 1.1;
287 margin-top: 1em;
288}
289
290.honk header .clip a {
291 color: var(--fg-subtle);
292}
293
294.clip {
295 text-transform: lowercase;
296}
297
298.honk header img {
299 float: left;
300 margin-right: 1em;
301 border-radius: 10%;
302 width: 64px;
303 height: 64px;
304}
305.honk header p {
306 margin-top: 0px;
307}
308
309.honk .noise {
310 line-height: 1.4;
311}
312
313.honk .noise code .kw { font-weight: bold; }
314.honk .noise code .bi { font-weight: bold; }
315.honk .noise code .st { color: var(--fg-subtle); }
316.honk .noise code .nm { color: #ba88ff; }
317.honk .noise code .op { color: #ba88ff; }
318.honk .noise code .tp { font-weight: bold; }
319.honk .noise code .cm { color: var(--fg-subtle); font-style: italic; }
320.honk .noise code .al { color: #aaffbb; }
321.honk .noise code .dl { color: #ffaabb; }
322
323summary::marker {
324 content: '\2192';
325}
326
327.honk details.actions summary {
328 color: var(--fg-subtle);
329}
330
331#emupicker{height:300px;overflow-y:scroll;padding:3px;background:var(--bg-dark);border:solid 5px var(--fg-subtle);text-align:center;display:none;}
332#emupicker img{margin:0;}
333.emuload{background:var(--bg-page);padding:0.5em;}
334
335.subtle .noise {
336 color: var(--fg-subtle);
337 font-size: 0.8em;
338}
339.subtle .noise a {
340 color: var(--fg-subtle);
341}
342.limited {
343 background: var(--bg-limited);
344 color: var(--fg-subtle);
345}
346.limited .glow {
347 box-shadow: 0px 0px 16px var(--fg-limited);
348}
349.limited .noise {
350 color: var(--fg-subtle);
351}
352.limited .noise a {
353 color: var(--fg-limited);
354}
355.limited details.actions summary {
356 color: var(--fg-limited);
357}
358details.noise[open] summary {
359 display: none;
360}
361h1, h2 {
362 font-family: "InterDisplay", sans-serif;
363 font-weight: 500;
364 font-size: 1.6em;
365}
366h3, h4 {
367 font-family: "InterDisplay", sans-serif;
368 font-weight: 500;
369 font-size: 1.1em;
370}
371
372#topmenu ul {
373 list-style: none;
374 padding-left: 1em;
375}
376
377header a {
378 text-decoration: none;
379 color: var(--header-fg);
380}
381
382main header a {
383 text-decoration: underline;
384}
385
386header details a {
387 color: var(--fg);
388}
389
390.honkmeta {
391 color: var(--fg-subtle);
392 float: right;
393 display: inline-flex;
394 padding: 0;
395 margin: 0;
396 list-style: none;
397}
398
399.honkmeta a {
400 color: var(--fg-subtle);
401}
402
403.honkmeta li:after {
404 content: '\00B7';
405 padding-right: 2px;
406 padding-left: 2px;
407}
408
409.honkmeta li:last-child:after {
410 content: '';
411}
412
413.honkmeta li {
414 padding-left: 2px;
415 display: inline-block;
416}
417
418nav {
419 float: right;
420 max-width: 100%;
421}
422
423nav ul {
424 padding: 0;
425 margin: 0;
426 list-style: none;
427 padding-bottom: 20px;
428}
429
430nav ul li {
431 padding-right: 10px;
432 display: inline-block;
433}
434
435img:not(.emu) {
436 background: var(--bg-page);
437}
438img, video {
439 max-width: 100%;
440 max-height: 600px;
441}
442.noise img:not(.emu) {
443 display: block;
444}
445img.emu {
446 width: 2em;
447 height: 2em;
448 vertical-align: middle;
449 margin: -2px;
450 object-fit: contain;
451}
452.nophone {
453 position: fixed;
454 opacity: 0.7;
455 cursor: pointer;
456}
457
458#emupicker{height:300px;overflow-y:scroll;padding:3px;background:var(--bg-dark);border:solid 1px var(--fg-subtle);text-align:center;}
459#emupicker img{margin:0;}
460
461a {
462 color: var(--fg);
463}
464
465a:hover {
466 background: var(--hover);
467}
468
469
470
471@media screen and (max-width: 1360px) {
472 .nophone {
473 display: none;
474 }
475}
476@media screen and (max-width: 740px) {
477 body {
478 font-size: 12px;
479 }
480
481 .info {
482 border: none;
483 margin-top: 0px;
484 }
485
486 .honk {
487 border-right: none;
488 border-left: none;
489 }
490
491 .honk header img {
492 width: 48px;
493 height: 48px;
494 border-radius: 10%;
495 }
496 details summary {
497 outline: none;
498 }
499}
500@media print {
501 #topmenu, #topspacer, #infobox, #refreshbox, .actions {
502 display: none;
503 }
504 html {
505 --bg-page: white;
506 --bg-dark: white;
507 --fg: black;
508 --fg-subtle: black;
509 --fg-limited: #a79;
510 }
511}
512
513/*
514 * CSP: style-src: self
515 */
516
517li.details {
518 list-style-type: none;
519 margin-left: -1em;
520}
521
522.left1em {
523 margin-left: 1em;
524}
525
526.hide {
527 display: none;
528}
529
530.textright {
531 text-align: right;
532}
533
534.font08em {
535 font-size: 0.8em;
536}
537
538.font18em {
539 font-size: 1.8em;
540}
541
542.wsnowrap {
543 white-space: nowrap;
544}
545
546.skinny main {
547 max-width: 700px;
548}
549
550.fontmonospace {
551 font-family: monospace;
552}