html {
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	user-select: none;
}

*, *:before, *:after {
	box-sizing: inherit;
}

html, body {
	height: 100%;
}

body {
	font: normal 20px/1.4 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	margin: 0 1em;
	padding: 1em 0;
	color: #FFF;
	background: #000;
	display: flex;
	text-shadow: 1px 1px 0 #000;
}

#video-background {
	position: fixed;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
	z-index: -100;
	transform: translateX(-50%) translateY(-50%);
	background-size: cover;
}

main {
	margin: auto;
}

h1 {
	font-weight: 400;
	font-size: 2.5em;
	margin: 0;
}

h3 {
	font-weight: 400;
	font-size: 1.0em;
	margin: 0;
	margin-top: 1em;
}

ul {
	list-style-type: none;
	padding: 0;
	margin-top: .5em;
	line-height: 1.6em;
}

a {
	color: #eee;
	position: relative;
}

a::before {
	background: transparent;
	display: block;
	content: " ";
	position: absolute;
	left: -10px;
	right: -10px;
	top: -3px;
	bottom: -5px;
	z-index: -1;
}

.service-wrap {
	display: inline-block;
	width: 5em;
}

.muted {
	color: #999;
}

a,
.service,
.muted {
	text-decoration: none;
}

a:hover,
a:focus {
	outline: none;
	text-shadow: 1px 1px 0 #FFF;
	color: #000;
}

a:hover::before,
a:focus::before {
	background: #fff;
}

a:hover .muted,
a:focus .muted {
	color: inherit;
}

svg {
	width: .9em;
	height: .9em;
	vertical-align: -.1em;
	margin-right: .5em;
	fill: #1793D1;
}


a:hover svg,
a:focus svg {
	fill: #0f618a;
}

@media (max-width: 30em) {
	h1 {
		font-size: 2.5em;
	}
}

@media (max-width: 25em) {
	h1 {
		font-size: 1.8em;
	}
}

canvas {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
}
