*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	font-size: 100%;
	color-scheme: light dark;
}

body {
	margin: 0;
	font-family: var(--sp-type-family-sans);
	font-size: var(--sp-type-size-body);
	line-height: var(--sp-type-line-height-body);
	color: var(--sp-color-text-primary);
	background: var(--sp-color-layer-canvas);
}

body.sp-mobile-menu-open {
	overflow: hidden;
}

a {
	color: var(--sp-color-link-default);
	text-underline-offset: 0.15em;
	transition:
		color var(--sp-motion-duration-fast) var(--sp-motion-ease-standard),
		text-decoration-color var(--sp-motion-duration-fast) var(--sp-motion-ease-standard);
}

a:hover {
	color: var(--sp-color-link-hover);
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

svg {
	display: block;
}

.sp-icon {
	width: 1em;
	height: 1em;
	flex: 0 0 auto;
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

button,
input,
select,
textarea {
	font: inherit;
}

button {
	color: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin-top: 0;
	margin-bottom: var(--sp-space-1);
	font-family: var(--sp-type-family-heading);
	color: var(--sp-color-text-strong);
	line-height: var(--sp-type-line-height-tight);
}

h1 {
	font-family: var(--sp-type-family-display);
	font-size: var(--sp-type-size-heading-1);
}

.has-display-font-size {
	font-family: var(--sp-type-family-display);
}

h2 {
	font-size: var(--sp-type-size-heading-2);
}

h3 {
	font-size: var(--sp-type-size-heading-3);
}

h4 {
	font-size: var(--sp-type-size-heading-4);
}

h5 {
	font-size: var(--sp-type-size-heading-5);
}

h6 {
	font-size: var(--sp-type-size-heading-6);
}

p {
	margin-top: 0;
}

input:not([type]),
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="search"],
input[type="url"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
input[type="month"],
input[type="week"],
input[type="time"],
textarea,
select {
	width: 100%;
	border: 1px solid var(--sp-color-border-subtle);
	border-radius: var(--sp-layout-radius-sm);
	padding: var(--sp-space-1) var(--sp-space-2);
	background: var(--sp-color-layer-input);
	color: var(--sp-color-text-primary);
	transition:
		background-color var(--sp-motion-duration-fast) var(--sp-motion-ease-standard),
		border-color var(--sp-motion-duration-fast) var(--sp-motion-ease-standard),
		box-shadow var(--sp-motion-duration-fast) var(--sp-motion-ease-standard);
}

input::placeholder,
textarea::placeholder {
	color: var(--sp-color-text-muted);
	opacity: 0.74;
}

input[type="checkbox"],
input[type="radio"] {
	accent-color: var(--sp-color-action-primary-bg);
}

input:not([type="checkbox"]):not([type="radio"]):not([type="button"]):not([type="submit"]):not([type="reset"]):not(:disabled):not([readonly]):hover,
textarea:not(:disabled):not([readonly]):hover,
select:not(:disabled):hover {
	border-color: var(--sp-color-border-strong);
	background: var(--sp-color-layer-2);
}

input[readonly],
textarea[readonly] {
	background: var(--sp-color-layer-1);
}

input:where(:user-invalid, [aria-invalid="true"]),
select:where(:user-invalid, [aria-invalid="true"]),
textarea:where(:user-invalid, [aria-invalid="true"]) {
	border-color: var(--sp-color-border-danger);
}

input:focus,
select:focus,
textarea:focus,
button:focus-visible,
a:focus-visible {
	outline: var(--sp-state-focus-ring-width) solid var(--sp-state-focus-ring-color);
	outline-offset: var(--sp-state-focus-ring-offset);
}

input:focus,
select:focus,
textarea:focus {
	border-color: var(--sp-color-border-selected);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--sp-state-focus-ring-color) 24%, transparent);
}

input:where(:user-invalid, [aria-invalid="true"]):focus,
select:where(:user-invalid, [aria-invalid="true"]):focus,
textarea:where(:user-invalid, [aria-invalid="true"]):focus {
	border-color: var(--sp-color-border-danger);
	box-shadow: 0 0 0 3px var(--sp-color-status-danger-soft);
}

input[disabled],
textarea[disabled],
select[disabled],
button[disabled],
[aria-disabled="true"] {
	cursor: not-allowed;
	opacity: var(--sp-state-disabled-opacity);
}

input[disabled],
textarea[disabled],
select[disabled] {
	border-color: var(--sp-color-border-disabled);
	background: var(--sp-color-layer-disabled);
	color: var(--sp-color-text-disabled);
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		scroll-behavior: auto !important;
		transition-duration: 1ms !important;
		animation-duration: 1ms !important;
		animation-iteration-count: 1 !important;
	}
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
