/*----------------------------------------------------------------- */
/* HEADER
/*----------------------------------------------------------------- */

header
{
	height: var(--header__height);

	background: var(--color__white);
	box-shadow: 0 0 83px rgba(0, 0, 0, 0.08);
}

header .container
{
	padding-top: 32px;
}

header .row > .row
{
	flex: 1;
}

header ul
{
	margin: 0;
}

header a
{
	text-decoration: none;
}

header a:hover
{
	text-decoration: none;

	color: var(--color__red);
}

@media (max-width: 1230px)
{
	header
	{
		position: fixed;
		z-index: 999;
		top: 0;
		left: 0;

		width: 100%;
	}

	header .container
	{
		padding-top: 0;
	}
}

/* PRE HEADER
----------------------------------------- */
.pre-header
{
	font-size: 1.5rem;
	line-height: 32px;

	position: absolute;
	top: 0;
	left: 0;

	width: 100%;
	height: 33px;

	border-bottom: 1px solid var(--color__white-darker);
}

.pre-header__label-desktop
{
	position: relative;

	margin-right: 14px;
	padding: 0 8px 0 16px;

	color: var(--color__white);
	background: var(--color__red);
}

.pre-header__label-desktop:after
{
	position: absolute;
	top: 0;
	left: 100%;

	display: block;

	width: 0;
	height: 0;

	content: '';

	border-width: 32px 0 0 14px;
	border-style: solid;
	border-color: transparent transparent transparent var(--color__red);
}

.pre-header__label-mobile
{
	display: none;
}

.nav_pre-header-right
{
	padding-right: 15px;
}

.pre-header-menu a
{
	display: block;

	margin: 0 10px;

	color: var(--color__black);
}

.pre-header-menu .active-item a,
.pre-header-menu .active-item_archive-ancestor a,
.pre-header-menu a:hover
{
	color: var(--color__red);
}

@media (max-width: 1230px)
{
	.pre-header
	{
		line-height: normal;

		position: static;

		display: block;

		height: auto;
		padding: 20px 0;

		border: none;
		border-top: 1px solid var(--color__white-darker);
		background: var(--color__white-dark);
	}

	.pre-header__wrapper
	{
		display: block;

		padding: 0 20px 20px 20px;

		border-bottom: 1px solid var(--color__white-darker);
	}

	.pre-header__label-desktop
	{
		display: none;
	}

	.pre-header__label-mobile
	{
		display: block;
	}

	.pre-header-menu a
	{
		margin: 10px 20px 0 0;

		text-decoration: underline;
	}

	.pre-header-menu a:hover
	{
		text-decoration: underline;
	}

	.nav_pre-header-right
	{
		padding: 0 20px;
	}
}

/* LOGO
----------------------------------------- */
.logo
{
	font-size: 0;
}

.logo img
{
	width: auto;
	height: 36px;
}

@media (max-width: 1230px)
{
	.logo img
	{
		height: 24px;
	}
}

/* PRIMARY NAVIGATION
----------------------------------------- */
.main-menu,
.sub-menu
{
	margin: 0;
}

.main-menu > li
{
	position: relative;
}

.main-menu a
{
	font-size: 2rem;
	font-weight: var(--font-weight__bold);

	display: block;

	margin: 0 17px;

	color: var(--color__black);
}

.main-menu > li:first-child > a
{
	margin-left: 0;
}

.main-menu > li:last-child > a
{
	margin-right: 0;
}

.main-menu > li:hover > a,
.main-menu a:hover,
.main-menu .active-item > a
{
	color: var(--color__red);
}

.main-menu > .menu-item-has-children > a:after
{
	display: inline-block;

	width: 8px;
	height: 8px;
	margin-top: -5px;
	margin-left: 9px;

	content: '';
	-webkit-transform: rotate(-45deg);
	        transform: rotate(-45deg);
	vertical-align: middle;

	border-bottom: 2px solid var(--color__black-lighter);
	border-left: 2px solid var(--color__black-lighter);
}

.main-menu .active-item > a
{
	cursor: default;
	pointer-events: none;
}

.main-menu .sub-menu
{
	position: absolute;
	z-index: 999;
	top: 0;
	left: 100%;

	visibility: hidden;

	padding: 10px 0;

	transition: 0.3s linear;
	white-space: nowrap;

	opacity: 0;
	background: var(--color__white);
	box-shadow: 0 12px 44px rgba(0, 0, 0, 0.1);
}

.main-menu > li > .sub-menu
{
	top: 55px;
	left: -5px;
}

.main-menu > li > .sub-menu:before
{
	position: absolute;
	right: 0;
	bottom: 100%;
	left: 0;

	display: block;

	width: 100%;
	height: 31px;

	content: '';

	background: var(--color__white);
}

.main-menu li:hover > .sub-menu
{
	visibility: visible;

	opacity: 1;
}

.main-menu .sub-menu li
{
	position: relative;
}

.main-menu .sub-menu a
{
	font-size: 1.7rem;
	font-weight: var(--font-weight__default);

	position: relative;

	display: block;

	margin: 0;
	padding: 10px 50px 10px 30px;

	background: var(--color__white);
}

.main-menu .sub-menu a:before
{
	position: absolute;
	top: 0;
	left: -1px;

	display: block;

	width: 3px;
	height: 100%;

	content: '';
	transition: var(--transition-delay__default);

	background: transparent;
}

.main-menu .sub-menu a:hover:before
{
	background: var(--color__red);
}

.main-menu .sub-menu > li:hover > a
{
	color: var(--color__red);
}

.main-menu .sub-menu .menu-item-bold a
{
	font-weight: var(--font-weight__bold);
}

.main-menu .sub-menu .menu-item-border
{
	margin-bottom: 10px;
	padding-bottom: 10px;

	border-bottom: 1px solid var(--color__white-darker);
}

.sub-show
{
	display: none;
}

@media (max-width: 1230px)
{
	.nav-wrapper
	{
		position: absolute;
		z-index: 999;
		top: var(--header__height);
		right: 0;
		left: 0;

		display: none;
		overflow: auto;

		width: 100%;
		height: calc(100vh - var(--header__height));

		background: var(--color__white-dark);
	}

	.nav-wrapper::-webkit-scrollbar
	{
		width: 8px;
		height: 8px;

		-webkit-appearance: none;
	}

	.nav-wrapper::-webkit-scrollbar-thumb
	{
		border: 1px solid var(--color__black-lightest);
		border-radius: 10px;
		background-color: var(--color__white);
	}

	.nav_main
	{
		padding: 18px 0;

		border-top: 1px solid var(--color__white-darker);
		background: var(--color__white);
	}

	.main-menu
	{
		display: block;
	}

	.main-menu a
	{
		font-size: 1.8rem;

		display: block;

		margin: 0;
		padding: 8px 20px;

		background: none;
	}

	.main-menu > .menu-item-has-children > a:after
	{
		display: none;
	}

	.main-menu .sub-menu
	{
		position: relative;

		visibility: visible;

		margin-bottom: 10px;
		padding-top: 0;
		padding-bottom: 0;
		padding-left: 20px;

		transition: none;

		opacity: 1;
		border: none;
		background: none;
		box-shadow: none;
	}

	.main-menu > li > .sub-menu
	{
		top: auto;
		left: auto;
	}

	.main-menu > li > .sub-menu:before
	{
		z-index: 1;
		top: 8px;
		right: auto;
		bottom: auto;
		left: 20px;

		width: 1px;
		height: calc(100% - 8px - 8px);

		background: var(--color__white-darker);
	}

	.main-menu .sub-menu .menu-item-border
	{
		margin: 0;
		padding: 0;

		border: none;
	}

	.main-menu > li.menu-item-has-children > .sub-show
	{
		top: 0;
		right: 0;
		bottom: auto;

		display: block;

		width: 100%;
		height: 40px;
	}

	.main-menu > li.menu-item-has-children > .icon-arrow:after
	{
		right: 27px;
		left: auto;
	}

	.main-menu > li > .sub-menu
	{
		display: none;

		border: none;
	}

	.main-menu .sub-menu a
	{
		font-size: 1.6rem;

		padding: 8px 20px;

		text-decoration: underline;
	}

	.main-menu .sub-menu a:before
	{
		display: none;
	}
}

/* Rewrites inline styles added via JavaScript function */
@media (min-width: 1231px)
{
	.nav-wrapper,
	.main-menu .sub-menu
	{
		display: block !important;

		height: auto !important;
	}
}

/* TOOLS
----------------------------------------- */
.tools__search
{
	position: relative;

	display: inline-block;

	width: 50px;
	height: 50px;

	border-radius: 5px;
	background: var(--color__white-dark);
}

.tools__search.active
{
	border-radius: 5px 5px 0 0;
}

.tools__search:after
{
	position: absolute;
	top: 100%;

	display: block;

	width: 100%;
	height: 16px;

	content: '';
	transition: var(--transition-delay__default);

	background: transparent;
}

.tools__search.active:after
{
	background: var(--color__white-dark);
}

.tools__search:hover
{
	text-decoration: none;
}

.tools__search .icon
{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;

	display: block;

	margin: auto;

	transition: var(--transition-delay__default);

	color: var(--color__black);
}

.tools__search:hover .icon
{
	color: var(--color__red);
}

.tools__search .icon-search
{
	display: block;

	width: 40px;
	height: 40px;
}

.tools__search.active .icon-search
{
	opacity: 0;
}

.tools__search .icon-close
{
	display: block;

	width: 16px;
	height: 16px;

	opacity: 0;
}

.tools__search.active .icon-close
{
	opacity: 1;
}

a.tools__apply
{
	margin-left: 20px;
}

.tools__nav-btn
{
	display: none;
}

@media (max-width: 1230px)
{
	.tools__search
	{
		width: 40px;
		height: 40px;
	}

	.tools__search:after
	{
		height: 5px;
	}

	.tools__search .icon-search
	{
		width: 28px;
		height: 28px;
	}

	a.tools__apply
	{
		font-size: 1.7rem;

		margin-left: 8px;
		padding: 8px 25px;

		background: var(--color__green);
	}

	a.tools__apply:hover
	{
		background: var(--color__green-dark);
	}

	.tools__nav-btn
	{
		font-size: 1.6rem;

		position: relative;

		display: block;

		height: 40px;
		margin-left: 8px;
		padding: 8px 15px;

		color: var(--color__white);
		border-radius: 5px;
		background: var(--color__red);
	}

	.tools__nav-btn:hover
	{
		color: var(--color__white);
		background: var(--color__red-dark);
	}

	.tools__nav-btn span,
	.tools__nav-btn span:before,
	.tools__nav-btn span:after
	{
		position: absolute;

		display: block;

		width: 19px;
		height: 1px;

		transition: var(--transition-delay__default);

		background: var(--color__white);
	}

	.tools__nav-btn span
	{
		position: relative;

		display: inline-block;

		margin: -3px 8px 0 0;

		vertical-align: middle;
	}

	.tools__nav-btn span:before,
	.tools__nav-btn span:after
	{
		left: 0;

		content: '';
	}

	.tools__nav-btn span:before
	{
		top: -6px;
	}

	.tools__nav-btn span:after
	{
		bottom: -6px;
	}

	.tools__nav-btn.active span
	{
		background: transparent;
	}

	.tools__nav-btn.active span:before
	{
		top: 0;

		transform: rotate(-45deg);
	}

	.tools__nav-btn.active span:after
	{
		bottom: 0;

		transform: rotate(45deg);
	}
}

@media (max-width: 420px)
{
	a.tools__apply
	{
		display: none;
	}
}
