:is(#toc, #rules) summary:is(:hover, :focus-visible) {
	color: var(--color-accent-dark);
}

#toc summary {
	--icon: dots;
}

#toc[open] summary {
	--icon: minus;
}

#toc ul {
	position: absolute;
	width: 100%;
	left: 0;
	right: 0;
	padding: 1em 2em;

	background: var(--color-secondary-light);
	box-shadow: 0 0.5em 0.5em rgba(0, 0, 0, 0.2);
	text-align: right;
	border-bottom-left-radius: 1em;
	border-bottom-right-radius: 1em;
}

#title {
	font-size: 200%;
	line-height: 1.2;
	margin-bottom: 0.5em;
}

h2 {
	font-weight: bold;
	text-transform: uppercase;
}

#meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
	margin-bottom: 1em;
	margin-left: -0.2em;

	font-size: 87.5%;
}

article > :first-child {
	margin: 3em 0;
}

#rules summary span {
	--icon: info;
	display: inline-flex;
	gap: 0.2em;
	align-items: center;
}

#more {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1em;
}

#section-title {
	display: flex;
	align-items: center;
	gap: 0.5em;
}

#section-title::before {
	content: '';
	display: inline-block;
	margin-left: -0.2em;
	width: 1em;
	aspect-ratio: 1;

	border-radius: 0.5em;
	border: 0.2em solid var(--key-color);
}

.extra-content:not(#rules) {
	margin-bottom: 1em;
}
