/* =========================================================
	MENU — PODSTAWOWY KONTENER / HEADER / LOGO
========================================================= */

.menu-container {
	position: fixed;
	top: 0;
	z-index: 9999999;
	/* background-color: var(--menu-bg); */
	transition: all 0.2s linear;
}

.transparent-menu .menu-container,
.single-realizacje .menu-container {
	/* background-color: rgba(0, 0, 0, 0.7); */
	transition: all 0.3s linear;
}

.menu-container.stickymenu {
	position: fixed;
	z-index: 999999;
	background-color: rgba(255, 255, 255, 0.8);
	transition: all 0.3s linear;
}

header .logo a {
	width: 100%;
	display: inline-block;
}

header .sticky .logo img {
	width: 15rem;
	margin: 1rem 0;
}

@media (min-width: 992px) {
	header .logo img {
		width: 16rem;
		margin: 0;
		height: auto;
		transition: all 0.3s linear;
		padding: 0.7rem 1.5rem 0 1.5rem;
		z-index: 2;
		position: relative;
	}
}

@media (max-width: 991px) {
	header .logo img {
		width: 100%;
		max-width: 9rem;
		height: auto;
		transition: all 0.3s linear;
	}
	
	header.header .container {
		padding: 0;
		margin: 0;
		max-width: 100%;
	}
}


/* =========================================================
	MENU DESKTOP
========================================================= */

header .nav-desktop ul.menu {
	display: flex;
	flex-wrap: wrap;
	position: relative;
	width: auto;
	margin: 0;
	padding: 0;
	align-self: center !important;
}

header nav .menu li,
header nav ul.menu > li {
	display: inline-block;
	list-style: none;
	position: relative;
}



header nav .menu a {
	display: inline-block;
	color: var(--color-menu);
	font-family: var(--menu-font);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing:0.1rem;
}

header nav .menu > li > a {
	box-sizing: border-box;
	width: 100%;
	text-align: center;
	transition: all 0.3s linear;
	
}

header nav .menu > li > a:hover,
header nav .menu a:hover,
header nav .menu .current_page_item > a,
header nav ul.menu li > a:hover {
	color: var(--color-menu-hover);
	/* border-bottom:2px solid var(--color-menu-hover); */
	/* border-radius:0.2rem; */
	transition: all 0.3s linear;
}

header .stickymenu nav .menu > li > a {
	color: var(--color-sticky-menu);
}

header .stickymenu nav .menu > li > a:hover {
	color: var(--color-sticky-menu-hover);
}

header nav.menu-toggle-on ul.menu li > a {
	color: var(--color-toggle-menu);
}

header nav.menu-toggle-on ul.menu li > a:hover {
	color: var(--color-toggle-menu-hover);
}

.menu ul {
	margin: 0;
}

@media (min-width: 992px) {
	header nav ul.menu {
		justify-content: space-between;
	}
	
	header nav ul.menu li {
		margin: 0 0.5rem;
	}
	
	header nav .menu > li > a {
		margin: 0;
		padding: 0.6rem 0.5rem;
		font-size:1rem;
		border-bottom: 2px solid rgba(0,0,0,0);
		/* border-radius:0.2rem; */
	}
	
	header nav .menu > li.menu-item-has-children > a{
		padding-right:2rem;
		
	}
	
	header nav .menu > li.menu-item-has-children > a:after {
		content: "\f0d7";
		font-family: FontAwesome;
		color: var(--color-menu);
		right: -0.5rem;
		top: 47%;
		transform: translate(-50%, -50%);
		width: 1.3rem;
		height: auto;
		position: absolute;
		font-size: 0.9rem;
	}
	
	
	body.home header .menu-container:not(.stickymenu) nav .menu > li > a, body.home header .menu-container:not(.stickymenu) nav .menu > li.menu-item-has-children > a:after{
		color: #fff;
	}
	
	
	
}


/* =========================================================
	MENU DESKTOP — SUBMENU
========================================================= */

header nav.nav-desktop .menu > li > .sub-menu {
	list-style-type: none;
	position: absolute;
	background-color: rgba(255,255,255,0.8);
	padding: 0;
	margin: 0;
	visibility: hidden;
	line-height: 1;
	width: auto;
	z-index: 9999;
	transition: all 0.4s ease;
	border-radius: 0.2rem;
}

header nav.nav-desktop .menu > li > .sub-menu > li > .sub-menu {
	list-style-type: none;
	position: absolute;
	left: 100%;
	top: 0;
	padding: 0.5rem 0;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	line-height: 1;
	background-color: white;
	width: auto;
	z-index: 9999999;
	transition: all 0.4s ease;
}

header nav.nav-desktop li:hover > .sub-menu,
header nav.nav-desktop li > .sub-menu > li:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transition: all 0.4s ease;
}

header nav.nav-desktop .sub-menu li {
	margin: 0;
	position: relative;
	text-align: left;
	z-index: 1;
	width: 100%;
	
}



header .nav-desktop .sub-menu > li > a {
	font-size:1rem;
}


header nav .sub-menu > li > a {
	color: var(--color-menu);
	padding: 0.6rem 0.5rem;
	box-sizing: border-box;
	display: inline-block;
	width: 100%;
	font-weight: 500;
	white-space: nowrap;
	
	text-decoration:none;
	border-bottom:2px solid rgba(0,0,0,0);

	/* border-radius:0.2rem; */
}

header nav .sub-menu li:hover a {
	
}

header nav .sub-menu li:hover,
header nav .sub-menu li.current-menu-item {
	color: var(--color-sticky-menu-hover);
	width: 100%;
}

header nav ul.sub-menu li > a:hover {
	color: var(--color-menu-hover);
}

header nav ul li:first-child .sub-menu {
	width: auto;
}

@media (min-width: 992px) {
	header nav ul li:first-child .sub-menu {
		display: flex;
		flex-wrap: wrap;
	}
	
	header nav ul li:first-child .sub-menu li {
		position: relative;
	}
}


/* =========================================================
	MENU MOBILE
========================================================= */

@media (max-width: 991px) {
	header nav ul.menu {
		width: 100% !important;
	}
	
	header nav .menu > li > a {
		color: var(--color-menu);
		font-size: 1.3rem;
		font-weight: 600;
		margin: 0;
		padding: 0.8rem 1rem !important;
		box-sizing: border-box;
		display: inline-block;
		width: 100%;
		transition: all 0.3s linear;
		text-transform: uppercase;
		letter-spacing: 10%;
	text-align:left;
	}
	
	header nav .sub-menu > li > a {
		text-align: center;
	}
	
	header nav.nav-mobile ul {
		padding: 0;
		margin: 0;
	}
	
	header nav.nav-mobile li {
		display: inline-block;
		list-style: none;
		position: relative;
		width: 100%;
	}
	
	header nav ul.menu li,
	header nav ul.menu > li {
		display: inline-block;
		width: 100%;
		border-right: 0;
		padding: 0;
	}
	
	header nav ul.menu > li a {
		padding: 0.5rem;
	}
	
	header nav .sub-menu {
		list-style-type: none;
		display: inline-block;
		position: relative;
		opacity: 1;
		visibility: visible;
	}
	
	header nav ul li:first-child .sub-menu li,
	header nav .sub-menu li,
	header nav a,
	header nav .sub-menu,
	header nav ul li:first-child .sub-menu {
		width: 100%;
	}
	
	nav {
		width: 100%;
		opacity: 0;
		height: 0;
		overflow: hidden;
	}
	
	.menu-toggle.on + nav {
		opacity: 1;
		height: auto;
		background-color: white;
		height: 100vh;
		transition:all 0.2s linear;
	}
	
	.menu {
		width: 100%;
		height: auto;
	}
	
	.main-navigation a {
		color: white;
		display: block;
		font-size: 14px;
		text-transform: uppercase;
		font-weight: 300;
		text-align: center;
		padding: 15px;
		line-height: 1;
		width: 100%;
	}
	
	.main-navigation > ul > li {
		border-top: 1px solid white;
	}
	
	.sticky-header-normal {
		position: relative !important;
	}
	
	.menu-close {
		height: 0;
		opacity: 0;
		transition: all 0.4s linear;
		overflow: hidden;
	}
	
	.menu-open {
		width: 100%;
		opacity: 1;
		height: auto;
		transition: all 0.4s linear;
		padding: 0 2vw;
	}
	
	
header .nav-mobile .sub-menu > li > a {
	font-size:1.3rem;
}
	
}


/* =========================================================
	MENU MOBILE — TOGGLE / HAMBURGER
========================================================= */

.menu-toggle {
	background-color: var(--menu-bg);
}

.sticky .menu-toggle {
	background-color: var(--sticky-menu-bg);
}

.menu-toggle.on {
	border-bottom: none;
}

@media (min-width: 992px) {
	.menu-toggle img {
		padding: 1rem 0;
	}
}

@media (max-width: 991px) {
	.menu-toggle-box {
		display: block;
		font-size: 0;
		border: 0 none;
		padding: 0;
		color: black;
		width: 32px;
		float: right;
		margin: 1rem;
		cursor: pointer;
		position: relative;
	}
	
	.line-one,
	.line-two,
	.line-three {
		background-color: var(--color-menu);
		width: 100%;
		height: 2px;
		margin: 7px auto;
		backface-visibility: hidden;
		transition: all 0.3s;
	}
	
	.stickymenu .line-one,
	.stickymenu .line-two,
	.stickymenu .line-three {
		background-color: var(--color-sticky-menu);
	}
	
	.menu-toggle.on .line-one {
		transform: rotate(-45deg) translate(-6px, 6px);
	}
	
	.menu-toggle.on .line-two {
		opacity: 0;
	}
	
	.menu-toggle.on .line-three {
		transform: rotate(45deg) translate(-6px, -6px);
	}
}


/* =========================================================
	MENU MOBILE — SUBMENU ROZWIJANE
========================================================= */

.nav.nav-mobile .menu {
	padding: 0 0.5rem;
}

.nav.nav-mobile li a,
.nav.nav-mobile .menu > li > a {
	padding: 0.8rem 1rem !important;
		text-align:left !important;
}

.nav.nav-mobile .menu > li > .sub-menu > li > .sub-menu > li > a {
	padding: 1rem;
	text-transform: none;
}

.nav.nav-mobile .menu li {
	position: relative;
}

.nav.nav-mobile ul.menu > li.menu-item-has-children::before {
	content: "\f0d7";
  font-family: FontAwesome;
  right: 1.2rem;
  position: absolute;
  margin-right: 0.5rem;
  transition: all 0.2s linear;
  z-index: 999999;
  cursor: pointer;
  margin: 0;
  top: 0.4rem;
  font-size: 1.5rem;
}

.nav.nav-mobile ul.menu li.menu-item-has-children.active::before {
	transform: rotate(180deg);
	transition: all 0.2s linear;
}

.nav.nav-mobile ul.menu > li.menu-item-has-children > .sub-menu {
	display: none;
}

.nav.nav-mobile ul.menu li.menu-item-has-children.active > .sub-menu {
	display: block;
}




/* =========================================================
	ELEMENTY CUSTOMOWE POZA STANDARDOWYM MENU
========================================================= */


a.menu-border-button {
	margin: 0;
	padding: 0.6rem 1rem;
	font-size:1rem;
	display: inline-block;
	color: var(--color-menu);
	border: 2px solid var(--color-menu);
	border-radius: 0.2rem;
	font-family: var(--menu-font);
	font-weight: 600;
	text-transform: uppercase;
	align-self: center !important;
	letter-spacing:0.1rem;
}

a.menu-border-button:hover {
	color:#fff;
	background-color: var(--color-menu-hover);
	border: 2px solid var(--color-menu-hover);
}


body.home .menu-container:not(.stickymenu) a.menu-border-button {
	color: #fff;
	border: 2px solid #fff;
}


body.home .menu-container:not(.stickymenu) a.menu-border-button:hover {
	color:#fff;
	background-color: var(--color-menu-hover);
	border: 2px solid var(--color-menu-hover);
}




@media(min-width:992px){
	
	header .logo{
	
	position:absolute;
	top:0;
	left:3rem;
}

	
	.logo:after{
		content: '';
		position: absolute;
		left: 50%;
		top: 0;
		background-image: url("../img/logo-mask.svg");
		width: 125%;
		height: 145%;
		z-index: 1;
		background-size: contain;
		background-repeat: no-repeat;
		transform: translate(-50%,0);
	}
}

@media(max-width:991px){
	
	header .menu-toggle .logo {
		top:1rem;
		left: 1rem;
	}
	
	header .menu-toggle .logo a {
		z-index:9999
	}
	
	
	
}



body:not(.home) .margin-menu{
	padding-top: 7.5rem;
}


