:root {
	--sans: system-ui, sans-serif;
	--mono: ui-monospace, monospace;
	--optical: 1;
}
html {
	padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
	scroll-behavior: smooth;
	scroll-padding-top: 10em;
	font-synthesis: none;
	-webkit-font-smoothing: antialiased;
}
img {
	-webkit-user-select: none !important;
	-khtml-user-select: none !important;
	-moz-user-select: none !important;
	-o-user-select: none !important;
	user-select: none !important;

	-webkit-user-drag: none;
	-khtml-user-drag: none;
	-moz-user-drag: none;
	-o-user-drag: none;
	user-drag: none;
}
.black {
	--bg: 0.08 0.09 0.1;
	--text: 0.92 0.93 0.95;
	--accent: 0.64 0.69 0.75;
	--border: 0.38 0.44 0.50;
	--tertiary: 0 0.8 0.67;
	--highlight: 0.08 0.32 0.8;
}
.white {
	--bg: 0.92 0.93 0.95;
	--text: 0.08 0.09 0.1;
	--accent: 0.38 0.44 0.5;
	--border: 0.64 0.69 0.75;
	--tertiary: 0 0.6 0.5;
	--highlight: 0.08 0.32 0.8;
}
.system {
	--bg: 0 0 0;
	--text: 0.90 0.95 1.00;
	--tertiary: 1.00 0.20 0.00;
	--border: 0.00 0.00 0.60;
	--accent: 0.00 0.65 1.00;
	--highlight: 0.45 0.00 1.00;
}
.mudhorn {
	--bg: 0.20 0.16 0.15;
	--text: 0.85 0.85 0.85;
	--accent: 0.75 0.73 0.71;
	--border: 0.38 0.42 0.45;
	--tertiary: 1 0.75 0.25;
	--highlight: 0.07 0.75 0.53;
}
.rebo {
	--bg: 0 0.05 0.20;
	--text: 0.85 0.86 0.9;

	--pink: 1 0.45 0.73;
	--orange: 1 0.73 0.16;
	--yellow: 1 0.89 0.33;
	--green: 0.56 0.91 0.43;
	--blue: 0.19 0.71 0.80;
	--purple: 0.66 0.45 0.85;
	--gray: 0.3 0.31 0.41;

	--accent: var(--yellow);
	--border: var(--blue);
	--tertiary: var(--orange);
	--highlight: var(--pink);
}
.xavier {
	--bg: 0.09 0.18 0.45;
	--text: 1.00 0.80 0.20;
	--accent: 1.00 0.50 0.25;
	--border: 0.21 0.32 0.85;
	--tertiary: 0.00 0.84 1.00;
	--highlight: 1.00 0.20 0.40;
}
.nola {
	--bg: 0.05 0.2 0.13;
	--text: 0.95 0.88 0.85;
	--accent: 0.72 0.8 0.64;
	--border: 0.12 0.4 0.26;
	--tertiary: 0.85 0.69 0.38;
	--highlight: 0.56 0.32 0.8;
}
.flynn {
	--bg: 0 0.07 0.1;
	--text: 0.6 1 1;
	--accent: 0.3 0.67 0.75;
	--border: 0.22 0.26 0.3;
	--tertiary: 0.35 1 0.56;
	--highlight: 0 0.85 0.85;
}
.doctor {
	--bg: 0.14 0.23 0.40;
	--text: 0.90 0.89 0.85;
	--accent: 0.75 0.75 0.67;
	--border: 0.30 0.40 0.50;
	--tertiary: 0.38 0.76 0.95;
	--highlight: 0.00 0.75 0.68;
}
.maihama {
	--bg: 0.28 0.4 0.37;
	--text: 1 0.96 0.9;
	--accent: 0.85 0.82 0.64;
	--border: 0.51 0.6 0.58;
	--tertiary: 1 0.8 0.2;
	--highlight: 0.16 0.8 0.69;
}
.theed {
	--bg: 0.40 0.00 0.17;
	--text: 00.95 0.85 0.71;
	--accent: 0.73 0.85 0.72;
	--border: 0.60 0.39 0.18;
	--tertiary: 0.90 0.65 0.31;
	--highlight: 0.45 0.67 0.90;
}
.tours {
	--bg: 0.06 0.10 0.30;
	--text: 0.60 0.90 1.00;
	--accent: 0.35 0.67 1.00;
	--border: 0.20 0.40 1.00;
	--tertiary: 1.00 0.51 0.15;
	--highlight: 0.00 0.75 1.00;
}
.ghost {
	--bg: 0.13 0.14 0.15;
	--text: 0.85 0.81 0.76;
	--accent: 0.65 0.55 0.45;
	--border: 0.35 0.27 0.21;
	--tertiary: 1 0.55 0.1;
	--highlight: 0.9 0.36 0.09;
}
.tertiary {
	color: color(display-p3 var(--tertiary) / 1)
}
.theme-selector input[type="radio"] {
	position: relative;
	appearance: none;
	width: 1.25rem;
	height: 1.25rem;
	border-radius: 2em;
	outline: 1px solid color(display-p3 var(--accent) / 1);
	background-color: color(display-p3 var(--bg) / 1);
}
.theme-selector input[type="radio"]:hover {
	outline: 1px solid color(display-p3 var(--text) / 1);
}
.theme-selector input[type="radio"]:active {
	outline: 1px solid color(display-p3 var(--text) / 0.5);
}
.theme-selector input[type="radio"]:checked {
	border: 6px solid color(display-p3 var(--bg) / 1);
	background-color: color(display-p3 var(--text) / 1);
}

::selection {
	background: color(display-p3 var(--highlight) / 0.5);
}
@font-face {
	font-family: "Polyhedra";
	src: url("/files/fonts/Polyhedra13.woff2") format('woff2-variations');
	/* font-weight: 300 900; */
}
.polyhedra {
	font-family: "Polyhedra";
	--optical: 0.75;
}
.polyhedra .repertoire {
	grid-template-columns: repeat(auto-fit, minmax(2em, 1fr));
}
@font-face {
	font-family: "Leota";
	src: url("/files/fonts/Leota.ttf") format('woff2-variations');
	font-weight: 300 900;
}
.leota {
	font-family: "Leota";
	--optical: 1.125;
}
@font-face {
	font-family: "Mutant";
	src: url("/files/fonts/MutantVF.woff2") format('woff2-variations');
}
.mutant {
	font-family: "Mutant";
	--optical: 0.8125;
}
@font-face {
	font-family: "Womprat";
	src: url("/files/fonts/Womprat.woff2") format('woff2');
}
.womprat {
	font-family: "Womprat";
	--optical: 0.875;
}
.womprat .repertoire {
	grid-template-columns: repeat(auto-fit, minmax(2em, 1fr));
}
#catchwords-list:not(.ss15) {
	font-size-adjust: 0.25;
}
@font-face {
	font-family: "WompratAurebesh";
	src: url("/files/fonts/WompratAurebesh.woff2") format('woff2');
}
.womprat .aurebesh, .womprat.aurebesh {
	font-family: "WompratAurebesh";
}
.womprat .high-galactic, .womprat.high-galactic,
.womprat .aurebesh .repertoire li:hover, .womprat.aurebesh .repertoire li:hover {
	font-family: "Womprat";
}
button.aurebesh {
	font-feature-settings: "dlig" 1;
}
@font-face {
	font-family: "Urayasu";
	src: url("/files/fonts/Urayasu.woff2") format('woff2');
}
.urayasu {
	font-family: "Urayasu";
	--optical: 1.125;
}
@font-face {
	font-family: "Spectre";
	src: url("/files/fonts/Spectre.woff2") format('woff2');
}
.spectre {
	font-family: "Spectre";
	--optical: 1.0625;
}
@font-face {
	font-family: "Sacul";
	src: url("/files/fonts/Sacul.woff2") format('woff2');
}
.sacul {
	font-family: "Sacul";
	--optical: 1;
}
@font-face {
	font-family: "SaculAurebesh";
	src: url("/files/fonts/SaculAurebesh.woff2") format('woff2');
}
.sacul .aurebesh, .sacul.aurebesh {
	font-family: "SaculAurebesh";
}
.sacul .high-galactic, .sacul.high-galactic,
.sacul .aurebesh .repertoire li:hover, .sacul.aurebesh .repertoire li:hover {
	font-family: "Sacul";
}

@font-face {
	font-family: "Nabouveau";
	src: url("/files/fonts/NabouveauLatin.woff2") format('woff2');
}
.nabouveau, .nabouveau.high-galactic, .nabouveau .high-galactic {
	font-family: "Nabouveau";
	--optical: 0.875;
}
@font-face {
	font-family: "NabouveauFuthork";
	src: url("/files/fonts/NabouveauFuthork.woff2") format('woff2');
}
.nabouveau .futhork, .nabouveau.futhork {
	font-family: "NabouveauFuthork";
}
.nabouveau .repertoire {
	grid-template-columns: repeat(auto-fit, minmax(2em, 1fr));
}
@font-face {
	font-family: "Pandorica";
	src: url("/files/fonts/Pandorica.woff2") format('woff2');
}
.pandorica {
	font-family: "Pandorica";
	--optical: 0.875;
}

@font-face {
	font-family: "Isomorphic";
	src: url("/files/fonts/Isomorphic.woff2") format('woff2');
}
@font-face {
	font-family: "IsomorphicOutline";
	src: url("/files/fonts/IsomorphicOutline.woff2") format('woff2');
}
.isomorphic {
	font-family: "Isomorphic";
	--optical: 0.875;
}
.isomorphic.outline, .isomorphic .outline {
	font-family: "IsomorphicOutline";
}
.isomorphic .regular, .isomorphic .repertoire li:hover {
	font-family: "Isomorphic";
}

body {
	background: color(display-p3 var(--bg) / 1);
	color: color(display-p3 var(--text) / 1);
	width: calc( 100% - 4rem);
	margin: 0 auto 1.5rem auto;
	font-family: var(--sans);
	font-synthesis: none;
	font-size: 0.75rem;
	overflow-x: auto;
	max-width: 1280px;
}
nav {
	position: fixed;
	display: flex;
	align-items: center;
	width: 100%;
	height: 4rem;
	padding: 0 2rem;
	margin: 0;
	top: 0;
	left: 0;
	background: color(display-p3 var(--bg) / 0.875);
	backdrop-filter: blur(0.25rem);
	-webkit-backdrop-filter: blur(0.25rem);
	border-bottom: 1px solid color(display-p3 var(--border) / 1);
	box-sizing: border-box;
	font-weight: 500;
	font-width: 125%;
	font-family: var(--sans);
	z-index: 1000;
	overflow-x: scroll;
}
nav a:has(svg) {
	display: inline-flex;
	vertical-align: middle;
}
nav svg {
	width: 2rem;
	height: 2rem;
	margin: 0 0.5rem 0 0;
	fill: currentColor;
	/* fill: color(display-p3 var(--accent) / 1); */
}
nav ul {
	margin: 0;
	padding: 0 0.25rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	text-align: center;
	list-style-type: none;
}
nav li {
	margin: 0.5rem;
}
header {
	text-align: center;
	margin: 6rem 0 1.5rem 0;
	padding-bottom: 1rem;
	border-bottom: 1px solid color(display-p3 var(--border) / 1);
}
header:has(.showcase) {
	border: none;
}
header::after {
	content: '';
	position: fixed;
	top: 4rem;
	left: 0;
	width: 100%;
	height: 24rem;
	z-index: -100;
	/* background: linear-gradient(color(display-p3 var(--highlight) / 0.125), color(display-p3 var(--highlight) / 0)); */
}
.pagination {
	display: flex;
	align-items: center;
}
.pagination img {
	width: calc(100% - 12rem);
	max-width: 960px;
	margin: 1rem auto;
	border: 1px solid color(display-p3 var(--border) / 1);
	box-sizing: border-box;
	display: block;
}
.pagination .previous, .pagination .next {
	font-size: calc(6em * var(--optical));
	margin: 0 auto;
	display: inline-block;
	height: revert;
}
.pagination a, .pagination a:visited {
	color: color(display-p3 var(--accent) / 1);
}
.pagination a:hover {
	color: color(display-p3 var(--text) / 1);
}
.pagination a:active {
	color: color(display-p3 var(--accent) / 0.5);
}
.grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	margin: 1rem 0;
}
.grid img {
	width: 100%;
	border: 1px solid color(display-p3 var(--border) / 1);
	box-sizing: border-box;
}
.marquee {
	overflow: hidden;
	border-left: 1px solid color(display-p3 var(--border) / 1);
	border-right: 1px solid color(display-p3 var(--border) / 1);
	margin: 1rem 0;
}
.marquee img {
	aspect-ratio: 2 / 1;
}
.loop {
	display: flex;
	will-change: transform;
	padding: 0;
	margin: 0;
	gap: 1rem;
}
.loop li {
	position: relative;
	overflow: hidden;
	line-height: 0;
	list-style: none;
	flex: 0 0 auto;
	border: 1px solid color(display-p3 var(--border) / 1);
	box-sizing: border-box;
}
.loop li::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
}
.loop li:has(a):hover::after {
	background: color(display-p3 0 0 0 / 0.5);
	z-index: 1;
}
.loop li:hover {
	border: 1px solid color(display-p3 var(--highlight) / 1);
}
.loop li span {
	position: absolute;
	bottom: 1rem;
	left: 50%;
	transform: translateX(-50%);
	opacity: 0;
	font-family: var(--sans);
	font-size: 0.75rem;
	z-index: 2;
	padding: 1em;
	color: white;
	background: color(display-p3 var(--border) / 0);
	border: 1px solid color(display-p3 var(--border) / 1);
	backdrop-filter: blur(0.125rem);
	-webkit-backdrop-filter: blur(0.125rem);
}
.loop li:hover span {
	opacity: 1;
	background: color(display-p3 var(--highlight) / 0.5);
	border: 1px solid color(display-p3 var(--highlight) / 1);
}
.loop li:active span {
	background: color(display-p3 var(--accent) / 0.25);
	border: 1px solid color(display-p3 var(--accent) / 1);
}
.loop li:has(a):active {
	border: 1px solid color(display-p3 var(--accent) / 1);
}
.loop img {
	width: 256px;
}
.sell {
	padding: 0.75rem;
	text-align: center;
}
article {
	max-width: 640px;
	margin: 3em auto;
}
article p {
	text-align: left;
	text-wrap: initial;
}
article.legal p, header p, .sell p, footer p {
	font-size: 0.75rem;
	font-width: 125%;
}
article h1, article h2, article h3 {
	justify-content: left;
	margin: 0.5em 0;
}
footer {
	text-align: center;
}
a, a:visited {
	font-weight: 800;
	color: color(display-p3 var(--text) / 1);
	text-underline-offset: 2px;
	text-decoration-thickness: 1px;
	text-decoration-color: color(display-p3 var(--text) / 0.5);
}
a:hover {
	color: color(display-p3 var(--highlight) / 1);
	text-decoration-color: color(display-p3 var(--highlight) / 0.5);
}
a:active {
	color: color(display-p3 var(--accent) / 0.5);
	text-decoration-color: color(display-p3 var(--accent) / 0.25);
}
h1 a, h2 a, h3 a, .pagination a {
	text-decoration: none;
}
.showcase {
	width: 100%;
	aspect-ratio: 16 / 9;
	border: 1px solid color(display-p3 var(--border) / 1);
	box-sizing: border-box;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 1.5rem 0;
}
.showcase > * {
	position: absolute;
}
.showcase svg {
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	fill: none;
	stroke-miterlimit: 10;
	stroke-width: 1px;
}
.showcase svg path {
	vector-effect: non-scaling-stroke;
	stroke: color(display-p3 var(--accent) / 1);
}
.showcase svg path.simple {
	stroke: color(display-p3 var(--tertiary) / 1);
}
.showcase img {
	width: 100%;
	height: 100%;
	opacity: 0.5;
	z-index: -1;
}
.white .showcase img {
	display: none;
}
.showcase h2 {
	color: color(display-p3 var(--accent) / 1);
}
.showcase h3 {
	color: color(display-p3 var(--accent) / 1);
}
.accent {
	color: color(display-p3 var(--accent) / 1);
}
h1, h2, h3 {
	margin:  0.5rem 0;
	display: flex;
	align-items: center;
	justify-content: center;
}
h1 {
	font-size: calc(6rem * var(--optical));
}
h2 {
	font-size: calc(3rem * var(--optical));
}
h3 {
	font-size: calc(1rem * var(--optical));
}

.breathe {
	font-variation-settings: "wght" 300, "wdth" 100;
	animation: breathe 5s infinite;
}

@keyframes breathe {
	0%		{ font-variation-settings: "wght" 300, "wdth" 100; }
	25%		{ font-variation-settings: "wght" 300, "wdth" 200; }
	50%		{ font-variation-settings: "wght" 700, "wdth" 200; }
	75%	{ font-variation-settings: "wght" 700, "wdth" 100; }
	100%	{ font-variation-settings: "wght" 300, "wdth" 100; }
}

.taxonomy {
	display: flex;
}
.taxonomy ul {
	flex: 1;
	padding: 0;
	list-style-type: none;
	font-size: 1rem;
	width: fit-content;
	line-height: 3em;
	color: color(display-p3 var(--text) / 1);
}
.taxonomy li {
	padding: 0 1em;
	border: 1px solid color(display-p3 var(--border) / 1);
	margin-right: -1px;
	margin-bottom: -1px;
}
.taxonomy ul:first-of-type {
	font-width: 100%;
}
.taxonomy ul:nth-of-type(2) {
	font-width: 150%;
}
.taxonomy ul:nth-of-type(3) {
	font-width: 200%;
}
.taxonomy ul li:first-of-type {
	font-weight: 300;
}
.taxonomy ul li:nth-of-type(2) {
	font-weight: 400;
}
.taxonomy ul li:nth-of-type(3) {
	font-weight: 500;
}
.taxonomy ul li:nth-of-type(4) {
	font-weight: 600;
}
.taxonomy ul li:nth-of-type(5) {
	font-weight: 700;
}

header h1 {
	font-weight: 300;
	height: 8rem;
}
header h2 {
	font-weight: 400;
	height: 4rem;
}
header h3 {
	font-weight: 500;
	height: 0.75rem;
}
hr {
	border: 0.5px solid color(display-p3 var(--border) / 1);
	margin: 1.5rem auto;
}
p {
	font-size: 1rem;
	line-height: 1.5em;
	font-family: var(--sans);
	color: color(display-p3 var(--accent) / 1);
	text-align: center;
	text-wrap: balance;
}
.home {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.home h1 {
	aspect-ratio: 4 / 1;
	width: 100%;
	height: 100%;
	background: color(display-p3 var(--bg) / 1);
	text-decoration: none;
	margin: 0;
}
.home h1 a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}
ul, ol {
	line-height: 1.5em;
	color: color(display-p3 var(--accent) / 1);
}
button {
	white-space: nowrap;
	cursor: pointer;
	font-family: inherit;
	font-size: calc(2rem * var(--optical));
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	height: 4rem;
	padding: 0 1em;
	margin: 0.5rem;
	line-height: 1em;
	outline: none;
	border: 1px solid color(display-p3 var(--border) / 1);
	color: color(display-p3 var(--text) / 1);
	background: color(display-p3 var(--accent) / 0);
}
button:hover {
	color: color(display-p3 var(--highlight) / 1) !important;
	background: color(display-p3 var(--highlight) / 0.25) !important;
	border: 1px solid color(display-p3 var(--highlight) / 1) !important;
}
button:active {
	color: color(display-p3 var(--accent) / 1) !important;
	background: color(display-p3 var(--accent) / 0.25) !important;
	border: 1px solid color(display-p3 var(--accent) / 1) !important;
}
button, form, form *, .repertoire {
	user-select: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
}
form:not(header form) {
	font-weight: 500;
	font-family: var(--mono);
	font-size: 0.75rem;
	column-width: 15rem;
	column-gap: 1rem;
	gap: 0.5rem;
	color: color(display-p3 var(--accent) / 1);
	border: 1px solid color(display-p3 var(--border) / 1);
	box-sizing: border-box;
	padding: 0.75rem 1rem;
}
form div {
	display: flex;
	align-items: center;
	height: 1.5rem;
	break-inside: avoid;
	white-space: nowrap;
	overflow: hidden;
}
input {
	accent-color: color(display-p3 var(--accent) / 1);
}
.truncate {
	display: none;
}
.affected, .help {
	padding: 0.125em 0.5em 0.1875em 0.5em;
	border-radius: 2em;
}
.help {
	cursor: default;
	font-weight: 800;
	color: color(display-p3 var(--highlight) / 1);
	background: color(display-p3 var(--highlight) / 0.25);
}
.help:hover {
	color: color(display-p3 var(--text) / 1);
	background: color(display-p3 var(--highlight) / 0.5);
}
.affected {
	margin-left: 0.5rem;
	color: color(display-p3 var(--tertiary) / 1);
	background: color(display-p3 var(--tertiary) / 0.25);
}
label {
	margin: 0;
	padding: 0.5rem;
}
label:hover .affected, input:hover:has(+ label) + label .affected {
	color: color(display-p3 var(--text) / 1);
	background: color(display-p3 var(--tertiary) / 0.5);
}
label:active .affected {
	background: color(display-p3 var(--accent) / 0.125);
}
label, input {
	cursor: pointer;
}
label:hover, input:hover:has(+ label) + label {
	color: color(display-p3 var(--text) / 1);
}
label:active, label:active .affected, input[type="checkbox"]:checked + label:active, div:has(input:disabled) label {
	color: color(display-p3 var(--accent) / 0.5);
}
div:has(input:disabled) label, input:disabled {
	cursor: not-allowed;
}
input[type="range"] {
	-webkit-appearance: none;
	background: transparent;
	margin-right: 0.5rem;
	width: 6rem;
	text-align: right;
}
input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	color: color(display-p3 var(--text) / 1);
	background: color(display-p3 var(--accent) / 1);
	width: 1rem;
	height: 1rem;
	border-radius: 2em;
	margin-top: -0.5rem;
}
input[type="range"]::-webkit-slider-thumb:hover {
	background: color(display-p3 var(--text) / 1);
}
input[type="range"]::-webkit-slider-runnable-track {
	background: color(display-p3 var(--accent) / 0);
	height: 0;
	border-radius: 1rem;
	border: 0.5px solid color(display-p3 var(--accent) / 1);
}
input[type="checkbox"] {
	flex-shrink: 0;
	appearance: none;
	width: 0.875rem;
	height: 0.875rem;
	margin: 0 0 0 0.125rem;
	background: color(display-p3 var(--accent) / 1);
	border-radius: 0.125rem;
	outline: 1px solid color(display-p3 var(--accent) / 1);
	background-color: color(display-p3 var(--bg) / 1);
}
input[type="checkbox"]:hover {
	outline: 1px solid color(display-p3 var(--text) / 1);
}
input[type="checkbox"]:active, input[type="checkbox"]:disabled {
	outline: 1px solid color(display-p3 var(--accent) / 0.5);
}
input[type="checkbox"]:checked {
	border: 3px solid color(display-p3 var(--bg) / 1);
	background-color: color(display-p3 var(--text) / 1);
}
input[type="checkbox"]:checked + label {
	color: color(display-p3 var(--text) / 1);
	font-weight: 800;
}
input[type="checkbox"].rounded {
	border-radius: 2em;
}
select {
	font-family: inherit;
	cursor: context-menu;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	padding: 0.125em 0.5em 0.25em 0.5em;
	outline: none;
	border: 1px solid color(display-p3 var(--accent) / 1);
	border-radius: 0.25rem;
	background: none;
	color: color(display-p3 var(--text) / 1);
}
select:hover {
	color: color(display-p3 var(--text) / 1);
	border: 1px solid color(display-p3 var(--highlight) / 1);
	background: color(display-p3 var(--highlight) / 0.5);
}
.sample {
	color: inherit;
	background: none;
	font-family: inherit;
	font-size: calc(6rem * var(--optical));
	text-align: center;
	caret-color: color(display-p3 var(--highlight) / 1);
	margin: 0;
	padding: 1rem 0.25rem;
	outline: none;
	overflow: hidden;
	grid-area: 1 / 1/ 2 / 2;
	resize: none;
	width: 100%;
	border: 1px solid color(display-p3 var(--border) / 0);
	box-sizing: border-box;
}
.sample::placeholder {
	color: color(display-p3 var(--text) / 1);
}
.sample:hover::placeholder {
	color: color(display-p3 var(--highlight) / 0.5);
}
.sample:hover {
	border: 1px solid color(display-p3 var(--highlight) / 1);
}
.sample:focus::placeholder, .sample:active::placeholder {
	color: color(display-p3 var(--border) / 0.25);
}
.sample:focus {
	border: 1px solid color(display-p3 var(--border) / 1);
}
.sample:active {
	border: 1px solid color(display-p3 var(--accent) / 1);
}
form + h3, .repertoire + h3 {
	margin-top: 2rem;
}
h3 + form, h3 + .repertoire {
	margin-top: 0;
}
form, .repertoire {
	margin: 1.5rem 0;
}
form + hr, .repertoire + hr {
	margin: 2rem 0 1.5rem 0;
}
.repertoire {
	width: calc(100% - 1px);
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(1.5em, 1fr));
	gap: 0;
	padding: 0;
	border: 0;
	font-size: calc(3rem * var(--optical));
	line-height: 1.5em;
	text-align: center;
	list-style-type: none;
}
.repertoire li {
	position: relative;
	align-items: center;
	color: color(display-p3 var(--text) / 1);
	border: 1px solid color(display-p3 var(--border) / 1);
	margin-right: -1px;
	margin-bottom: -1px;
	cursor: pointer;
}
.repertoire::after {
	content: "";
	grid-column: 1 / -1;
	visibility: hidden;
}
.repertoire li:hover {
	color: color(display-p3 var(--highlight) / 1) !important;
	background: color(display-p3 var(--highlight) / 0.25) !important;
	border: 1px solid color(display-p3 var(--highlight) / 1) !important;
	z-index: 10 !important;
}
.repertoire li::before {
	font-family: var(--sans);
	font-size: 0.875rem;
	font-weight: 800;
	font-width: 100%;
	content: "Copied";
	color: white;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: 250ms ease-in-out;
	pointer-events: none;
	font-feature-settings:
		"ss01" 0,
		"ss02" 0,
		"ss03" 0,
		"ss04" 0,
		"ss05" 0,
		"ss06" 0,
		"ss07" 0,
		"ss08" 0,
		"ss09" 0,
		"ss10" 0,
		"ss11" 0,
		"ss12" 0,
		"ss13" 0,
		"ss14" 0,
		"ss15" 0,
		"ss16" 0,
		"ss17" 0,
		"ss18" 0,
		"ss19" 0,
		"ss20" 0;
}
.repertoire li.copied::before {
	opacity: 1;
	content: "Copied";
	backdrop-filter: blur(0.125rem);
	-webkit-backdrop-filter: blur(0.125rem);
	transition: 50ms ease-in-out;
}
.repertoire li:active {
	color: color(display-p3 var(--accent) / 1) !important;
	background: color(display-p3 var(--accent) / 0.25) !important;
	border: 1px solid color(display-p3 var(--accent) / 1) !important;
	z-index: 100 !important;
}
.repertoire li.copied {
	color: color(display-p3 var(--border) / 1);
}

.calt > li.calt,
.liga > li.liga,
.dlig > li.dlig,
.titl > li.titl,
.salt > li.salt,
.tnum > li.tnum,
.onum > li.onum,
.ss01 > li.ss01,
.ss02 > li.ss02,
.ss03 > li.ss03,
.ss04 > li.ss04,
.ss05 > li.ss05,
.ss06 > li.ss06,
.ss07 > li.ss07,
.ss08 > li.ss08,
.ss09 > li.ss09,
.ss10 > li.ss10,
.ss11 > li.ss11,
.ss12 > li.ss12,
.ss13 > li.ss13,
.ss14 > li.ss14,
.ss15 > li.ss15,
.ss16 > li.ss16,
.ss17 > li.ss17,
.ss18 > li.ss18,
.ss19 > li.ss19,
.ss20 > li.ss20 {
	color: color(display-p3 var(--tertiary) / 1);
	border: 1px solid color(display-p3 var(--tertiary) / 1);
	background-color: color(display-p3 var(--tertiary) / 0.125);
	z-index: 1;
}
@media (max-width: 680px) {
	body {
		width: calc( 100% - 2rem);
	}
	nav {
		padding: 0 1rem;
	}
	h1 {
		font-size: calc(3rem * var(--optical));
	}
	h2 {
		font-size: calc(2rem * var(--optical));
	}
	h3 {
		font-size: calc(1rem * var(--optical));
	}
	header h1 {
		height: 4rem;
	}
	header h2 {
		height: 2.67rem;
	}
	header h3 {
		height: 0.75rem;
	}
	.pagination img {
		width: calc(100% - 6rem);
	}
	.pagination .previous, .pagination .next {
		font-size: calc(3em * var(--optical));
	}
	button {
		height: 3rem;
		padding: 0 0.75em;
		font-size: calc(1.5rem * var(--optical));
	}
	.sample {
		font-size: calc(2.5rem * var(--optical));
	}
	.repertoire {
		font-size: calc(2rem * var(--optical));
	}
	.repertoire li::before {
		font-size: 0.5rem;
	}
}

@media (hover: none) and (pointer: coarse) {
	.help {
		display: none;
	}
}