:root {
	interpolate-size: allow-keywords;
}

html,
body {
	font-family:
		system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
	width: 100%;
	padding: 0;
	margin: 0;
	color-scheme: light;
}

#main-content-link {
	position: absolute;
	top: 0;
	left: 0;
	padding: 1em;
	background: white;
	opacity: 0;

	&:focus-visible {
		display: block;
		z-index: 1000;
		opacity: 1;
	}
}

main {
	margin: 0 calc(100% / 4);
	scroll-margin-top: var(--topbar-height);
	margin-bottom: max(var(--navigation-mobile-height), var(--topbar-height));
	padding-left: 1em;
	padding-right: 1em;
	@media screen and (max-width: 650px) {
		margin-left: 0;
		margin-right: 0;
	}
}

h1, h2, h3, h4, h5, h6 {
	text-wrap: balance;
}

.container {
	min-width: fit-content;
	border: var(--container-border);
	border-radius: var(--container-rounding);
	padding: 1.5rem 1.25rem;
	margin: 2rem auto 0; /* order of margins is important */
	margin-top: 2rem;
	position: relative;

	h1, h2, h3, h4, h5, h6 {
		margin-top: 0;
	}

	@media screen and (max-width: 650px) {
		border: unset;
		padding: 0;
		padding-top: 0.5rem;
		margin-top: 0;
	}
}

.searchbar-filter {
	display: none;
}

.button-list {
	display: flex;
	gap: var(--button-gap);
	justify-content: end;

	@media screen and (max-width: 650px) {
		justify-content: space-evenly;

		> * {
			flex: 1;
		}
	}
}

button, .button {
	border-width: 0;
	font-size: inherit;

	color: var(--component-text-color);
	background: var(--component-background);
	cursor: pointer;
	padding-block: var(--button-padding);
	padding-inline: calc(2 * var(--button-padding));
	text-decoration: none;
	border-radius: 0.5rem;
	text-align: center;

	&:hover, &:focus-visible {
		background: color-mix(
			in oklab,
			color-mix(in oklab, var(--component-background) 100%, blue 5%),
			black 10%
		);
	}

	&:active {
		background: color-mix(
			in oklab,
			color-mix(in oklab, var(--component-background) 100%, blue 10%),
			black 20%
		);
	}
}

input, select {
	accent-color: var(--kit-green);
	font-size: inherit;

	border: var(--input-border);
	border-radius: var(--input-rounding);
	padding-block: var(--button-padding);
	padding-inline: calc(2 * var(--button-padding));
}

hr {
	border-style: solid;
	color: grey;
	margin-top: calc(3 * var(--button-padding));
	margin-bottom: 0;
}

hr + table {
	margin-top: 0;
}

table {
	border-collapse: collapse;
	width: 100%;
	tr {
		&:hover, &:focus-within {
			background: #e9e9e9;
		}
		&:first-child td {
			border-top: none;
		}
		td {
			border: 1px solid lightgray;
			border-collapse: collapse;
			text-align: center;
			padding: 0 0.5rem;
			&:has(.x-button) {
				padding: 0;
			}
		}
		td:first-child {
			border-left: none;
		}
		td:last-child {
			border-right: none;
		}
	}

	.x-button {
		border-radius: 0;
		width: 100%;
		height: 100%;
	}
}

.comment {
	margin-top: 0.125%;
	line-height: 1em;
	font-size: 75%;
	color: gray;
}
