html {
	box-sizing: border-box;
}

*,
*:before,
*:after {
	box-sizing: inherit;
	font-family: var(--font-family);
}

body {
	background: var(--palette-bg);
	padding: 0;
	margin: 0;
	scroll-behavior: smooth;
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--font-family);
	font-weight: 400;
	line-height: 1.25em;
	margin-bottom: var(--scale-plus-2);
}

h1 {
	font-size: var(--scale-plus-5);
}

h2 {
	font-size: var(--scale-plus-3);
}

h3 {
	font-size: var(--scale-plus-2);
}

h4 {
	font-size: var(--scale-plus-1);
}

h5 {
	font-size: var(--scale-plus-1);
}

h6 {
	font-size: var(--scale-plus-1);
}

a {
	color: var(--color-primary);
	text-decoration: underline;
	transition: var(--duration-transition);
	font-size: inherit;
}

a:hover {
	text-decoration: none;
	color: var(--color-primary-300);
}

p {
	margin: 0 0 var(--scale-0) 0;
}

ul {
	margin: 0;
	padding: 0;
	padding-left: 1em;
}

ul li {
	padding-left: 0.5em;
}

p,
ul li {

	font-size: var(--scale-0);
	line-height: 1.5em;
}

span {
	font-size: inherit;
}

strong,
b {
	font-weight: var(--font-weight-bold);
	font-size: inherit;
}

em,
i {
	font-style: italic;
	font-size: inherit;
}

sub {
	font-size: var(--scale-decrease-2);
	position: relative;
	top: 0.5em;
}

sup {
	font-size: var(--scale-decrease-2);
	position: relative;
	top: 0;
}

blockquote {
	border-left: solid var(--size-border-width) var(--palette-border);
	font-style: italic;
	margin: 0 0 var(--size-element-margin) 0;
	padding: (var(--size-element-margin) / 4) 0 (var(--size-element-margin) / 4) var(--size-element-margin);
}

code {
	background: #000;
	font-family: var(--font-family-fixed);
	margin: 0 0.25em;
	padding: 0.25em 0.65em;
}


.align-center {
	text-align: center;
}

.align-left {
	text-align: left;
}

.align-right {
	text-align: right;
}




/* Form Styles */
form {
	margin: 0 0 var(--size-element-margin) 0;
}

fieldset {
	border: none;
	padding: 0;
	margin-bottom: var(--scale-plus-1);
}

fieldset legend {
	margin: var(--scale-plus-2) 0;
	border-bottom: 1px solid var(--color-neutrals-300);
	padding-bottom: var(--scale-0);
	font-size: var(--scale-plus-1);
	width: 100%;
}

label {
	display: block;
	margin-bottom: var(--scale-minus-2);
	transition: all 0.2s ease-out;
}

input,
textarea,
select {
	appearance: none;
	background: transparent;
	box-sizing: border-box;
	border-radius: var(--size-border-radius);
	border: solid var(--size-border-width) var(--color-neutrals-300);
	transition: border-color 0.2s ease;
	color: var(--palette-color-primary-500);
	display: block;
	outline: 0;
	padding: 0 0.5em;
	text-decoration: none;
	width: 100%;
	margin-bottom: 2em;
	font-family: var(--font-family);
	font-size: var(--scale-minus-1);
	height: var(--size-element-height);
}

:is(input, textarea, select):where(:active:not(:disabled), :focus) {
	border-color: var(--color-primary-500);
	outline: none;
}

:is(input, textarea, select):disabled {
	background: #eee;
	color: #000;
}


select {

	/* styling */
	background-color: white;

	display: inline-block;
	font: inherit;

	/* reset */

	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
}




select {
	background-image:
		linear-gradient(45deg, transparent 50%, gray 50%),
		linear-gradient(135deg, gray 50%, transparent 50%),
		linear-gradient(to right, #ccc, #ccc);
	background-position:
		calc(100% - 20px) calc(1em + 2px),
		calc(100% - 15px) calc(1em + 2px),
		calc(100% - 2.5em) 0.5em;
	background-size:
		5px 5px,
		5px 5px,
		1px 1.5em;
	background-repeat: no-repeat;
}

select:focus {
	background-image:
		linear-gradient(45deg, green 50%, transparent 50%),
		linear-gradient(135deg, transparent 50%, green 50%),
		linear-gradient(to right, #ccc, #ccc);
	background-position:
		calc(100% - 15px) 1em,
		calc(100% - 20px) 1em,
		calc(100% - 2.5em) 0.5em;
	background-size:
		5px 5px,
		5px 5px,
		1px 1.5em;
	background-repeat: no-repeat;
	border-color: green;
	outline: 0;
}

select.classic {
	background-image:
		linear-gradient(45deg, transparent 50%, blue 50%),
		linear-gradient(135deg, blue 50%, transparent 50%),
		linear-gradient(to right, skyblue, skyblue);
	background-position:
		calc(100% - 20px) calc(1em + 2px),
		calc(100% - 15px) calc(1em + 2px),
		100% 0;
	background-size:
		5px 5px,
		5px 5px,
		2.5em 2.75em;
	background-repeat: no-repeat;
}

select.classic:focus {
	background-image:
		linear-gradient(45deg, white 50%, transparent 50%),
		linear-gradient(135deg, transparent 50%, white 50%),
		linear-gradient(to right, gray, gray);
	background-position:
		calc(100% - 15px) 1em,
		calc(100% - 20px) 1em,
		100% 0;
	background-size:
		5px 5px,
		5px 5px,
		2.5em 2.5em;
	background-repeat: no-repeat;
	border-color: grey;
	outline: 0;
}




select.round {
	background-image:
		linear-gradient(45deg, transparent 50%, gray 50%),
		linear-gradient(135deg, gray 50%, transparent 50%),
		radial-gradient(#ddd 70%, transparent 72%);
	background-position:
		calc(100% - 20px) calc(1em + 2px),
		calc(100% - 15px) calc(1em + 2px),
		calc(100% - .5em) .5em;
	background-size:
		5px 5px,
		5px 5px,
		1.5em 1.5em;
	background-repeat: no-repeat;
}

select.round:focus {
	background-image:
		linear-gradient(45deg, white 50%, transparent 50%),
		linear-gradient(135deg, transparent 50%, white 50%),
		radial-gradient(gray 70%, transparent 72%);
	background-position:
		calc(100% - 15px) 1em,
		calc(100% - 20px) 1em,
		calc(100% - .5em) .5em;
	background-size:
		5px 5px,
		5px 5px,
		1.5em 1.5em;
	background-repeat: no-repeat;
	border-color: green;
	outline: 0;
}



select:-moz-focusring {
	color: transparent;
	text-shadow: 0 0 0 #000;
}


textarea {
	padding: 0.75em 1em;
	height: calc(var(--size-element-height) * 2);
}

progress {
	color: var(--color-primary-500);
	background: var(--color-primary-500);
}

progress::-moz-progress-bar {
	background: var(--color-primary-500);
}

progress progress::-webkit-progress-bar {
	background-color: var(--color-neutrals-100);
}

progress::-webkit-progress-value {
	background: var(--color-primary-500);
}

@supports (-webkit-appearance: none) or (-moz-appearance: none) {

	input[type='checkbox'],
	input[type='radio'] {
		--active: var(--color-primary-500);
		--active-inner: #fff;
		--focus: 2px rgba(39, 94, 254, .3);
		--border: #bbc1e1;
		--border-hover: #275efe;
		--background: #fff;
		--disabled: #f6f8ff;
		--disabled-inner: #e1e6f9;
		-webkit-appearance: none;
		-moz-appearance: none;
		height: 21px;
		outline: none;
		display: inline-block;
		vertical-align: top;
		position: relative;
		margin: 0;
		cursor: pointer;
		border: 1px solid var(--bc, var(--border));
		background: var(--b, var(--background));
		transition: background 0.3s, border-color 0.3s, box-shadow 0.2s;
	}

	input[type='checkbox']:after,
	input[type='radio']:after {
		content: '';
		display: block;
		left: 0;
		top: 0;
		position: absolute;
		transition: transform var(--d-t, 0.3s) var(--d-t-e, ease), opacity var(--d-o, 0.2s);
	}

	input[type='checkbox']:checked,
	input[type='radio']:checked {
		--b: var(--active);
		--bc: var(--active);
		--d-o: 0.3s;
		--d-t: 0.6s;
		--d-t-e: cubic-bezier(0.2, 0.85, 0.32, 1.2);
	}

	input[type='checkbox']:disabled,
	input[type='radio']:disabled {
		--b: var(--disabled);
		cursor: not-allowed;
		opacity: 0.9;
	}

	input[type='checkbox']:disabled:checked,
	input[type='radio']:disabled:checked {
		--b: var(--disabled-inner);
		--bc: var(--border);
	}

	input[type='checkbox']:disabled+label,
	input[type='radio']:disabled+label {
		cursor: not-allowed;
	}

	input[type='checkbox']:hover:not(:checked):not(:disabled),
	input[type='radio']:hover:not(:checked):not(:disabled) {
		--bc: var(--border-hover);
	}

	input[type='checkbox']:focus,
	input[type='radio']:focus {
		box-shadow: 0 0 0 var(--focus);
	}

	input[type='checkbox']:not(.switch),
	input[type='radio']:not(.switch) {
		width: 21px;
	}

	input[type='checkbox']:not(.switch):after,
	input[type='radio']:not(.switch):after {
		opacity: var(--o, 0);
	}

	input[type='checkbox']:not(.switch):checked,
	input[type='radio']:not(.switch):checked {
		--o: 1;
	}

	input[type='checkbox']+label,
	input[type='radio']+label {
		font-size: 14px;
		line-height: 21px;
		display: inline-block;
		vertical-align: top;
		cursor: pointer;
		margin-left: 4px;
	}

	input[type='checkbox']:not(.switch) {
		border-radius: 7px;
	}

	input[type='checkbox']:not(.switch):after {
		width: 5px;
		height: 9px;
		border: 2px solid var(--active-inner);
		border-top: 0;
		border-left: 0;
		left: 7px;
		top: 4px;
		transform: rotate(var(--r, 20deg));
	}

	input[type='checkbox']:not(.switch):checked {
		--r: 43deg;
	}

	input[type='checkbox'].switch {
		width: 38px;
		border-radius: 11px;
	}

	input[type='checkbox'].switch:after {
		left: 2px;
		top: 2px;
		border-radius: 50%;
		width: 15px;
		height: 15px;
		background: var(--ab, var(--border));
		transform: translateX(var(--x, 0));
	}

	input[type='checkbox'].switch:checked {
		--ab: var(--active-inner);
		--x: 17px;
	}

	input[type='checkbox'].switch:disabled:not(:checked):after {
		opacity: 0.6;
	}

	input[type='radio'] {
		border-radius: 50%;
	}

	input[type='radio']:after {
		width: 19px;
		height: 19px;
		border-radius: 50%;
		background: var(--active-inner);
		opacity: 0;
		transform: scale(var(--s, 0.7));
	}

	input[type='radio']:checked {
		--s: 0.5;
	}
}

// xlarge max
@media (max-width: 1599px) {}

// large max
@media (max-width: 1199px) {
	h1 {
		font-size: var(--scale-plus-4);
	}

	h2 {
		font-size: var(--scale-plus-2);
	}

	h3 {
		font-size: var(--scale-plus-1);
	}
}

// medium max
@media (max-width: 991px) {}

// small max
@media (max-width: 767px) {}

// xsmall max
@media (max-width: 575px) {}


a.button, span.button {
	border: 1px solid var(--color-primary);
	padding: 0.5em 2em;
	text-decoration: none;
	border-radius: 25px;
	color: #727272;
}

a.button:hover, span.button:hover {
	background: white;
}