*, *::before, *::after {
	box-sizing: border-box;
}
:where(html, body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd) {
	margin: 0;
	padding: 0;
}
html {
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}
body {
	min-height: 100vh;
	font-synthesis-weight: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, picture, video, canvas, svg {
	display: block;
	max-width: 100%;
}
img, video {
	height: auto;
	max-width: 100%;
	display: block;
	line-height: 1em;
}
li {
	list-style:none;
}
input, textarea, select, button {
	font: inherit;
	color: inherit;
	letter-spacing: inherit;
}
button {
	background: transparent;
	border: none;
	padding: 0;
	cursor: pointer;
}
textarea {
	resize: vertical;
}
:where(ul[role="list"], ol[role="list"]) {
	list-style: none;
	margin: 0;
	padding: 0;
}
:where(:focus-visible) {
	outline: 2px solid CanvasText;
	outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation: none !important;
		transition: none !important;
		scroll-behavior: auto !important;
	}
}
.visually-hidden {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0 0 0 0);
	white-space: nowrap; border: 0;
}
.flow-root {
	display: flow-root;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
th, td {
	padding: 0;
	text-align: left;
}

/* =======================================

	cf

======================================= */
.cf:before,
.cf:after {
	content:"";
	display:table;
}
.cf:after {
	clear:both;
}
/* For IE 6/7 (trigger hasLayout) */
.cf {
	zoom:1;
}

