/*
 ************************************************************
 *
 * 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%;
}

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

*
{
	box-sizing: border-box;
}

a,
dl,
dt,
dd,
path,
span,
strong,
input,
select,
label,
textarea,
button,
.button,
.colorbox,
.fas,
.fas:before,
.fas:after,
.far,
.far:before,
.far:after,
.item,
.title,
.title::after,
.title .tag,
.title h2
{
	transition-property: opacity, fill, color, border-color, background-color;
	transition-duration: .3s;
	transition-timing-function: ease;
}

/*
 * - STYLES
 */

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

.responsive body
{
	overflow-x: initial;
}

html, body
{
	height: 100%;
}

html
{
	--font-body: 'Proxima Nova', Arial, sans-serif;
	--font-feat: 'Proxima Nova', Arial, sans-serif;
	--color-white: #ffffff;
	--color-black: #000000;
	--color-cvi-1: #342b60;
	--color-cvi-2: #62bb46;
	--color-cvi-2-light: #eff8ec;
	--color-cvi-lightgray-1: #f6f6f8;
	--color-cvi-lightgray-2: #d8d9e2;
	--color-cvi-gray: #9396b0;
	--color-cvi-gray-2: #c2c4d6;
}

body
{
	font-size: 100%;
	line-height: 1.4em;
	color: var(--color-cvi-1);
}

body figure
{
	margin: 0;
}

.wrapper
{
	font-size: 16px;
}

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

h1,
h2,
h3,
h4,
h5,
h6,
.title h1,
.title h2,
.title h3,
.title h4,
.title h5,
.title h6,
.title span
{
	font-family: var(--font-body);
	font-weight: 700;
	line-height: 1.1em;
	color: var(--color-cvi-1);
}

.heading h1,
.heading h2
{
	text-transform: uppercase;
	font-weight: 800;
}

body:not(.home) .heading h1,
.heading h2
{
	color: var(--color-cvi-2);
}

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;
}

h2
{
	font-size: 30px;
}

h3
{
	font-size: 24px;
}

h4
{
	font-size: 20px;
}

h5
{
	font-size: 18px;
}

h6
{
	font-size: 16px;
}

.heading h1,
.heading h2
{
	font-size: 40px;
}

@media only screen and (max-width: 767px)
{
	.responsive h1
	{
		font-size: 36px;
	}
	.responsive h2
	{
		font-size: 30px;
	}
	.responsive h3
	{
		font-size: 24px;
	}
	.responsive h4
	{
		font-size: 20px;
	}
	.responsive h5
	{
		font-size: 18px;
	}
	.responsive h6
	{
		font-size: 16px;
	}
	.responsive .heading h1,
	.responsive .heading h2
	{
		font-size: 36px;
	}
}

@media only screen and (max-width: 480px)
{
	.responsive h1
	{
		font-size: 36px;
	}
	.responsive h2
	{
		font-size: 27px;
	}
	.responsive h3
	{
		font-size: 21px;
	}
	.responsive h4
	{
		font-size: 18px;
	}
	.responsive h5
	{
		font-size: 16px;
	}
	.responsive h6
	{
		font-size: 15px;
	}
	.responsive .heading h1,
	.responsive .heading h2
	{
		font-size: 27px;
	}
}

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

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

/*
 * - TYPO
 */

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

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

main p:first-child,
main ul:first-child,
main ol:first-child,
main table: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 blockquote:last-child
{
	margin-bottom: 0;
}

main p > a.button
{
	margin: 0;
}

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

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

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: 20px 0;
	border: solid var(--color-cvi-lightgray-2);
	border-width: 1px 0 0;
}

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

@media only screen and (max-width: 767px)
{
	.responsive blockquote
	{
		padding: 16px;
	}
}

@media only screen and (min-width: 768px)
{
	.responsive blockquote
	{
		padding: 16px 24px;
	}
}

/*
 * - LINKS
 */

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

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

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

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

/*
 * - LISTS
 */

ul
{
	list-style: none outside;	
}

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

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

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

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-cvi-2);
}

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;
}

/*
 * - ICON
 */

.fas,
.far
{
	color: var(--color-cvi-2);
}

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

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

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: 14px;
	display: block;
	width: 100%;
	margin: 0;
	padding: 16px 12px;
	line-height: 1.4em;
	outline: none;
	border-width: 1px;
	border-radius: 0;
	border-style: solid;
	border-color: var(--color-cvi-lightgray-2);
	background-color: var(--color-white);
	color: var(--color-cvi-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-cvi-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-cvi-lightgray-2);
	background-color: var(--color-white);
	color: transparent;
}

input[type="checkbox"]:checked::before
{
	color: var(--color-cvi-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-cvi-lightgray-2);
}

label.radio input + span::after
{
	top: 8px;
	left: 8px;
	width: 8px;
	height: 8px;
	border: none;
	background-color: var(--color-cvi-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-cvi-2) !important;
}

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

button,
.button
{
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 16px;
	text-align: center;
	display: inline-block;
	margin: 0;
	padding: 0 24px;
	min-width: auto;
	cursor: pointer;
	line-height: 38px;
	border-radius: 20px;
	border-width: 1px;
	border-style: solid;
	text-transform: none;
	-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.far::before
{
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
}

/*
 * - SIZE
 */

.button.size-small
{
	padding: 0 24px;
	line-height: 38px;
	border-radius: 20px;
	font-size: 15px;
}

.button.size-medium
{
	padding: 0 32px;
	line-height: 48px;
	border-radius: 25px;
	font-size: 17px;
}

.button.size-large
{
	padding: 0 40px;
	line-height: 58px;
	border-radius: 30px;
	font-size: 18px;
}

/*
 * - COLOR
 */

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

button:hover,
.button:hover
{
	background-color: var(--color-cvi-2);
	border-color: var(--color-cvi-2);
	color: var(--color-white);
}

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

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

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

.button.color-blue:hover
{
	background-color: var(--color-cvi-2);
	border-color: var(--color-cvi-2);
	color: var(--color-white);
}

.button.color-red,
.button.color-red:focus
{
	background-color: var(--color-cvi-2);
	border-color: var(--color-cvi-2);
	color: var(--color-white);
}

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

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

.button.color-lightgray:hover
{
	background-color: var(--color-cvi-1);
	border-color: var(--color-cvi-1);
	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-cvi-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;
	}
}

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

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

/*
 * ----------------------------------------------------------
 *
 * WORDPRESS GENERATED CLASSES
 *
 * ----------------------------------------------------------
 *
 * - IMAGE
 */

figure
{
	width: auto !important;
}

@media only screen and (max-width: 479px)
{
	.responsive figure img
	{
		width: 100%;
		height: auto;
	}
}

/*
 * - ALIGN
 */

.alignleft,
.alignright,
.aligncenter,
.alignleft img,
.alignright img,
.aligncenter img
{
	display: block;
	position: relative;
}

body .alignleft
{
	float: left;
	margin: 0px 32px 0px 0;
}

body .alignright
{
	float: right;
	margin: 0px 0px 0px 32px;
}

body .aligncenter
{
	clear: both;
	margin: 24px auto;
}

@media only screen and (max-width: 989px)
{
	.responsive body .alignleft,
	.responsive body .alignright,
	.responsive body .aligncenter
	{
		clear: both;
		float: none;
		margin: 24px 0;
		margin-right: auto;
	}
}

@media only screen and (min-width: 990px)
{
	.responsive body .alignleft
	{
		margin: 0px 32px 32px 0;
	}
	.responsive body .alignright
	{
		margin: 0px 0px 32px 32px;
	}
	.responsive body .aligncenter
	{
		margin: 32px auto;
	}
}

/*
 * - CAPTION
 */

.wp-caption p,
.wp-caption figcaption
{
	margin-top: 16px;
	color: var(--color-cvi-gray);
}

@media only screen and (max-width: 767px)
{
	.responsive .wp-caption p,
	.responsive .wp-caption figcaption
	{
		font-size: 15px;
	}
}

@media only screen and (min-width: 768px)
{
	.responsive .wp-caption p,
	.responsive .wp-caption figcaption
	{
		font-size: 16px;
	}
}

/*
 * ----------------------------------------------------------
 *
 * WORDPRESS GALLERY
 *
 * ----------------------------------------------------------
 *
 * - COLUMNS
 */

.gallery-columns-1
{
	grid-template-columns: repeat(1, 1fr);
}

.gallery-columns-2
{
	grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3
{
	grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4
{
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5
{
	grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6
{
	grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7
{
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8
{
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9
{
	grid-template-columns: repeat(9, 1fr);
}

/*
 * - GRID
 */

.gallery
{
	display: grid;
	margin: 32px 0;
	grid-template-columns: repeat(4, 1fr);
}

.gallery + .button
{
	margin-top: -16px;
}

@media only screen and (max-width: 767px)
{
	.responsive .gallery
	{
		grid-gap: 8px;
	}
}

@media only screen and (min-width: 768px)
{
	.responsive .gallery
	{
		grid-gap: 12px;
	}
}

/*
 * - ITEM
 */

.gallery .gallery-item,
.gallery .gallery-icon
{
	margin: 0;
	padding: 0;
}

.gallery .gallery-item
{
	width: auto;
	height: auto;
}

.gallery .gallery-item.first
{
	grid-column: span 2;
	grid-row: span 2;
}

.gallery br,
.gallery .gallery-item:nth-child(n+6)
{
	display: none !important;
}

/*
 * - ELEMENT
 */

.gallery a,
.gallery a img
{
	display: block;
	position: relative;
	max-width: 100%;
	border: none;
}

.gallery p,
.gallery-caption
{
	display: none;
}

.gallery:after
{
	content: '';
	display: table;
	clear: both;
}

.gallery figure img
{
	display: block;
	max-width: 100%;
	width: 100%;
	height: auto;
	margin: 0;
}