* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
* + * {
	margin-top: 1.5em;
}

img {
	max-width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}
a img {
	display: block;
}
figure {
	line-height: 0;
}

html {
	font-size: 1em;
	line-height: 1.5;
	min-height: 100vh;
}

body {
	background: #222;
	color: #ddd;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
	font-size: calc( 1rem + .125vw );
	min-height: 100vh;
	margin-top: 0;
	display: flex;
	flex-direction: column;
}

::selection {
	background: #05549f;
	color: #fff;
	text-shadow: none;
}

.text-smaller {
	font-size: 1rem;
}

input, textarea, select, button {
	font-size: 1em;
}
fieldset {
	border: 0;
}
button {
	border: 0;
	border-radius: 0;
	cursor: pointer;
	padding: .375em .75em;
}

a,
.intro .toggler {
	color: #47a6ff; /* double lightness from WD logo color */
	text-decoration: none;
}

input.toggler {
	position: absolute;
	opacity: 0;
	z-index: -1;
}
label.toggler {
	cursor: pointer;
}
.toggle-target {
	display: none;
}
input.toggler:checked ~ .toggle-target {
	display: block;
}

.icon svg {
	width: 1.5em;
	height: 1.5em;
}

main,
section,
.content-width {
	width: 100%;
	max-width: 72em;
	margin: 0 auto;
	padding: 0 .75em;
}

main {
	flex: 1 0 auto;
}
header,
footer {
	flex-shrink: 0;
}

header {
	margin: 0;
	padding: 1.5em 0;
}

h1 {
	position: relative;
	white-space: nowrap;
	text-indent: 100%;
	overflow: hidden;
	background: url('i/shuckstop.svg') 0 0 no-repeat;
	height: 2.25em;
}
h1::before {
	content: "";
	display: block;
	padding-bottom: 23.077%;
}

table {
	width: 100%;
	border-collapse: collapse;
}

th svg {
	width: 3em;
	height: 3em;
}

tbody tr:hover {
	outline: 1px solid #666;
}

tr:nth-of-type(2n) td {
	background: #292929;
}

td {
	padding: .375em;
	text-align: center;
}

td a {
	color: inherit;
}

.hidden {
	display: none;
}

.n-a {
}

.ago {
	margin-top: 0;
	opacity: .5;
}

.muted {
	opacity: .5;
}

.check {
	color: #999;
}

.lowest a:after{
	content: " 🥇";
}

.lowest-ever a:after{
	content: " 🔥";
}

.oos {
	text-decoration: line-through;
}

/*
	https://colorbrewer2.org/#type=diverging&scheme=RdBu&n=5
	https://coolors.co/d0152d-d52a39-df5351-ea7c6a-f4a582-efb499-e9c2b0-e4d0c7-e1d7d3-dedede
*/

.bad {
	color: rgba(202, 0, 32, .75);
}
.fair {
	color: rgba(146, 197, 222, .75);
}
.go {
	color: rgba(5, 113, 176, .75);
}
.go a:after {
	content: " 💸";
}

.bad.grade-0 { color: rgba(222, 222, 222, .75); }
.bad.grade-1 { color: rgba(228, 208, 199, .75); }
.bad.grade-2 { color: rgba(233, 194, 176, .75); }
.bad.grade-3 { color: rgba(239, 180, 153, .75); }
.bad.grade-4 { color: rgba(244, 165, 130, .75); }
.bad.grade-5 { color: rgba(234, 124, 106, .75); }
.bad.grade-6 { color: rgba(223, 83, 81, .75); }
.bad.grade-7 { color: rgba(213, 42, 57, .75); }
.bad.grade-8 { color: rgba(208, 21, 45, .75); }
.bad.grade-9 { color: rgba(202, 0, 32, .75); }

footer {
	background: #111;
	padding: 1.5em 0;
}

.sidebar {
	background: #222;
	border-left: 2px solid #666;
	position: fixed;
	top: 0; bottom: 0;
	right: 0;
	margin: 0;
	padding: 1.5em;
	transform: translateX(100%);
	transition: transform .3s ease;
	z-index: 1;
	width: 90%;
	max-width: 25em;
	overflow-y: auto;
}
.sidebar-close {
	position: absolute;
	top: 1.5em;
	right: 1.5em;
}
.sidebar-close + * {
	margin-top: 0;
}

#help-toggle,
#controls-toggle,
.help-open,
.controls-open {
	position: fixed;
	top: 1.5em;
	right: 1.5em;
	margin: 0;
}

#help-toggle,
.help-open {
	right: 4.5em;
}

#help-toggle:checked ~ #help,
#controls-toggle:checked ~ #controls {
	transform: translateX(0);
	box-shadow: 0 0 .75em rgba(0,0,0,.5),
				0 0 1.5em rgba(0,0,0,.4),
				0 0 2.25em rgba(0,0,0,.3),
				0 0 3em rgba(0,0,0,.2);
}

.sidebar ul {
	list-style-type: none;
	margin-left: 1.5em;
}
.sidebar li + li {
	margin-top: .375em;
}

#help p,
#help ul {
	font-size: 1rem;
}

#help .xl {
	font-size: 1.5rem;
}

.symbols li {
	display: flex;
	align-items: center;
}
.symbols .xl {
	margin-right: .75em;
}

footer section {
	margin-top: 0;
}

.announce {
	background: #00a46a;
	padding: .75em;
}

.announce .content-width {
	padding-right: 6.75em;
}

.announce * + * {
	margin-top: .375em;
}

.announce ul {
	margin-left: 1em;
}

.announce a {
	color: #fff;
	font-weight: bold;
	text-decoration: underline;
}

.announce .muted {
	opacity: .8;
}