/* @import url('/fonts/pixeboy.woff2'); */

@font-face {
	font-family: 'pixeboy';
	font-display: swap;
	src: url('/assets/pixeboy-pq0q8sRN.woff2');
}

:root {
	--dark: rgb(11, 4, 16);
	--light: rgb(255, 207, 219);
	--spacer-1: 0.25rem;
	--spacer-2: 0.5rem;
	--spacer-3: 1rem;

	--background: var(--light);
	--foreground: var(--dark);

	--pink: hsla(331, 73.04%, 54.9%, 1);
	--orange: hsla(38, 80.11%, 64.51%, 1);
	--purple: hsla(277, 73.04%, 54.9%, 1);

	--link-color: var(--pink);
	--border-radius: 0.25rem;
}

@supports (color: color(display-p3 0 0 0%)) {
:root {
	--light: rgb(255, 207, 219);
}

@media (color-gamut: p3) {
:root {
	--light: color(display-p3 0.99467 0.80663 0.85637);
}
}
}

@media (prefers-color-scheme: dark) {
	:root {
		--background: var(--dark);
		--foreground: var(--light);
		--link-color: rgb(94, 48, 116);
	}
}

@view-transition {
	navigation: auto;
}

html {
	font-family: sans-serif;
	scroll-behavior: smooth;
}

body {
	display: grid;
	margin: 0;
	padding: 0;
	background-color: var(--background);
	color: var(--foreground);
	min-block-size: 100%;
	min-height: 100dvh;
}

body  > div {
		display: grid;
		grid-template-rows: auto 1fr auto;
		grid-template-columns: repeat(4, 1fr);
		gap: var(--spacer-3);
	}

@media screen and (min-width: 768px) {

body  > div {
			grid-template-columns: repeat(12, 1fr);
	}
		}

a {
	color: var(--link-color);
	text-decoration-color: var(--foreground);
}

header {
	place-items: center;
}

header  > a:first-child {
		align-self: center;
		font-family: 'pixeboy', monospace;
		text-transform: uppercase;
		color: white;
		-webkit-text-decoration: none;
		text-decoration: none;
		font-size: clamp(2rem, 18vw, 5rem);
		text-shadow: .5vw 3px 0 rgb(94, 48, 116);
		max-inline-size: 7ch;
		line-height: .6;
		rotate: -14deg;
		animation: pulsate 1.5s ease-in-out infinite;
		transform-origin: center;
		grid-column: 1 / 5;
		grid-row: 1;
	}

@media screen and (min-width: 768px) {

header  > a:first-child {
			grid-column: 3 / 9;
	}
		}

header img {
		background: var(--background);
		grid-area: show;
		max-inline-size: 100%;
		grid-column: 1 / 5;
		grid-row: 1;
	}

@media screen and (min-width: 768px) {

header img {
			grid-column: 3 / 9;
	}
		}

@keyframes pulsate {
  0% {
    scale: 1;
  }
  50% {
    scale: 1.1;
  }
  100% {
    scale: 1;
  }
}

header,
main,
footer {
	display: grid;
	grid-column: span 4;
	grid-template-columns: subgrid;
	padding-inline: var(--spacer-3);
	padding-block: 0.5rem;
}

@media screen and (min-width: 768px) {

header,
main,
footer {
		grid-column: 2 / 12;
}
	}

main {
	text-align: center;

}

main  > img {
		color: var(--foreground);
		max-inline-size: 100%;
		height: auto;
	}

main h2 {
		font-family: 'pixeboy', monospace;
		text-transform: uppercase;
		text-shadow: .5vw 3px 0 var(--purple);
		font-size: 3rem;
	}

:is(main h3):nth-child(2) {
			border-bottom: 2px solid var(--pink);
		}

:is(main h3):nth-child(4) {
			border-bottom: 2px solid var(--orange);
		}

:is(main h3):nth-child(6) {
			border-bottom: 2px solid var(--purple);
		}

main section {
		grid-column: span 4;
	}

@media screen and (min-width: 768px) {

main section {
			grid-column: 3 / 9;
	}
		}

dl {
	display: grid;
	grid-template-columns: 2fr 1fr;
	letter-spacing: .1ch;
	margin-block-end: 5cqi;
}

dl dd {
		text-align: right;
	}

nav {
	display: flex;
	justify-content: flex-end;
	gap: var(--spacer-3);
}

nav a {
		font-family: 'pixeboy', monospace;
		text-transform: uppercase;
		font-size: 1.5rem;
	}

footer nav {
		grid-column: span 4;
	}

@media screen and (min-width: 768px) {

footer nav {
			grid-column: span 12;
	}
		}

form {
	border: none;
	display: flex;
	flex-direction: column;
	gap: var(--spacer-3);
}

form label {
		display: block;
	}

form input,form textarea {
		max-inline-size: 100%;
		font-size: 1.1rem;
	}

@media screen and (min-width: 768px) {

form {
		grid-column: 2 / 10;
}
	}

button,
input[type="submit"],
input[type="button"] {
	background-color: var(--link-color);
	color: var(--background);
	display: inline-block;
	border: 0;
	padding: var(--spacer-2) var(--spacer-3);
	cursor: pointer;
	border-radius: var(--border-radius);
	font-size: 1.1rem;
}
