Terrible font hacks to get an outline.
[heroik.git] / heroik.css
1 /* The person who associated a work with this deed has dedicated the
2 work to the public domain by waiving all of his or her rights to
3 the work worldwide under copyright law, including all related and
4 neighboring rights, to the extent allowed by law.
5
6 You can copy, modify, distribute and perform the work, even for
7 commercial purposes, all without asking permission.
8
9 See https://creativecommons.org/publicdomain/zero/1.0/ for details.
10 */
11
12 @font-face {
13 font-family: Oranienbaum;
14 font-style: normal;
15 font-weight: 400;
16 src: url('Oranienbaum-Regular.woff') format('woff');
17 }
18
19 @font-face {
20 font-family: Cardo;
21 font-style: normal;
22 font-weight: 400;
23 src: url('Cardo-Regular.woff') format('woff');
24 }
25
26 @font-face {
27 font-family: Cardo;
28 font-style: normal;
29 font-weight: 700;
30 src: url('Cardo-Bold.woff') format('woff');
31 }
32
33 @font-face {
34 font-family: Cardo;
35 font-style: italic;
36 font-weight: 400;
37 src: url('Cardo-Italic.woff') format('woff');
38 }
39
40 * {
41 margin: 0;
42 padding: 0;
43 }
44
45 #change {
46 position: relative;
47 top: 1em;
48 }
49
50 ul {
51 margin-left: 1em;
52 margin-bottom: 1em;
53 }
54
55 ul.cards {
56 list-style-type: none;
57 display: inline-block;
58 margin: auto;
59 }
60
61 html {
62 font-family: Cardo, serif;
63 font-size: 20px;
64 background-color: black;
65 min-height: 100%;
66 height: 100%;
67 }
68
69 @media (max-width: 639px) {
70 html { font-size: 14px; }
71 }
72
73 body {
74 background-color: black;
75 min-height: 100%;
76 height: 100%;
77 box-sizing: border-box;
78 }
79
80 body.standalone {
81 padding-top: 20px;
82 }
83
84 main {
85 background-color: white;
86 max-width: 25.2em;
87 margin: 0 auto;
88 padding: 1em;
89 display: block;
90 min-height: 100%;
91 box-sizing: border-box;
92 }
93
94 body.standalone main {
95 padding-top: 0.5em;
96 }
97
98 table {
99 border-collapse: collapse;
100 margin: auto;
101 max-width: 25em;
102 }
103
104 table.tall td {
105 padding-top: 0.125em;
106 padding-bottom: 0.125em;
107 }
108
109 thead {
110 font-size: 0.8em;
111 font-variant: small-caps;
112 vertical-align: bottom;
113 text-align: left;
114 }
115
116 th {
117 font-weight: bold;
118 }
119
120 tbody, tfoot {
121 vertical-align: top;
122 text-align: left;
123 }
124
125
126 tbody tr:nth-last-child(odd) {
127 background-color: hsl(270, 30%, 85%);
128 }
129
130 #fate th:first-child, #fate td:first-child {
131 text-align: center;
132 width: 2em;
133 }
134
135 #abilities td {
136 text-align: justify;
137 -webkit-hyphens: auto;
138 -moz-hyphens: auto;
139 -ms-hyphens: auto;
140 hyphens: auto;
141 }
142
143 #abilities td:first-child {
144 white-space: nowrap;
145 }
146
147
148 th, td {
149 padding: 0 0.5rem;
150 }
151
152 h1:before {
153 content: '\25cf';
154 color: #dae9bc;
155 text-shadow: -0.08333em -0.08333em 0.25em #aec38b,
156 0.08333em -0.08333em 0.25em #aec38b,
157 0.08333em 0.08333em 0 #534f53,
158 -0.08333em 0.08333em 0 #534f53,
159 0 0.1667em 0 #414045;
160 -webkit-text-stroke: 0;
161 display: inline-block;
162 width: 1em;
163 margin-top: -0.1em;
164 vertical-align: top;
165 margin-left: -1em;
166 }
167
168 h1 {
169 padding-left: 1em;
170 margin-top: 1em;
171 margin-bottom: 0.5em;
172 font-family: Oranienbaum, Cardo, serif;
173 color: hsl(270, 25%, 75%);
174 font-size: 2em;
175 text-shadow: none;
176 border-bottom: solid hsl(270, 25%, 50%) 0.0625em;
177 line-height: 0.8em;
178 font-weight: normal;
179 text-shadow: -1px 0 black, 1px 0 black,
180 0 1px black, 0 -1px black,
181 -0.707px -0.707px black, 0.707px 0.707px black,
182 -0.707px 0.707px black, 0.707px -0.707px black;
183 }
184
185 h1:first-child {
186 margin-top: 0;
187 }
188
189 h2:before {
190 content: '\25fc';
191 color: #00a1eb;
192 font-size: 1.5em;
193 width: 0.55em;
194 display: inline-block;
195 }
196
197 h2 {
198 height: 1.15em;
199 font-size: 1.25em;
200 font-family: Oranienbaum, Cardo, serif;
201 text-align: left;
202 letter-spacing: -1px;
203 z-index: 1;
204 border-bottom: solid hsl(270, 30%, 85%) 0.25em;
205 padding-right: 1em;
206 white-space: nowrap;
207 margin-bottom: 0.5em;
208 font-weight: bold;
209 }
210
211 a:link, a:visited, a:active {
212 color: hsl(270, 25%, 50%);
213 font-weight: bold;
214 text-decoration: none;
215 }
216
217 .fate-name { font-weight: bold; }
218 .fate-effect { font-style: italic; font-size: 0.95em; }
219 .fate-action { font-size: 0.95em; }
220
221 input[type=checkbox] {
222 margin-right: 0.5em;
223 }
224
225 .button {
226 font-size: 1.1em;
227 font-weight: bold;
228 color: black !important;
229 background-color: hsl(270, 30%, 85%);
230 margin: 0.0625em 0;
231 padding: 0.375em 0.5em;
232 display: inline-block;
233 border-radius: 0 0.5em 0 0.5em;
234 transition: box-shadow 0.167s, border-color 0.167s, opacity 0.333s;
235 -webkit-transition: box-shadow 0.167s, border-color 0.167s, opacity 0.333s;
236 box-shadow: 0.125em 0.125em 0.25em 0.0625em #aaa;
237 border: solid hsl(270, 30%, 85%) 1px;
238 min-width: 6em;
239 }
240
241 .button.small {
242 min-width: 1.25em;
243 }
244
245 .button:hover, .button:focus {
246 box-shadow: 0.125em 0.125em 0.25em 0.0625em #888;
247 border-color: hsl(270, 25%, 50%);
248 }
249
250 .button:active {
251 box-shadow: 0.0625em 0.0625em 0.0625em 0.0625em #888;
252 }
253
254 main > div, main > noscript {
255 text-align: center;
256 margin-bottom: 1rem;
257 display: block;
258 }
259
260 ul.cards li {
261 padding: 0.25em 0;
262 display: inline-block;
263 width: 8em;
264 }
265
266 select {
267 -webkit-appearance: none;
268 -moz-appearance: none;
269 appearance: none;
270 font-family: Cardo, serif;
271 font-size: 1.1em;
272 margin-top: 0.5em;
273 width: 60%;
274 margin-left: 20%;
275 padding: 0 0.5em;
276 border: solid hsl(270, 30%, 85%) 1px;
277 border-radius: 0 0.5em 0 0.5em;
278 background-color: hsl(270, 30%, 85%);
279 box-shadow: 0.125em 0.125em 0.25em 0.0625em #aaa;
280 transition: box-shadow 0.167s, border-color 0.167s;
281 -webkit-transition: box-shadow 0.167s, border-color 0.167s;
282 text-align:-webkit-center !important;
283 font-weight: bold;
284 }
285
286 select:hover, select:focus {
287 box-shadow: 0.125em 0.125em 0.25em 0.0625em #888;
288 border-color: hsl(270, 25%, 50%);
289 outline: none;
290 }
291
292 select:active {
293 box-shadow: 0.0625em 0.0625em 0.0625em 0.0625em #888;
294 outline: none;
295 }
296
297 option {
298 -webkit-appearance: none;
299 -moz-appearance: none;
300 appearance: none;
301 font-family: Cardo, serif;
302 background-color: white;
303 text-align: center;
304 font-weight: normal;
305 }
306
307 p, li {
308 text-align: justify;
309 -webkit-hyphens: auto;
310 -moz-hyphens: auto;
311 -ms-hyphens: auto;
312 hyphens: auto;
313 }
314
315 p {
316 margin-bottom: 0.5em;
317 }
318
319 blockquote {
320 text-align: justify;
321 font-style: italic;
322 margin-left: 1em;
323 margin-right: 1em;
324 margin-bottom: 0.5em;
325 font-size: 0.95em;
326 }
327
328 @keyframes row-content-in {
329 0% { max-height: 0; opacity: 0; }
330 50% { max-height: 10em; }
331 100% { opacity: 1; }
332 }
333 @-webkit-keyframes row-content-in {
334 0% { max-height: 0; opacity: 0; }
335 50% { max-height: 10em; }
336 100% { opacity: 1; }
337 }
338
339 table {
340 width: 100%;
341 }
342
343 #fate tbody tr div {
344 max-height: 10em;
345 animation: row-content-in 0.6667s;
346 -webkit-animation: row-content-in 0.6667s;
347 }
348
349 #fate tbody ~ tfoot {
350 transition: opacity 0.3333s, visibility 0s 0.3333s;
351 -webkit-transition: opacity 0.3333s, visibility 0s 0.3333s;
352 opacity: 0;
353 visibility: hidden;
354 }
355
356 #fate tbody:empty ~ tfoot {
357 opacity: 1;
358 visibility: visible;
359 }
360
361 .button.big {
362 display: block;
363 width: 80%;
364 margin: 1em auto;
365 }
366
367 .card1 {
368 width: 2.5em;
369 background-color: white;
370 display: inline-block;
371 margin: 0.2em 0.375em;
372 border: solid 1px black;
373 }
374
375 .card2 {
376 width: 2.5em;
377 background-color: black;
378 display: inline-block;
379 margin: 0.2em 0.375em;
380 border: solid 1px black;
381 color: white;
382 }
383
384 .card {
385 display: block;
386
387 position: relative;
388 width: 20em;
389 height: 27.1875em;
390 font-size: 88.275%;
391 /* width: 64mm;
392 height: 87mm;
393 font-size: 9pt;*/
394 margin: auto;
395 margin: 0.5em auto;
396 z-index: 1;
397 }
398
399
400 .card:after {
401 content: '';
402 display: block;
403 position:absolute;
404 width:100%;
405 height:100%;
406 left:0;
407 top:0;
408 background-image: url(card.png);
409 background-size: cover;
410 z-index: -1;
411 }
412
413 .card .art {
414 position: absolute;
415 z-index: -1;
416 left: 9.5%;
417 right: 9.5%;
418 width: 81%;
419 height: auto;
420 top: 7.1%;
421 }
422
423 .card.adventurer .name, .card.adventurer .type {
424 background-color: #4ba12f;
425 }
426
427 .card.object .name, .card.object .type {
428 background-color: #cdab4c;
429 }
430
431 .card .name {
432 position: absolute;
433 color: white;
434 text-align: center;
435 width: 77%;
436 border: solid white 0.1em;
437 border-radius: 0.4em;
438 line-height: 1.6em;
439 height: 5.5%;
440 font-size: 0.85em;
441 font-weight: bold;
442 left: 11.5%;
443 right: 11.5%;
444 top: 3.5%;
445 box-sizing: border-box;
446 text-shadow: 0 0 0.5em black;
447 }
448
449 .card .type {
450 color: black;
451 letter-spacing: 0.05em;
452 font-weight: bold;
453 text-shadow: -0.0707em -0.0707em rgba(255, 255, 255, 0.7),
454 0.0707em -0.0707em rgba(255, 255, 255, 0.7),
455 -0.0707em 0.0707em rgba(255, 255, 255, 0.7),
456 0.0707em 0.0707em rgba(255, 255, 255, 0.7),
457 0.1em 0 rgba(255, 255, 255, 0.7),
458 -0.1em 0 rgba(255, 255, 255, 0.7),
459 0 0.1em rgba(255, 255, 255, 0.7),
460 0 -0.1em rgba(255, 255, 255, 0.7);
461 text-align: left;
462 margin: auto;
463 position: absolute;
464 height: 2.55%;
465 width: 84%;
466 left: 8%;
467 top: 52.3333%;
468 box-sizing: border-box;
469 padding-left: 0.6667em;
470 font-size: 0.575em;
471 line-height: 1.25em;
472 box-shadow: inset 0 0 0.25em black;
473 }
474
475 .card .gender {
476 position: absolute;
477 height: 9%;
478 top: 47.5%;
479 right: 8.5%;
480 }
481
482 .card .gender img {
483 float: right;
484 height: 100%;
485 }
486
487 .card .abilities {
488 text-align: left;
489 position: absolute;
490 top: 57%;
491 bottom: 8%;
492 left: 10%;
493 right: 10%;
494 font-size: 0.8em;
495 line-height: 1.05em;
496 padding-left: 1em;
497 }
498
499 .card .cost span {
500 position: relative;
501 content: ' ';
502 width: 1.5em;
503 height: 1.5em;
504 border-radius: 1.5em;
505 border: solid black 0.75em;
506 display: inline-block;
507 box-sizing: border-box;
508 margin: 0.5em 0.05em;
509 box-shadow: 0 0 0.05em 0.05em black;
510 }
511
512 .card .cost span:before {
513 position: absolute;
514 text-align: center;
515 left: -0.75em;
516 top: -0.75em;
517 color: black;
518 line-height: 1.333em;
519 opacity: 0.5;
520 width: 1.5em;
521 height: 1.5em;
522 }
523
524
525 .card .cost .r:before { content: 'r'; }
526 .card .cost .g:before { content: 'g'; }
527
528 .card .cost .r {
529 background-color: #e4573c;
530 border-color: #e4573c;
531 }
532 .card .cost .g {
533 background-color: #abbc45;
534 border-color: #abbc45;
535 }
536
537 .card .abilities .skill:before {
538 content: "Skill: ";
539 font-weight: bold;
540 margin-left: -1em;
541 }
542
543 .card .abilities .temporary:before {
544 content: "Temporary power: ";
545 font-weight: bold;
546 margin-left: -1em;
547 }
548
549 .card .abilities .ultimate:before {
550 content: "Ultimate power: ";
551 font-weight: bold;
552 margin-left: -1em;
553 }
554
555 .card .effect {
556 text-align: center;
557 position: absolute;
558 top: 59%;
559 bottom: 8%;
560 left: 15%;
561 width: 70%;
562 font-size: 0.8em;
563 line-height: 1.05em;
564 }
565
566 .card .flavor {
567 position: absolute;
568 bottom: 9%;
569 width: 80%;
570 left: 10%;
571 font-style: italic;
572 color: black;
573 font-size: 0.6em;
574 }
575
576 .card .code {
577 position: absolute;
578 color: white;
579 bottom: 3.5%;
580 right: 12%;
581 font-size: 0.65em;
582 text-shadow: -0.0433em -0.0433em black,
583 0.0433em -0.0433em black,
584 -0.0433em 0.0433em black,
585 0.0433em 0.0433em black,
586 0.06667em 0 black,
587 -0.06667em 0 black,
588 0 0.06667em black,
589 0 -0.06667em black;
590 }
591
592 #statusbar {
593 display: none;
594 position: fixed;
595 left: 0;
596 top: 0;
597 right: 0;
598 height: 20px;
599 background-color: black;
600 }
601
602 body.standalone #statusbar {
603 display: block;
604 }
605
606 h1, h2, [onclick], label {
607 -webkit-user-select: none;
608 -moz-user-select: none;
609 user-select: none;
610 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
611 cursor: default;
612 }
613
614 [onclick], select, label {
615 cursor: pointer;
616 }
617
618 td:target {
619 font-weight: bold;
620 }
621
622 @media print {
623
624 @page {
625 size: 3.5in 7in;
626 margin: 0.5em;
627 }
628 .no-print {
629 display: none !important;
630 }
631
632 body, html {
633 background-color: white;
634 font-size: 10pt;
635 }
636
637 main {
638 max-width: 3.5in;
639 }
640 }
641
642 @media screen and (-webkit-min-device-pixel-ratio:0) {
643 h1 {
644 text-shadow: none;
645 -webkit-text-stroke: 1px black;
646 latter-spacing: -1px;
647 }
648
649 .broken-on-webkit {
650 display: none !important;
651 }
652
653 }