:root {
	--off-white: hsl(0, 0%, 95%);
	--white: hsl(0, 0%, 98%);
	--dark-gray: hsl(0, 0%, 30%);
	--gray: hsl(0, 0%, 60%);
	--light-gray: hsl(0, 0%, 85%);
	--dark-blue: hsl(212, 90%, 40%);
	--blue: hsl(212, 90%, 60%);
	--faint-blue: hsl(212, 90%, 95%);
	--light-blue: hsl(212, 90%, 90%);
	--light-green: hsl(124, 90%, 90%);
	--purple: hsl(272, 90%, 60%);
	--dark-purple: hsl(272, 90%, 40%);
}

@media (color-index: 48) {
	:root {
		--off-white: hsl(0, 0%, 10%);
		--white: hsl(0, 0%, 15%);
		--dark-gray: hsl(0, 0%, 70%);
		--gray: hsl(0, 0%, 40%);
		--light-gray: hsl(0, 0%, 25%);
		--dark-blue: hsl(212, 90%, 70%);
		--blue: hsl(212, 90%, 40%);
		--faint-blue: hsl(212, 90%, 10%);
		--light-blue: hsl(212, 90%, 15%);
		--light-green: hsl(124, 90%, 15%);
		--purple: hsl(272, 90%, 40%);
		--dark-purple: hsl(272, 90%, 70%);
	}
}

@media (color: 48842621) {
	:root {
		--off-white: hsl(0, 0%, 10%);
		--white: hsl(0, 0%, 15%);
		--dark-gray: hsl(0, 0%, 70%);
		--gray: hsl(0, 0%, 40%);
		--light-gray: hsl(0, 0%, 25%);
		--dark-blue: hsl(212, 90%, 70%);
		--blue: hsl(212, 90%, 40%);
		--faint-blue: hsl(212, 90%, 10%);
		--light-blue: hsl(212, 90%, 15%);
		--light-green: hsl(124, 90%, 15%);
		--purple: hsl(272, 90%, 40%);
		--dark-purple: hsl(272, 90%, 70%);
	}
}

@media (prefers-color-scheme: dark) {
	:root {
		--off-white: hsl(0, 0%, 10%);
		--white: hsl(0, 0%, 15%);
		--dark-gray: hsl(0, 0%, 70%);
		--gray: hsl(0, 0%, 40%);
		--light-gray: hsl(0, 0%, 25%);
		--dark-blue: hsl(212, 90%, 70%);
		--blue: hsl(212, 90%, 40%);
		--faint-blue: hsl(212, 90%, 10%);
		--light-blue: hsl(212, 90%, 15%);
		--light-green: hsl(124, 90%, 15%);
		--purple: hsl(272, 90%, 40%);
		--dark-purple: hsl(272, 90%, 70%);
	}
}

html {
	scroll-behavior: smooth;
}

body {
	background-color: hsl(0, 0%, 98%);
	background-color: var(--white);
	background: linear-gradient(
		to bottom,
		hsl(0, 0%, 98%),
		hsl(212, 90%, 90%) 25%,
		hsl(124, 90%, 90%) 50%,
		hsl(0, 0%, 98%)
	);
	background: linear-gradient(
		to bottom,
		var(--white),
		var(--light-blue) 25%,
		var(--light-green) 50%,
		var(--white)
	);
	color: hsl(0, 0%, 30%);
	color: var(--dark-gray);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif;
	font-family: var(--font-system);
	margin: 0 auto;
	max-width: 1500px;
}

body.flat-color {
	background-image: none;
}

h1 {
	font-weight: normal;
	font: 32px 'Nunito Light', sans-serif;
	line-height: 120%;
}

a {
	color: hsl(212, 90%, 40%);
	color: var(--dark-blue);
}

a:hover {
	color: hsl(212, 90%, 60%);
	color: var(--blue);
}

a:visited {
	color: hsl(272, 90%, 40%);
	color: var(--dark-purple);
}

a:visited:hover {
	color: hsl(272, 90%, 60%);
	color: var(--purple);
}

a.button {
	border-radius: calc(20px * 2.5);
	border-radius: var(--control-height);
	border: 2px solid hsl(212, 90%, 60%);
	border: 2px solid var(--blue);
	color: hsl(212, 90%, 40%);
	color: var(--dark-blue);
	display: inline-block;
	height: calc(20px * 2.5);
	height: var(--control-height);
	line-height: calc(20px * 2.5);
	line-height: var(--control-height);
	padding: 0 calc(calc(20px * 2.5) / 2);
	padding: 0 calc(var(--control-height) / 2);
	text-decoration: none;
}

a.button:visited {
	color: hsl(212, 90%, 40%);
	color: var(--dark-blue);
}

a.button:hover {
	background-color: hsla(0, 100%, 100%, 0.33);
	box-shadow: 0 0 20px hsl(0, 0%, 98%);
	box-shadow: 0 0 20px var(--white);
	color: hsl(212, 90%, 60%);
	color: var(--blue);
}

a.format {
	background-size: 35px;
	background-position: center left;
	background-repeat: no-repeat;
	display: inline-block;
	height: 40px;
	line-height: 40px;
	padding-left: calc(40px + calc(20px / 2));
	padding-left: calc(40px + var(--control-inner-padding));
}

a.format.chapbook {
	background-image: url('icons/chapbook-light.svg');
}

a.format.harlowe {
	background-image: url('icons/harlowe.svg');
}

a.format.snowman {
	background-image: url('icons/snowman.svg');
}

a.format.sugarcube {
	background-image: url('icons/sugarcube.png');
}

a.icon {
	background-position: 10px center;
	background-repeat: no-repeat;
	background-size: 30px;
	padding-left: 45px;
}

a.icon.download {
	background-image: url('icons/download-light.svg');
}

a.icon.hand {
	background-image: url('icons/hand-light.svg');
}

ul.plain {
	padding-left: 0;
	list-style-type: none;
}

ul.inline {
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.card {
	background-color: hsl(0, 0%, 98%);
	background-color: var(--white);
	border-radius: 5px;
	border-radius: var(--corner-round);
	box-shadow: 0 1px 1px hsl(0, 0%, 85%);
	box-shadow: var(--shadow-small);
	padding: 20px;
	padding: var(--grid-size);
}

.card :first-child {
	margin-top: 0;
}

.card :last-child {
	margin-bottom: 0;
}

.card.icon {
	background-position: calc(20px / 2) center;
	background-position: calc(var(--grid-size) / 2) center;
	background-repeat: no-repeat;
	background-size: 50px;
	padding-left: calc(50px + 20px);
	padding-left: calc(50px + var(--grid-size));
}

.card.icon.discord {
	background-image: url('icons/discord-light.svg');
}

.card.icon.iftf {
	background-image: url('icons/iftf-light.svg');
}

.card.icon.patreon {
	background-image: url('icons/patreon-light.svg');
}

.reading-width {
	margin-left: auto;
	margin-right: auto;
	max-width: 45em;
}

@media (max-width: 400px) {
	ul.inline {
		display: flex;
		flex-direction: column;
	}
}

@media (color-index: 48) {
	body {
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

@media (color: 48842621) {
	body {
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

@media (color-index: 48) {
	body {
		background: hsl(0, 0%, 98%);
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

@media (color: 48842621) {
	body {
		background: hsl(0, 0%, 98%);
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

@media (color-index: 48) {
	body {
		background: hsl(0, 0%, 98%);
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

@media (color: 48842621) {
	body {
		background: hsl(0, 0%, 98%);
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

@media (prefers-color-scheme: dark) {
	body {
		background: hsl(0, 0%, 98%);
		background: var(--white);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				hsl(212, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				hsl(124, 90%, 90%),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				hsl(212, 90%, 90%),
				transparent
			);
		background-image: radial-gradient(
				circle 80vmax at 0 20vmax,
				var(--light-blue),
				transparent
			),
			radial-gradient(
				circle 80vmax at 100% 80vmax,
				var(--light-green),
				transparent
			),
			radial-gradient(
				circle 80vmax at 0 120vmax,
				var(--light-blue),
				transparent
			);
	}

	a.button:hover {
		background-color: hsla(0, 100%, 100%, 0.1);
		box-shadow: 0 0 20px hsl(0, 0%, 50%);
		color: hsl(212, 90%, 40%);
		color: var(--dark-blue);
	}

	a.format.chapbook {
		background-image: url('icons/chapbook-dark.svg');
	}

	.card.icon.discord {
		background-image: url('icons/discord-dark.svg');
	}

	.card.icon.iftf {
		background-image: url('icons/iftf-dark.svg');
	}

	.card.icon.patreon {
		background-image: url('icons/patreon-dark.svg');
	}
}

:root {
	/* Used for cards. */
	--shadow-small: 0 1px 1px var(--light-gray);

	/* Used for dropdown menus and other things that hover over the UI. */
	--shadow-large: 0 2px 8px var(--gray);
}

@media (color-index: 48) {
	:root {
		--shadow-small: 0 0 1px var(--dark-gray);
		--shadow-large: 0 0 1px var(--dark-gray), 0 0 10px 2px var(--white);
	}
}

@media (color: 48842621) {
	:root {
		--shadow-small: 0 0 1px var(--dark-gray);
		--shadow-large: 0 0 1px var(--dark-gray), 0 0 10px 2px var(--white);
	}
}

@media (prefers-color-scheme: dark) {
	:root {
		--shadow-small: 0 0 1px var(--dark-gray);
		--shadow-large: 0 0 1px var(--dark-gray), 0 0 10px 2px var(--white);
	}
}

:root {
	/* Baseline grid. */
	--grid-size: 20px;

	/* Height for buttons, text inputs, etc. */
	--control-height: calc(var(--grid-size) * 2.5);

	--control-inner-padding: calc(var(--grid-size) / 2);

	/* Gap between unrelated UI elements. */
	--ui-gap: calc(var(--grid-size) * 2);

	/* Border radius for elements with round corners. */
	--corner-round: 5px;
}

@font-face {
	font-family: 'Nunito Light';
	src: url('fonts/nunito-light.woff2') format('woff2'),
		url('fonts/nunito-light.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

:root {
	/* display font, for titles */
	--font-display: 'Nunito Light', sans-serif;

	/* base UI font */
	--font-system: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif;
}

#intro {
	padding: 20px;
	padding: var(--grid-size);
}

#intro h1 {
	background-image: url('icons/twine.svg');
	background-position: top center;
	background-repeat: no-repeat;
	background-size: 100px;
	font-size: 36px;
	padding-top: calc(100px + calc(20px));
	padding-top: calc(100px + calc(var(--grid-size))); 
	text-align: center;
}

#intro p {
	font-size: 18px;
	line-height: 140%;
}

#intro ul.actions {
	list-style-type: none;
	padding-left: 0;
	text-align: center;
}

#intro ul.actions li {
	display: inline-block;
	font-size: 18px;
	margin: 0 calc(calc(20px * 2) / 4);
	margin: 0 calc(var(--ui-gap) / 4);
}

#intro .version {
	font-size: 16px;
	text-align: center;
}

@media (max-width: 500px) {
	#intro ul.actions {
		display: flex;
		flex-direction: column;
		grid-gap: calc(20px / 2);
		grid-gap: calc(var(--grid-size) / 2);
		margin-left: 0;
		margin-right: 0;
	}

	#intro ul.actions a {
		display: block;
	}
}

#resources {
	display: grid;
	grid-gap: 20px;
	grid-gap: var(--grid-size);
	grid-template-columns: 3fr 3fr 4fr;
	padding: 0 20px 20px 20px;
	padding: 0 var(--grid-size) var(--grid-size) var(--grid-size);
}

#resources > * {
	background-color: hsla(0, 100%, 100%, 0.4);
	border-radius: calc(2 * 5px);
	border-radius: calc(2 * var(--corner-round));
	padding: 0 20px 20px 20px;
	padding: 0 var(--grid-size) var(--grid-size) var(--grid-size);
}

#resources h1 {
	background-blend-mode: lighten;
	background-position: center left;
	background-repeat: no-repeat;
	background-size: 48px;
	font-size: 30px;
	height: 48px;
	line-height: 48px;
	padding-left: calc(48px + calc(20px / 2) / 2);
	padding-left: calc(48px + var(--control-inner-padding) / 2);
	margin-bottom: 20px;
	margin-bottom: var(--grid-size);
	text-align: left;
}

#resources #community {
	align-items: center;
	display: grid;
	grid-column: 1 / span 3;
	grid-gap: 20px;
	grid-gap: var(--grid-size);
	grid-row: 3 / span 1;
	grid-template-columns: auto 1fr 1fr;
	padding-top: 20px;
	padding-top: var(--grid-size);
}

#resources #community h1 {
	background-image: url('icons/users-light.svg');
	margin: 0;
}

#resources #donate {
	grid-column: 3 / span 1;
	grid-row: 1 / span 2;
}

#resources #donate h1 {
	background-image: url('icons/heart-light.svg');
}

#resources #learn {
	align-items: flex-start;
	grid-column: 1 / span 2;
	grid-row: 1 / span 1;
}

#resources #learn h1 {
	background-image: url('icons/book-light.svg');
}

#resources #learn .cards {
	grid-template-columns: 2fr 1fr;
}

#resources #source-code {
	grid-column: 1 / span 2;
	grid-gap: 20px;
	grid-gap: var(--grid-size);
	grid-row: 2 / span 1;
}

#resources #source-code h1 {
	background-image: url('icons/file-code-light.svg');
}

#resources #source-code .cards {
	grid-template-columns: 2fr 3fr;
}

#resources .cards {
	display: grid;
	grid-gap: 20px;
	grid-gap: var(--grid-size);
}

#resources .cards.staggered .card {
	margin-right: calc(2 * 20px);
	margin-right: calc(2 * var(--grid-size));
}

#resources .cards.staggered .card:nth-child(even) {
	margin-left: calc(2 * 20px);
	margin-left: calc(2 * var(--grid-size));
	margin-right: 0;
}

#resources .cards.staggered.reverse .card {
	margin-left: calc(2 * 20px);
	margin-left: calc(2 * var(--grid-size));
	margin-right: 0;
}

#resources .cards.staggered.reverse .card:nth-child(even) {
	margin-left: 0;
	margin-right: calc(2 * 20px);
	margin-right: calc(2 * var(--grid-size));
}

@media (max-width: 768px) {
	#resources {
		display: flex;
		flex-direction: column;
	}
}

@media (max-width: 500px) {
	#resources #learn .cards, #resources #community, #resources #source-code .cards {
		display: flex;
		flex-direction: column;
		grid-gap: 20px;
		grid-gap: var(--grid-size);
	}

	#resources .cards.staggered .card, #resources .cards.staggered .card:nth-child(even) {
		margin: 0;
	}

	#resources #community {
		align-items: flex-start;
	}
}

@media (color-index: 48) {
	#resources > * {
		background-color: hsla(0, 0%, 0%, 0.15);
	}

	#resources h1 {
		opacity: 0.8;
	}

	#resources #community h1 {
		background-image: url('icons/users-dark.svg');
	}

	#resources #donate h1 {
		background-image: url('icons/heart-dark.svg');
	}

	#resources #learn h1 {
		background-image: url('icons/book-dark.svg');
	}

	#resources #source-code h1 {
		background-image: url('icons/file-code-dark.svg');

	}
}

@media (color: 48842621) {
	#resources > * {
		background-color: hsla(0, 0%, 0%, 0.15);
	}

	#resources h1 {
		opacity: 0.8;
	}

	#resources #community h1 {
		background-image: url('icons/users-dark.svg');
	}

	#resources #donate h1 {
		background-image: url('icons/heart-dark.svg');
	}

	#resources #learn h1 {
		background-image: url('icons/book-dark.svg');
	}

	#resources #source-code h1 {
		background-image: url('icons/file-code-dark.svg');

	}
}

@media (prefers-color-scheme: dark) {
	#resources > * {
		background-color: hsla(0, 0%, 0%, 0.15);
	}

	#resources h1 {
		opacity: 0.8;
	}

	#resources #community h1 {
		background-image: url('icons/users-dark.svg');
	}

	#resources #donate h1 {
		background-image: url('icons/heart-dark.svg');
	}

	#resources #learn h1 {
		background-image: url('icons/book-dark.svg');
	}

	#resources #source-code h1 {
		background-image: url('icons/file-code-dark.svg');

	}
}

#showcase h1 {
	text-align: center;
}

#showcase .items {
	display: grid;
	grid-gap: 20px;
	grid-gap: var(--grid-size);
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	padding: 20px;
	padding: var(--grid-size);
}

#showcase .items .item {
	aspect-ratio: 1;
	background-position: center;
	background-size: cover;
	border-radius: 5px;
	border-radius: var(--corner-round);
	color: hsl(0, 0%, 98%);
	color: var(--white);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	position: relative;
	transition: transform 0.2s;
}

#showcase .items .item:hover {
	box-shadow: 0 2px 8px hsl(0, 0%, 60%);
	box-shadow: var(--shadow-large);
	transform: scale(1.075);
	z-index: 2;
}

#showcase .items a {
	text-decoration: none;
}

#showcase .item .text {
	align-items: center;
	-webkit-backdrop-filter: blur(10px);
	        backdrop-filter: blur(10px);
	background-color: hsla(0, 0%, 0%, 0.5);
	border-bottom-left-radius: 5px;
	border-bottom-left-radius: var(--corner-round);
	border-bottom-right-radius: 5px;
	border-bottom-right-radius: var(--corner-round);
	display: flex;
	flex-direction: column;
	height: calc(20px * 4);
	height: calc(var(--grid-size) * 4);
	justify-content: center;
}

#showcase .item .text * {
	margin: 0;
}

#showcase .item a {
	color: hsl(0, 0%, 98%);
	color: var(--white);
}

#showcase .item .text * {
	margin: 0;
	text-align: center;
}

#showcase .item.no-art {
	background-color: hsl(212, 90%, 95%);
	background-color: var(--faint-blue);
	background-image: repeating-linear-gradient(-70deg, transparent, transparent 19px, hsl(212, 90%, 90%) 19px, hsl(212, 90%, 90%) 20px), repeating-linear-gradient(200deg, transparent, transparent 19px, hsl(212, 90%, 90%) 19px, hsl(212, 90%, 90%) 20px);
	background-image: repeating-linear-gradient(-70deg, transparent, transparent 19px, var(--light-blue) 19px, var(--light-blue) 20px), repeating-linear-gradient(200deg, transparent, transparent 19px, var(--light-blue) 19px, var(--light-blue) 20px);
	box-shadow: 0 1px 1px hsl(0, 0%, 85%);
	box-shadow: var(--shadow-small);
}

#showcase .item.no-art .text {
	-webkit-backdrop-filter: none;
	        backdrop-filter: none;
	background: none;
	color: hsl(0, 0%, 30%);
	color: var(--dark-gray);
	flex-grow: 1;
	padding: 20px;
	padding: var(--grid-size);
}

#showcase .more {
	text-align: center;
}

@media (max-width: 768px) {
	#resources {
		display: flex;
		flex-direction: column;
	}
}

@media (color-index: 48) {
	#showcase .items .item {
		color: var(--black);
	}

	#showcase .items a {
		color: var(--black);
	}
}

@media (color: 48842621) {
	#showcase .items .item {
		color: var(--black);
	}

	#showcase .items a {
		color: var(--black);
	}
}

@media (prefers-color-scheme: dark) {
	#showcase .items .item {
		color: var(--black);
	}

	#showcase .items a {
		color: var(--black);
	}
}

footer {
	margin-bottom: calc(2 * 20px);
	margin-bottom: calc(2 * var(--grid-size));
	text-align: center;
}

.error-page {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 100vh;
}