:root {
	--white: color(display-p3 1 1 1 / 1);
	--lighter-gray: color(display-p3 0.931 0.937 0.95 / 1);
	--light-gray: color(display-p3 0.833 0.838 0.85 / 1);
	--gray: color(display-p3 0.712 0.725 0.75 / 1);
	--dark-gray: color(display-p3 0.36 0.374 0.4 / 1);
	--black: color(display-p3 0 0 0 / 1);
	--yellow: color(display-p3 1 0.813 0.25 / 1);
	--orange: color(display-p3 1 0.707 0.12 / 1);
	--red-orange: color(display-p3 0.9 0.428 0.09 / 1);
	--violet: color(display-p3 0.208 0 0.5 / 1);
	--violet-50: color(display-p3 0.208 0 0.5 / 0.5);
	--violet-25: color(display-p3 0.208 0 0.5 / 0.25);
	--purple: color(display-p3 0.50 0.00 0.50 / 1);
	--purple-50: color(display-p3 0.50 0.00 0.50 / 0.5);
	--purple-25: color(display-p3 0.50 0.00 0.50 / 0.25);
	--bg: var(--lighter-gray);
	--inventory-bg: var(--black);
	--text: var(--black);
	--link: var(--violet);
	--visited: var(--violet);
	--active: var(--purple-50);
	--hover: var(--purple);
	--app-accent: var(--light-gray);
}
.white-rabbit {
	--app-accent: color(display-p3 0.202 0.45 0.326);
}
.daruma {
	--app-accent: color(display-p3 0.75 0.188 0.188);
}
* {
	box-sizing: border-box;
}
html {
	background: var(--bg);
	font-synthesis: none;
	padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
	margin: auto;
	display: flex;
	min-height: 100vh;
	scroll-behavior: smooth;
	scroll-padding-top: 1em;
}
body {
	width: 100%;
	font-family: ui-sans-serif;
	color: var(--text);
	margin: 0;
}
header {
	display: block;
	margin: 0;
	padding: 0;
	width: 100%;
	box-shadow: 0 2px 6px var(--light-gray);
}
main, footer {
	width: 100%;
	max-width: 960px;
	margin: 2em auto;
	padding: 0 2em;
}
footer {
	text-align: right;
	color: var(--gray);
	line-height: 1.25em;
}
hr {
	border: none;
	border-top: 1px solid var(--light-gray);
	margin: 1.5em 0;
}
.logo {
	display: inline-block;
	width: 176px;
	height: 40px;
	margin: 0 auto 0 0;
	background: currentColor;
	/* background: linear-gradient(180deg, var(--violet), var(--purple)); */
	-webkit-mask-image: url('kadomaru.svg');
	mask-image: url('kadomaru.svg');
}
.brand {
	background: var(--yellow);
	border-bottom: 1px solid var(--orange);
	padding: 1em;
}
.brand div {
	display: flex;
	margin: 0 auto;
	max-width: 960px;
	align-items: center;
}
nav {
	background: var(--white);
	color: var(--purple);
	margin: 0;
	padding: 0.5em 0;
	width: 100%;
	font-weight: 500;
}
nav ul {
	display: flex;
	list-style: none;
	padding: 0;
	margin: 0 auto;
	max-width: 960px;
	line-height: 1em;
}
nav li {
	display: flex;
	flex: 1;
	text-align: center;
	border-left: 1px solid var(--lighter-gray);
}
nav li:last-child {
	border-right: 1px solid var(--lighter-gray);
}
nav li a {
	text-decoration: none;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding: 0.5em;
}
nav li svg {
	height: 24px;
	width: 24px;
	margin: -0.0625 0.25em 0 0.25em;
	display: inline-block;
	vertical-align: middle;
}
nav li svg path.primary {
	fill: var(--yellow);
}
nav li svg path.secondary {
	fill: currentColor;
}
a {
	color: var(--link);
}
a:visited {
	color: var(--visited);
}
a:hover {
	color: var(--hover);
}
a:active {
	color: var(--active);
}
h1 a, h2 a, h3 a, .grid a {
	text-decoration: none;
}
h1, h2, h3 {
	margin: 0.5em 0;
}
h1 {
	font-weight: 800;
}
h2 {
	font-weight: 700;
}
h3 {
	color: var(--gray);
	font-weight: 600;
}
p {
	margin: 1em 0;
	line-height: 1.25em;
}
section p {
	max-width: 480px;
}
section:has(p):not(:has(.app)) {
	max-width: 480px;
	margin: 0 auto;
}
blockquote {
	color: var(--dark-gray);
	border-left: 1px solid var(--light-gray);
	padding: 0 1.5em;
	margin: 1.5em 0;
}
ol, ul {
	margin: 0;
	padding: 0 0 0 1.5em;
	line-height: 1.25em;
}
code {
	font-family: ui-monospace;
	color: var(--purple);
}
.grid {
	max-width: 480px;
	margin: 2em auto;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(128px, 1fr));
	gap: 1em;
}
.grid .tile {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.grid .tile img {
	width: min(128px, 30vw);
	height: min(128px, 30vw);
	margin: 0;
	user-drag: none;
	-webkit-user-drag: none;
}
.grid .tile span {
	display: block;
	text-align: center;
	margin: 1em 0 1.5em 0;
	font-weight: 500;
}
.grid .tile a {
	color: var(--dark-gray);
}
.grid .tile a:hover span {
	color: var(--gray);
}
.grid .tile a:hover img {
	opacity: 0.75;
}
.grid .tile a:active span, .grid .tile a:active img {
	opacity: 0.625;
}
.icon {
	mask: url("./app.svg");
	-webkit-mask: url("./app.svg");
}
.app .icon {
	display: inline-block;
	width: 1.5em;
	vertical-align: -0.375em;
	margin-right: 0.25em;
}
.app {
	display: flex;
	align-items: center;
}
.app h1 {
	margin-right: auto;
}
section:has(.grid) h1,
section:has(.grid) h3,
section:has(.grid) p {
	text-align: center;
}
.version {
	color: var(--gray);
	font-weight: 200;
}
button {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	white-space: nowrap;
	cursor: pointer;
	color: var(--white);
	background: var(--violet);
	box-shadow: 0 2px 6px var(--light-gray);
	font-weight: 700;
	font-size: 1em;
	border-radius: 2em;
	padding: 1em 1.5em;
	margin: 0.5em 0;
	line-height: 1em;
	outline: none;
	border: none;
}
button:hover {
	background: var(--purple);
}
button:active {
	background: var(--purple-50);
}
.screenshot {
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 0.125em;
	box-shadow: 0 4px 12px var(--light-gray);
	background: var(--app-accent);
	margin: 2em 0;
	position: relative;
}
.screenshot img {
	position: absolute;
	inset: 2em;
	width: calc(100% - 4em);
	height: calc(100% - 4em);
	object-fit: contain;
}
table {
	width: 100%;
	border: 1px solid var(--light-gray);
	border-collapse: collapse;
	margin: 1.5em 0;
}
section table {
	max-width: 480px;
}
td, th {
	height: 2em;
	min-width: 1.5em;
	padding: 0.25em;
	border: 1px solid var(--light-gray);
}
@media (max-width: 600px) {
	.logo {
		margin: 0 auto;
	}
	nav li {
		font-size: 0.875em;
	}
	nav li:first-child {
		border-left: none;
	}
	nav li:last-child {
		border-right: none;
	}
	nav li a {
		flex-direction: column;
		padding: 0.25em;
	}
	nav li svg {
		height: 32px;
		width: 32px;
		margin: 0 auto 0.5em auto;
		display: block;
		vertical-align: middle;
	}
	main, footer {
		padding: 0 1.5em;
	}
	section p {
		margin: 1.5em auto;
	}
	footer {
		text-align: center;
	}
	section:has(.app) h1,
	section:has(.app) h2,
	section:has(.app) h3 {
		text-align: center;
	}
	section:has(.app) button {
		display: block;
		margin: 0.5em auto;
	}
	.app .icon {
		display: block;
		width: 128px;
		margin: 0.25em auto 0.5em auto;
	}
	.screenshot img {
		inset: 1em;
		width: calc(100% - 2em);
		height: calc(100% - 2em);
	}
	.app {
		flex-direction: column;
		gap: 0.5em;
	}
	.app h1 {
		margin: 0;
	}
}