@font-face {
	font-family: "PressStart2P";
	src: url("/assets/PressStart2P.woff2") format("woff2");
}

:root {
	--background-color: rgb(30, 33, 46);
	--dark-color: rgb(12, 7, 28);
	--font-color: rgb(155, 159, 168);
	--accent-color: rgb(255, 77, 77);
	--accent-shadow-color: rgba(255, 77, 77, 0.5);
	--color-p1: rgb(88, 219, 252);
	--color-p2: rgb(252, 233, 88);
	--font-base: monospace;
	--font-accent: "PressStart2P";
}

* {
	box-sizing: border-box;
}

body {
	font-family: var(--font-base);
	background-color: var(--background-color);
	color: var(--font-color);
}

:is(h1, h2, h3, h4, h5, h6) {
	color: var(--accent-color);
	text-align: center;
	font-family: var(--font-accent);
	text-shadow: 0 0 0.8rem var(--accent-shadow-color);
}

:is(h1) {
	text-transform: uppercase;
}

:is(a) {
	color: var(--accent-color);
}

:is(button) {
	background-color: var(--accent-color);
	border: none;
	border-radius: 2px;
	padding: 0.5rem 1ch;
	margin: 0.5rem;
}

footer {
	max-width: calc(80vh * 16 / 9);
	margin: auto;
	text-align: center;
}

nav ul {
	list-style: none;
	padding: 0;
	line-height: 1.5rem;
}

[hidden] {
	display: none !important;
}

#canvas {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-height: 80vh;
	max-width: calc(80vh * 16 / 9);
	aspect-ratio: 16/9;
	margin: auto;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
	margin-bottom: 10rem;
	border-radius: 2px;
}

#canvas:focus {
	outline: 1px solid rgba(255, 255, 255, 0.3);
}

.controls {
	margin-bottom: 10rem;
	text-align: center;
}

.controls__group {
	display: inline-block;
	vertical-align: top;
}

.controls__group:not(:last-of-type) {
	margin-right: 5rem;
}

.controls__cursor,
.controls__attack,
.controls__block {
	list-style: none;
	display: inline-grid;
	gap: 0.1rem;
	padding: 0;
	font-size: 1.5rem;
	margin-right: 1rem;
	vertical-align: middle;
}

.controls__attack,
.controls__block {
	grid-template-columns: auto auto;
}

.controls__cursor {
	grid-template-columns: auto auto auto;
	grid-template-rows: auto auto;
}

.controls__cursor li:first-of-type {
	grid-column-start: 1;
	grid-column-end: 4;
	display: flex;
	justify-content: center;
}

.controls__group p {
	font-size: 1.5rem;
	margin: 3rem 0 0 0;
}

.controls__group svg {
	width: 7rem;
	aspect-ratio: 1.1/1;
	vertical-align: middle;
	color: var(--dark-color);
}

.controls__group.move svg {
	--gamepad-move: var(--accent-color);
}

.controls__group.attack svg {
	--gamepad-attack: var(--accent-color);
}

.controls__group.block svg {
	--gamepad-block: var(--accent-color);
}

:is(kbd) {
	background: var(--dark-color);
	padding: 0.5rem;
	display: inline-grid;
	height: 2.8rem;
	width: 2.8rem;
	place-items: center;
	border-radius: 2px;
}

.color-p1 {
	color: var(--color-p1);
}

.color-p2 {
	color: var(--color-p2);
}

input[type="range"] {
	-webkit-appearance: none;
	margin: 1rem 0;
	width: 100%;
	background: transparent;
}

input[type="range"]::-webkit-slider-runnable-track {
	height: 1rem;
	background: var(--dark-color);
}

input[type="range"]::-moz-range-track {
	height: 1rem;
	background: var(--dark-color);
}

input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	border: none;
	height: 1rem;
	width: 1rem;
	border-radius: 0;
	background: var(--accent-color);
	border: 0;
}

input[type="range"]::-moz-range-thumb {
	-webkit-appearance: none;
	border: none;
	height: 1rem;
	width: 1rem;
	border-radius: 0;
	background: var(--accent-color);
	border: 0;
}

.credits {
	text-align: center;
	list-style: none;
	margin-bottom: 8rem;
	gap: 1ch;
}
