/*! Algos team*/
html {
	line-height: 1.15;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%
}

body {
	margin: 0
}

header,
nav,
section {
	display: block
}

h1 {
	font-size: 2em;
	margin: .67em 0
}

figcaption,
main {
	display: block
}

a {
	background-color: transparent;
	-webkit-text-decoration-skip: objects
}

b,
strong {
	font-weight: inherit;
	font-weight: bolder
}

code {
	font-family: monospace, monospace;
	font-size: 1em
}

dfn {
	font-style: italic
}

audio {
	display: inline-block
}

audio:not([controls]) {
	display: none;
	height: 0
}

img {
	border-style: none
}

svg:not(:root) {
	overflow: hidden
}

button,
input {
	font-family: sans-serif;
	font-size: 100%;
	line-height: 1.15;
	margin: 0
}

button,
input {
	overflow: visible
}

button {
	text-transform: none
}

[type=reset],
[type=submit],
button,
html [type=button] {
	-webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
	border-style: none;
	padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
	outline: 1px dotted ButtonText
}

legend {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal
}

[type=checkbox],
[type=radio] {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
	height: auto
}

[type=search] {
	-webkit-appearance: textfield;
	outline-offset: -2px
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
	-webkit-appearance: none
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit
}

menu {
	display: block
}

summary {
	display: list-item
}

canvas {
	display: inline-block
}

[hidden],
template {
	display: none
}

html {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	font-family: sans-serif
}

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

h1,
h2,
h3,
p {
	margin: 0
}

button {
	background: transparent;
	padding: 0
}

button:focus {
	outline: 1px dotted;
	outline: 5px auto -webkit-focus-ring-color
}

ul {
	margin: 0
}

*,
:after,
:before {
	border: 0 solid #000
}

img {
	border-style: solid
}

[type=button],
[type=reset],
[type=submit],
button {
	border-radius: 0
}

img {
	height: auto
}

button,
input {
	font-family: inherit
}

input::-webkit-input-placeholder {
	color: inherit;
	opacity: .5
}

input::-ms-input-placeholder {
	color: inherit;
	opacity: .5
}

input::placeholder {
	color: inherit;
	opacity: .5
}

[role=button],
button {
	cursor: pointer
}

@font-face {
	font-family: VCR OSD Mono;
	font-style: normal;
	font-weight: 400;
	src: local("VCR OSD Mono"), url("../fonts/VCR-OSD-MONO.woff") format("woff")
}

@font-face {
	font-family: DOS;
	font-style: normal;
	font-weight: 400;
	src: url("fonts/Fixedsys500c.html");
	src: local("\263A"), url("../fonts/Fixedsys500c.woff") format("woff"), url("../fonts/Fixedsys500c.ttf") format("truetype"), url("../fonts/Fixedsys500c.svg") format("svg")
}

@font-face {
	font-family: Capcom Serif Large;
	font-weight: 400;
	font-style: normal;
	src: url("../fonts/Capcom-Serif-Large.woff2") format("woff2"), url("../fonts/Capcom-Serif-Large.woff") format("woff")
}

body {
	font-family: VCR OSD Mono, monospace;
	background-color: #131111;
	color: #fff;
	min-height: 100vh;
	width: 100%;
	text-transform: uppercase;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-shadow: 4px 4px 0 rgba(0, 0, 0, .75);
	-ms-interpolation-mode: nearest-neighbor;
	image-rendering: -webkit-optimize-contrast;
	image-rendering: -moz-crisp-edges;
	image-rendering: -o-pixelated;
	image-rendering: pixelated
}

body,
h2 {
	font-size: 32px
}

h2 {
	font-family: Capcom Serif Large, monospace;
	color: #ff00db;
	margin-bottom: 64px;
	text-shadow: 5px 5px #551a8b
}

h3 {
	font-size: 32px
}

@media (min-width:768px) {
	h2 {
		font-size: 80px
	}

	h3 {
		font-size: 48px
	}
}

a {
	text-decoration: none;
	cursor: pointer;
	color: #41ff00
}

img {
	max-width: 100%
}

input[type=email] {
	color: #41ff00;
	text-align: center;
	text-transform: uppercase;
	font-size: 16px;
	width: 100%;
	overflow: visible;
	border-width: 2px;
	border-color: transparent;
	background: rgba(0, 0, 0, .85);
	padding: 16px 48px
}

input[type=email]::-webkit-input-placeholder {
	color: #41ff00;
	opacity: 1
}

input[type=email]::-ms-input-placeholder {
	color: #41ff00;
	opacity: 1
}

input[type=email]::placeholder {
	color: #41ff00;
	opacity: 1
}

input[type=email]:focus {
	border-width: 2px;
	border-color: #41ff00;
	outline: 0
}

input[type=email]:focus::-webkit-input-placeholder {
	opacity: .5
}

input[type=email]:focus::-ms-input-placeholder {
	opacity: .5
}

input[type=email]:focus::placeholder {
	opacity: .5
}

button[type=submit] {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	position: absolute;
	opacity: .75;
	top: 0;
	bottom: 0;
	right: 0;
	padding: 16px
}

button[type=submit]:hover {
	opacity: 1
}

.site-nav {
	position: absolute;
	z-index: 30;
	top: 0;
	text-align: center;
	width: 100%;
	padding: 16px;
	margin-top: 16px;
	font-size: 13px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	color: #fff;
	text-transform: uppercase
}

.site-nav a {
	padding-left: 8px;
	padding-right: 8px;
	color: #41ff00;
	text-decoration: none
}

.site-nav a:hover {
	color: #ff00db
}

@media (min-width:768px) {
	.site-nav {
		font-size: 16px;
		padding: 40px;
		font-size: 32px
	}
}

@media (min-width:768px) {
	.site-nav a {
		padding-left: 40px;
		padding-right: 40px
	}
}

.text-shadow-sm {
	text-shadow: 2px 2px 0 rgba(0, 0, 0, .75)
}

.button {
	background-color: #551a8b;
	color: #fff;
	padding: 16px 32px;
	text-decoration: none;
	display: inline-block;
	-webkit-box-shadow: 10px 10px 0 rgba(0, 0, 0, .75);
	box-shadow: 10px 10px 0 rgba(0, 0, 0, .75);
	position: relative
}

.button:hover {
	background-color: #ff00db
}

.button:active {
	-webkit-box-shadow: 8px 8px 0 rgba(0, 0, 0, .75);
	box-shadow: 8px 8px 0 rgba(0, 0, 0, .75);
	bottom: -2px
}

#above-ground {
	background-size: cover;
	width: 100%;
	height: 100vh;
	min-height: 700px;
	background-image: url("../img/sprites/laravel-hq.gif");
	background-repeat: no-repeat;
	background-position: bottom;
	-ms-interpolation-mode: nearest-neighbor;
	image-rendering: -webkit-optimize-contrast;
	image-rendering: -moz-crisp-edges;
	image-rendering: -o-pixelated;
	image-rendering: pixelated
}

#metro {
	height: 700px;
	background-image: url("../img/sprites/metro-animated.gif");
	background-position: 0;
	background-repeat: repeat-x
}

@media (min-width:768px) {
	#metro {
		background-position: 50%
	}
}

#walkway {
	background-color: #0b0c1a;
	position: relative;
	background-image: url("../img/sprites/castle.png");
	background-size: 800px;
	background-position: top;
	height: 380px
}

#schedule {
	background: url("../img/sprites/cavern.png") no-repeat top;
	background-size: cover;
	position: relative;
	z-index: 10;
	padding-bottom: 300px
}

#underground-city {
	background: #11081d url("../img/sprites/underground-city.gif") repeat-y top;
	background-size: cover;
	-webkit-box-shadow: inset 0 240px 60px #000;
	box-shadow: inset 0 240px 60px #000;
	margin-top: -180px
}

#speakers {
	position: relative;
	/*padding-bottom: 120px;*/
	background-color: #0b0c1a;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#0b0c1a), to(#392868));
	background-image: linear-gradient(180deg, #0b0c1a, #392868)
}

.schedule-list {
	list-style: none outside;
	margin: 0;
	padding: 0;
	text-align: center
}

.schedule-list li {
	display: block;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding-top: 8px;
	padding-bottom: 8px;
	margin-bottom: 8px
}

.schedule-list .schedule-time {
	font-family: DOS, monospace;
	width: 100%
}

.schedule-list .event-name {
	width: 100%;
	font-size: 18px
}

@media (min-width:768px) {
	.schedule-list {
		text-align: left
	}

	.schedule-list .schedule-time {
		text-align: right;
		margin-right: 40px;
		width: 100px
	}

	.schedule-list .event-name {
		width: auto
	}
}

.toolbar {
	background-color: #bbb;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	margin-bottom: 16px;
	color: #000;
	text-shadow: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-family: DOS, monospace
}

.toolbar a,
.toolbar div {
	margin-right: 8px;
	padding: 8px;
	color: #131111
}

.toolbar a:first-letter,
.toolbar div:first-letter {
	color: #a90201
}

.toolbar a:hover,
.toolbar div:hover {
	background-color: #0aa
}

.error {
	color: #fff;
	font-size: 16px;
	padding: 8px 4px;
	-webkit-box-shadow: 10px 10px 0 rgba(0, 0, 0, .75);
	box-shadow: 10px 10px 0 rgba(0, 0, 0, .75);
	font-family: DOS, monospace;
	text-shadow: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 100px;
	width: 280px
}

.error,
.error .error-heading {
	background-color: #a90201;
	position: absolute;
	text-align: center
}

.error .error-heading {
	color: #fcfc54;
	border-right-width: 2px;
	border-left-width: 2px;
	border-color: #fff;
	top: 0;
	padding-left: 4px;
	padding-right: 4px;
	width: 70px;
	margin-left: -35px;
	left: 50%
}

.error .error-msg {
	width: 100%;
	height: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border: 4px double #fff
}

.error p,
.sponsor {
	width: 100%
}

.sponsor {
	padding: 16px 32px;
	border-width: 1px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	border-color: #000;
	color: #555;
	font-size: 21px;
	font-family: DOS, monospace;
	text-decoration: none
}

.sponsor:hover {
	background-color: #000;
	color: #41ff00
}

#sprite-lambo {
	position: absolute;
	bottom: -30px;
	left: 80px;
	width: 200px
}

@media (min-width:768px) {
	#sprite-lambo {
		width: 300px
	}
}

#sprite-brute {
	position: absolute;
	overflow: hidden;
	width: 100%;
	bottom: 0;
	margin-bottom: -20px;
	height: 6rem
}

#sprite-brute img {
	position: absolute;
	top: 0;
	-webkit-animation: left-to-right 24s linear infinite;
	animation: left-to-right 24s linear infinite
}

#sprite-pipes {
	position: relative;
	height: 140px;
	background: #0b0c1a url("../img/sprites/pipes.png") repeat-x 0 0;
	background-size: 800px
}

#sprite-roger {
	position: absolute;
	bottom: 0;
	margin-bottom: -8px;
	right: 0;
	margin-right: 24px
}

.cursor-zoom {
	cursor: -webkit-zoom-in;
	cursor: zoom-in
}

.text-shadow-none {
	text-shadow: none
}

.text-outline {
	text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000
}

.blur {
	-webkit-filter: blur(.5px);
	filter: blur(.5px)
}

.mix-multiply {
	mix-blend-mode: multiply
}

.pulse {
	-webkit-animation: pulse infinite 4s ease-in-out;
	animation: pulse infinite 4s ease-in-out
}

@-webkit-keyframes pulse {
	0% {
		-webkit-filter: contrast(1);
		filter: contrast(1)
	}

	60% {
		-webkit-filter: contrast(3);
		filter: contrast(3)
	}

	to {
		-webkit-filter: contrast(1);
		filter: contrast(1)
	}
}

@keyframes pulse {
	0% {
		-webkit-filter: contrast(1);
		filter: contrast(1)
	}

	60% {
		-webkit-filter: contrast(3);
		filter: contrast(3)
	}

	to {
		-webkit-filter: contrast(1);
		filter: contrast(1)
	}
}

@-webkit-keyframes left-to-right {
	0% {
		left: -20%
	}

	to {
		left: 100%
	}
}

@keyframes left-to-right {
	0% {
		left: -20%
	}

	to {
		left: 100%
	}
}

.text-rainbow {
	color: #0aa
}

@media (min-width:768px) {
	.text-rainbow {
		text-shadow: none;
		background: -webkit-gradient(linear, left top, right top, from(#ff00db), color-stop(#551a8b), color-stop(#0aa), to(#41ff00));
		background: linear-gradient(90deg, #ff00db, #551a8b, #0aa, #41ff00);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent
	}
}

.flip {
	-webkit-transform: scaleX(-1);
	transform: scaleX(-1)
}

[v-cloak] {
	display: none
}

.v--modal {
	background-color: #fff;
	border-radius: none
}

.v--modal-overlay {
	background: transparent !important
}

.v--modal-overlay.bsod {
	background-color: #0200af !important;
	color: #fff !important;
	font-family: DOS, monospace !important;
	text-transform: none !important
}

.v--modal-overlay.bsod .v--modal {
	padding: 120px;
	background: none !important
}

.v--modal-overlay.bsod .v--modal p {
	margin-bottom: 40px
}

* {
	-webkit-transition: none !important;
	transition: none !important
}

.bg-black {
	background-color: #000
}

.bg-blue {
	background-color: #0200af
}

.bg-teal {
	background-color: #0aa
}

.bg-grey-dark {
	background-color: #131111
}

.bg-pink {
	background-color: #ff00db
}

.hover\:bg-purple:hover {
	background-color: #551a8b
}

.bg-cover {
	background-size: cover
}

.bg-contain {
	background-size: contain
}

.border-black {
	border-color: #000
}

.border-white {
	border-color: #fff
}

.border-patina {
	border-color: #69a494
}

.border-gold {
	border-color: #c6af30
}

.border-silver {
	border-color: #708495
}

.border-bronze {
	border-color: #50463b
}

.hover\:border-green:hover {
	border-color: #41ff00
}

.border-2 {
	border-width: 2px
}

.border-3 {
	border-width: 3px
}

.border-4 {
	border-width: 4px
}

.border {
	border-width: 1px
}

.block {
	display: block
}

.inline-block {
	display: inline-block
}

.hidden {
	display: none
}

.group:hover .group-hover\:inline-block {
	display: inline-block
}

.group:hover .group-hover\:hidden {
	display: none
}

.flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex
}

.flex-col {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column
}

.flex-wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}

.items-center {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

.justify-center {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center
}

.float-right {
	float: right
}

.font-dos {
	font-family: DOS, monospace
}

.h-24 {
	height: 6rem
}

.h-full {
	height: 100%
}

.h-screen {
	height: 100vh
}

.h-screen-1\/2 {
	height: 50vh
}

.m-2 {
	margin: 16px
}

.my-1 {
	margin-top: 8px;
	margin-bottom: 8px
}

.my-3 {
	margin-top: 24px;
	margin-bottom: 24px
}

.my-6 {
	margin-top: 64px;
	margin-bottom: 64px
}

.mx-auto {
	margin-left: auto;
	margin-right: auto
}

.mt-1 {
	margin-top: 8px
}

.mr-1 {
	margin-right: 8px
}

.mb-1 {
	margin-bottom: 8px
}

.mr-2 {
	margin-right: 16px
}

.mb-2 {
	margin-bottom: 16px
}

.mb-3 {
	margin-bottom: 24px
}

.ml-3 {
	margin-left: 24px
}

.mt-4 {
	margin-top: 32px
}

.mb-4 {
	margin-bottom: 32px
}

.mt-5 {
	margin-top: 40px
}

.mb-5 {
	margin-bottom: 40px
}

.mt-6 {
	margin-top: 64px
}

.mb-6 {
	margin-bottom: 64px
}

.mb-7 {
	margin-bottom: 80px
}

.mb-8 {
	margin-bottom: 120px
}

.max-w-sm {
	max-width: 30rem
}

.max-w-lg {
	max-width: 50rem
}

.max-w-xl {
	max-width: 60rem
}

.max-w-2xl {
	max-width: 70rem
}

.-mx-3 {
	margin-left: -24px;
	margin-right: -24px
}

.opacity-0 {
	opacity: 0
}

.opacity-50 {
	opacity: .5
}

.group:hover .group-hover\:opacity-100 {
	opacity: 1
}

.p-1 {
	padding: 8px
}

.p-2 {
	padding: 16px
}

.p-4 {
	padding: 32px
}

.p-5 {
	padding: 40px
}

.px-1 {
	padding-left: 8px;
	padding-right: 8px
}

.px-2 {
	padding-left: 16px;
	padding-right: 16px
}

.px-3 {
	padding-left: 24px;
	padding-right: 24px
}

.px-4 {
	padding-left: 32px;
	padding-right: 32px
}

.py-6 {
	padding-top: 64px;
	padding-bottom: 64px
}

.py-8 {
	padding-top: 120px;
	padding-bottom: 120px
}

.pb-3 {
	padding-bottom: 24px
}

.pb-4 {
	padding-bottom: 32px
}

.pt-6 {
	padding-top: 64px
}

.pt-7 {
	padding-top: 80px
}

.pt-8 {
	padding-top: 120px
}

.pb-8 {
	padding-bottom: 120px
}

.absolute {
	position: absolute
}

.relative {
	position: relative
}

.sticky {
	position: -webkit-sticky;
	position: sticky
}

.pin-t {
	top: 0
}

.pin-r {
	right: 0
}

.pin-b {
	bottom: 0
}

.pin-l {
	left: 0
}

.shadow {
	-webkit-box-shadow: 0 16px 20px rgba(0, 0, 0, .5);
	box-shadow: 0 16px 20px rgba(0, 0, 0, .5)
}

.shadow-flat {
	-webkit-box-shadow: 10px 10px 0 rgba(0, 0, 0, .75);
	box-shadow: 10px 10px 0 rgba(0, 0, 0, .75)
}

.text-center {
	text-align: center
}

.text-white {
	color: #fff
}

.text-green {
	color: #41ff00
}

.text-pink {
	color: #ff00db
}

.text-patina {
	color: #69a494
}

.text-gold {
	color: #c6af30
}

.text-silver {
	color: #708495
}

.text-bronze {
	color: #50463b
}

.hover\:text-green:hover {
	color: #41ff00
}

.hover\:text-pink:hover {
	color: #ff00db
}

.hover\:text-patina:hover {
	color: #69a494
}

.text-xs {
	font-size: 16px
}

.text-sm {
	font-size: 21px
}

.uppercase {
	text-transform: uppercase
}

.no-underline {
	text-decoration: none
}

.hover\:underline:hover {
	text-decoration: underline
}

.tracking-wide {
	letter-spacing: .15em
}

.w-full {
	width: 100%
}

.z-10 {
	z-index: 10
}

.z-20 {
	z-index: 20
}

@media (min-width:768px) {
	.md\:block {
		display: block
	}

	.md\:flex {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex
	}

	.md\:m-0 {
		margin: 0
	}

	.md\:m-1 {
		margin: 8px
	}

	.md\:-mx-2 {
		margin-left: -16px;
		margin-right: -16px
	}

	.md\:absolute {
		position: absolute
	}

	.md\:text-sm {
		font-size: 21px
	}

	.md\:text-base {
		font-size: 32px
	}

	.md\:w-1\/2 {
		width: 50%
	}

	.md\:w-1\/3 {
		width: 33.33333%
	}

	.md\:w-1\/4 {
		width: 25%
	}
}