/*
 ************************************************************
 *
 * BASE
 *
 ************************************************************
 *
 * ----------------------------------------------------------
 *
 * RESET AND BASICS
 *
 * ----------------------------------------------------------
 *
 * - RESET
 */

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
main,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video
{
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font-size: 100%;
	font: inherit;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section
{
	display: block;
}

iframe,
object,
embed
{
	max-width: 100%;
}

ol, ul
{
	list-style: none;
}

table
{
	border-collapse: collapse;
	border-spacing: 0;
}

*
{
	box-sizing: border-box;
}

/*
 * - STYLES
 */

html.responsive,
.responsive body
{
	overflow-x: hidden;
}

.responsive body
{
	overflow-x: initial;
}

html, body
{
	height: 100%;
}

html
{
	--font-body: 'Aptos', Arial, sans-serif;
	--font-feat: 'Kobenhavn', Arial, sans-serif;
	--color-white: #ffffff;
	--color-black: #000000;
	--color-gray-1: #666666;
	--color-gray-2: #999999;
	--color-lightgray-1: #f5f5f5;
	--color-lightgray-2: #dddddd;
	--color-1: #00b4ff;
	--color-1-light: #7fd9ff;
}

body
{
	font-family: var(--font-body);
	font-size: 100%;
	line-height: 1.6em;
	color: var(--color-black);
}

.wrapper
{
	font-size: 16px;
}

/*
 * ----------------------------------------------------------
 *
 * TYPOGRAPHY
 *
 * ----------------------------------------------------------
 *
 * - HEADING
 */

h1,
h2,
h3,
h4,
h5,
h6
{
	font-family: var(--font-feat);
	font-weight: 400;
	line-height: 1.2em;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a
{
	font-weight: inherit;
	text-decoration: none;
	color: inherit;
}

h1 strong,
h2 strong,
h3 strong,
h4 strong,
h5 strong,
h6 strong
{
	color: inherit;
}

h1:first-letter
{
	text-transform: capitalize;
}

h1
{
	font-size: 40px;
}

.home h1
{
	font-size: 36px;
}

h2
{
	font-size: 30px;
}

h3
{
	font-size: 24px;
}

h4
{
	font-size: 20px;
}

h5
{
	font-size: 18px;
}

h6
{
	font-size: 16px;
}

@media only screen and (max-width: 1279px)
{
	.responsive h1
	{
		font-size: 32px;
	}
	.responsive h2
	{
		font-size: 28px;
	}
	.responsive h3
	{
		font-size: 20px;
	}
	.responsive h4
	{
		font-size: 18px;
	}
	.responsive h5
	{
		font-size: 16px;
	}
	.responsive h6
	{
		font-size: 15px;
	}
	
}

/*
 * - TYPO
 */

p,
a,
span,
main,
header,
footer
{
	font-family: var(--font-body);
	font-weight: 300;
}

main p,
main ul,
main ol,
main table
{
	margin: 24px 0;
}

main figure,
main blockquote
{
	margin: 40px 0;
}

main p:first-child,
main ul:first-child,
main ol:first-child,
main table:first-child,
main figure:first-child,
main blockquote:first-child
{
	margin-top: 0;
}

main p:last-child,
main ul:last-child,
main ol:last-child,
main table:last-child,
main figure:last-child,
main blockquote:last-child
{
	margin-bottom: 0;
}

b,
b a,
strong,
strong a
{
	font-weight: 500;
}

p + h1,
p + h2,
p + h3,
p + h4,
p + h5,
p + h6
{
	margin-top: 24px;
}

em
{
	font-style: italic;
}

small
{
	font-size: 80%;
}

sup
{
	vertical-align: super;
	font-size: smaller;
}

sub
{
	vertical-align: sub;
	font-size: smaller;
}

mark
{
	background-color: transparent;
	color: inherit;
}

hr
{
	height: 0;
	margin: 32px 0;
	border: solid var(--color-lightgray-2);
	border-width: 1px 0 0;
}

blockquote
{
	border-left-style: solid;
	border-left-width: 6px;
	border-left-color: var(--color-1);
	background-color: var(--color-lightgray-1);
}

/*
 * - LINKS
 */

a,
a:focus
{
	text-decoration: none;
	outline: 0;
	max-width: 100%;
	max-width: none\9;
	color: var(--color-black);
}

#top a:where(:not(.wp-element-button))
{
	text-decoration: none;
}

a:hover
{
	outline: 0;
	text-decoration: underline;
	color: var(--color-1);
}

p a,
p a:visited
{
	line-height: inherit;
}

/*
 * - LISTS
 */

ul ul,
ul ol,
ol ol,
ol ul
{
	margin: 4px 0 4px 32px;
}

ul ul li,
ul ol li,
ol ol li,
ol ul li
{
	margin-bottom: 12px;
}

ul
{
	list-style: none outside;	
}

ul.square
{
	list-style: square outside;
}

ul.circle
{
	list-style: circle outside;
}

ul.disc
{
	list-style: disc outside;
}

ul li::marker
{
	color: var(--color-1);
}

ol
{
	position: relative;
	list-style: none;
	counter-reset: li;
	padding-left: 0;
}

ol li
{
	counter-increment: li;
	display: flex;
	flex-direction: row;
	padding: 4px 0 4px 32px;
}

ol li::before
{
	content: counter(li, decimal-leading-zero);
	position: absolute;
	left: 0px;
	width: 32px;
	font-weight: 700;
	color: var(--color-1);
}

/*
 * - ICON
 */

.fas,
.fas::before
{
	color: var(--color-1);
}

/*
 * ----------------------------------------------------------
 *
 * FORM
 *
 * ----------------------------------------------------------
 *
 * - INPUT
 */

::-webkit-input-placeholder
{
	opacity: 1;
	color: var(--color-gray-1);
}
::-moz-placeholder
{
	opacity: 1;
	color: var(--color-gray-1);
}
:-ms-input-placeholder
{
	opacity: 1;
	color: var(--color-gray-1);
}
:-moz-placeholder
{
	opacity: 1;
	color: var(--color-gray-1);
}

input[type="text"],
input[type="input"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="url"],
input[type="tel"],
input[type="search"],
textarea,
select,
.ui-selectmenu-button
{
	font-family: var(--font-body);
	font-size: 16px;
	display: block;
	width: 100%;
	margin: 0;
	padding: 12px;
	line-height: 1.4em;
	outline: none;
	border-width: 2px;
	border-radius: 4px;
	border-style: solid;
	border-color: var(--color-lightgray-2);
	background-color: var(--color-white);
	color: var(--color-1);
}

textarea
{
	width:100%;
	min-height: 60px;
}

select,
.ui-selectmenu-button
{
	width: 100%;
}

/*
 * - LEGEND
 */

legend,
.legend
{
	display: block;
	font-weight: 700;
	font-size: 15px;
	color: var(--color-1);
}

.legend
{
	font-size: 18px;
}

/*
 * - LABEL
 */

label,
label a
{
	font-weight: 400;
	font-size: 14px;
}

label input
{
	margin-right: 8px;
}

/*
 * - CHECKBOX
 */

input[type="checkbox"]
{
	-webkit-appearance: none;
	-moz-appearance: none;
	-o-appearance: none;
	appearance: none;
	outline: none;
	content: none;
	margin: 0 8px 0 0;
	cursor: pointer;
}

input[type="checkbox"]::before
{
	content: "✓";
	font-size: 16px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 18px;
	height: 18px;
	padding: 2px;
	border: 1px solid var(--color-lightgray-2);
	background-color: var(--color-white);
	color: transparent;
}

input[type="checkbox"]:checked::before
{
	color: var(--color-1);
}

/*
 * - RADIO
 */

label.radio
{
	display: block;
	user-select: none;
	text-align: left;
	cursor: pointer;
}

label.radio input
{
	display: none;
}

label.radio input + span
{
	display: flex;
	align-items: center;
	position: relative;
	height: 24px;
	padding-left: 32px;
}

label.radio input + span::before,
label.radio input + span::after
{
	content: '';
	position: absolute;
	display: block;
	border-width: 1px;
	border-style: solid;
	border-radius: 50%;
}

label.radio input + span::before
{
	top: 0;
	left: 0;
	width: 18px;
	height: 18px;
	padding: 2px;
	margin-right: 8px;
	background-color: var(--color-white);
	border-color: var(--color-lightgray-2);
}

label.radio input + span::after
{
	top: 8px;
	left: 8px;
	width: 8px;
	height: 8px;
	border: none;
	background-color: var(--color-1);
	opacity: 0;
	transform: scale(0, 0);
	transition: all .2s cubic-bezier(0.64, 0.57, 0.67, 1.53);
}

label.radio input:checked + span:after
{
	opacity: 1;
	transform: scale(1, 1);
}

/*
 * - ERROR
 */

form .error,
form .error + span::before
{
    border: 1px solid var(--color-1) !important;
}

/*
 * ----------------------------------------------------------
 *
 * BUTTONS
 *
 * ----------------------------------------------------------
 *
 * - DEFAULT
 */

button,
.button
{
	font-family: var(--font-feat);
	font-weight: 400;
	font-size: 14px;
	text-align: center;
	display: inline-block;
	margin: 0;
	padding: 0 24px;
	min-width: auto;
	cursor: pointer;
	line-height: 38px;
	border-radius: 6px;
	border-width: 1px;
	border-style: solid;
	text-transform: uppercase;
	-webkit-box-shadow: none;
	   -moz-box-shadow: none;
	        box-shadow: none;
}

@media only screen and (max-width: 480px)
{
	.responsive button,
	.responsive .button
	{
		width: 100%;
	}
}

span.button
{
	display: inline-block;
}

.button.fas::before,
.button.fas::after
{
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
}

/*
 * - SIZE
 */

.button.size-small
{
	padding: 0 24px;
	line-height: 38px;
	font-size: 14px;
}

.button.size-medium
{
	padding: 0 32px;
	line-height: 46px;
	font-size: 16px;
}

.button.size-large
{
	padding: 0 40px;
	line-height: 54px;
	font-size: 18px;
}

/*
 * - COLOR
 */

.button,
.button:focus
{
	background-color: transparent;
	border-color: var(--color-1);
	color: var(--color-1);
}

.button:hover
{
	background-color: var(--color-1);
	border-color: var(--color-1);
	color: var(--color-white);
}

.color-white,
.color-white:focus
{
	background-color: transparent;
	border-color: var(--color-white);
	color: var(--color-white);
}

.color-white:hover
{
	background-color: var(--color-white);
	border-color: var(--color-white);
	color: var(--color-1);
}

.color-1,
.color-1:focus
{
	background-color: var(--color-1);
	border-color: var(--color-1);
	color: var(--color-white);
}

.color-1:hover
{
	background-color: var(--color-1-light);
	border-color: var(--color-1-light);
	color: var(--color-white);
}

/*
 * ----------------------------------------------------------
 *
 * ELEMENTS
 *
 * ----------------------------------------------------------
 *
 * - IMAGES
 */

img, a img
{
	display: block;
	max-width: 100%;
	margin: 0;
	padding: 0;
	height: auto;
	border: none;
}

/*
 * - TABLES
 */

th,
td
{
	padding: 12px;
	border-style: solid;
	border-width: 1px;
	border-color: var(--color-lightgray-2);
	border-left: none;
	border-right: none;
	text-align: left;
}

table
{
	width: 100%;
	padding: 0;
	margin: 0;
}

th
{
	font-weight: bold;
}

@media only screen and (max-width: 767px)
{
	.table
	{
		width: 100% !important;
		overflow-x: scroll; 
	}
	.table table
	{
		white-space: nowrap;
	}
}

/*
 * - CODE
 */

pre, code
{
	font-family: 'Courier New', Courier, monospace;
}

pre
{
	clear: both;
	width: 100%;
	padding: 2em;
	margin: 32px 0;
	line-height: 2em;
	overflow: auto;
	position: relative;
	left: 0;
	border-style: solid;
	border-width: 1px;
	background-image: linear-gradient(rgba(0, 0, 0, .05) 50%, transparent 50%, transparent);
	background-size: 100% 4em;
	transition: all ease-in-out 0.5s;
	text-transform: none;
	font-size: 12px;
}

/*
 * - MISC
 */

.clearboth
{
	clear: both;
}

.floatleft
{
	float:left;
}

.floatright
{
	float:right;
}

.screen-reader-only
{
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	border: 0;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	overflow: hidden;
}

.not-found
{
	font-size: 16px;
}

.hidden
{
	display: none !important;
}

@media only screen and (max-width: 767px)
{
	.responsive #top .mobile-hide
	{
		display: none !important;
	}
}

@media only screen and (min-width: 768px) and (max-width: 1279px)
{
	.responsive #top .tablet-hide
	{
		display: none !important;
	}
}

@media only screen and (min-width: 1280px)
{
	.responsive #top .desktop-hide
	{
		display: none !important;
	}
}