/* Custom CSS
--------------------------------------------------------- */
::selection {
	background-color: var(--c-primary-alt) !important;
	color: var(--c-white) !important;
}
body {
	font-weight: 300;
	font-size: 2em;
	background-color: var(--c-page-bg);
}
body::-webkit-scrollbar {
	width: 8px;
}
body::-webkit-scrollbar-track {
	background: var(--c-white);
}
 
body::-webkit-scrollbar-thumb {
	background-color: var(--c-primary);
}
#content {
	padding: 0;
}
.container.xlarge {
	max-width: 100%;
}

.wysiwyg a:not(.button) {
	text-decoration:underline;
}

@media (min-width: 768px) {
	.container.xlarge {
		padding-left: calc(var(--gap-default) * 2);
		padding-right: calc(var(--gap-default) * 2);
	}
	.grid {
		grid-gap: calc(var(--gap-default) * 2);
	}
}

.single .elementor-section.elementor-section-boxed > .elementor-container,
.entry-content .elementor-section.elementor-section-boxed > .elementor-container {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}

.elementor-top-section.elementor-section-full_width .elementor-inner-section.elementor-section-full_width {
	padding-left: calc((var(--gap-default) * 2) - 10px);
	padding-right: calc((var(--gap-default) * 2) - 10px);
	padding-top: calc((var(--gap-default) * 2) - 10px);
	padding-bottom: calc((var(--gap-default) * 2) - 10px);
}

.entry-content .elementor-section.elementor-section-boxed > .elementor-container .elementor-section > .elementor-container {
	max-width: calc(var(--container-width) + 20px);
	/*padding-left: 0;
	padding-right: 0;*/
}

.page-id-11 .nosun-text-widget ul, .page-id-11 .nosun-text-widget ol,
.page-id-885 .nosun-text-widget ul, .page-id-885 .nosun-text-widget ol {
	padding: 0 0 2rem 2rem;
}

/* Typo
--------------------------------------------------------- */
.elementor-widget-heading h1.elementor-heading-title, .entry-content h1, h1,
.elementor-widget-heading h2.elementor-heading-title, .entry-content h2, h2,
.elementor-widget-heading h3.elementor-heading-title, .entry-content h3, h3,
.elementor-widget-heading h4.elementor-heading-title, .entry-content h4, h4,
.elementor-widget-heading h5.elementor-heading-title, .entry-content h5, h5,
.elementor-widget-heading h6.elementor-heading-title, .entry-content h6, h6 {
	text-transform: uppercase;
	letter-spacing: var(--ls-m);
	line-height: 1.4;
}
.elementor-widget-heading h1.elementor-heading-title, .entry-content h1, h1 {
	font-size: 3rem;
}
.elementor-widget-heading h3.elementor-heading-title, .entry-content h3, h3,
.elementor-widget-heading h4.elementor-heading-title, .entry-content h4, h4 {
	text-transform: none;
	letter-spacing: 0;
}
@media (min-width: 768px) {
	.elementor-widget-heading h1.elementor-heading-title, .entry-content h1, h1 {
		font-size: 4rem;
	}
}
@media (min-width: 1081px) {
	.elementor-widget-heading h1.elementor-heading-title, .entry-content h1, h1 {
		font-size: 6rem;
	}
	.elementor-widget-heading h1.elementor-heading-title, .entry-content h1, h1,
	.elementor-widget-heading h2.elementor-heading-title, .entry-content h2, h2,
	.elementor-widget-heading h3.elementor-heading-title, .entry-content h3, h3,
	.elementor-widget-heading h4.elementor-heading-title, .entry-content h4, h4,
	.elementor-widget-heading h5.elementor-heading-title, .entry-content h5, h5,
	.elementor-widget-heading h6.elementor-heading-title, .entry-content h6, h6 {
		margin-bottom: calc(var(--gap-default) * 1);
	}
}
a {
	text-decoration: none !important;
}

/* Header
--------------------------------------------------------- */
header#header {
	background-color: transparent;
	box-shadow: none;
	z-index: 9900;
	/*transform: translateY(-81px);*/
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.mobile-menu-open header#header,
.sticky-nav header#header {
	background-color: var(--c-page-bg);
	border-bottom: 1px solid var(--c-lightest-gray);
}
/*.mobile-menu-open header#header,
header#header.visible {
	transform: translateY(0px);
}
.elementor-editor-active header#header {
	position: static !important;
	transform: translateY(0px) !important;
}*/
#logo {
	float: left;
}
#logo svg {
	height: 40px;
	width: auto;
	display: inline-block;
	float: left;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.sticky-nav #logo svg {
	height: 40px;
}
#logo svg polygon,
#logo svg path {
	fill: var(--c-lightest-gray) !important;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.page-template-page-dark-header #logo svg polygon,
.page-template-page-dark-header #logo svg path,
.mobile-menu-open #logo svg polygon,
.mobile-menu-open #logo svg path,
.sticky-nav #logo svg polygon,
.sticky-nav #logo svg path {
	fill: var(--c-text) !important;
}

#main-menu {
	margin-right: var(--gap-default);
}
#desktop-main-menu li,
#main-menu li {
	margin-right: var(--gap-default);
}
#desktop-main-menu li a,
#main-menu li a {
	color: var(--c-white);
	text-transform: uppercase;
	letter-spacing: var(--ls-m);
	font-weight: 300;
	position: relative;
	display: inline-block;
    float: left;
    padding: 1.5rem 1rem;
    font-size: var(--fs-s);
}
#desktop-main-menu li a::after,
#main-menu li a::after {
	content: "";
	position: absolute;
	bottom: 1rem;
	left: 1rem;
	width: 0;
	height: 1px;
	background-color: currentColor;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
#main-menu li.button {
	padding: 0 !important;
	margin-bottom: 0;
	border: none !important;
	transform: translate(0, 0) !important;
	opacity: 1 !important;
	/*margin-right: 5rem;*/
	margin-right: 0;
}
#main-menu li.button a {
	color: var(--c-text);
	background-color: var(--c-lightest-gray);
	line-height: 26px;
	min-width: 140px;
	text-align: center;
}
#main-menu li.button a:hover,
.page-template-page-dark-header #desktop-main-menu li.button a,
.page-template-page-dark-header #main-menu li.button a,
.mobile-menu-open #main-menu li.button a,
.sticky-nav #main-menu li.button a {
	background-color: var(--c-text);
	color: var(--c-white);
}
.page-template-page-dark-header #main-menu li.button a {
	color: var(--c-white) !important;
}
.page-template-page-dark-header #main-menu li.button a:hover,
.mobile-menu-open #main-menu li.button a:hover,
.sticky-nav #main-menu li.button a:hover {
	background-color: var(--c-primary-alt);
	color: var(--c-white);
}
#main-menu li.button a::after {
	display: none;
}
#desktop-main-menu li.current-menu-item a::after,
#desktop-main-menu li a:hover::after,
#main-menu li.current-menu-item a::after,
#main-menu li a:hover::after {
	width: calc(100% - 2rem);
}
#desktop-main-menu li.current-menu-item a,
#desktop-main-menu li a:hover,
#main-menu li.current-menu-item a,
#main-menu li a:hover {
	color: var(--c-white);
}

.page-template-page-dark-header #desktop-main-menu li a,
.mobile-menu-open #desktop-main-menu li a,
.sticky-nav #desktop-main-menu li a,
.page-template-page-dark-header #main-menu li a,
.mobile-menu-open #main-menu li a,
.sticky-nav #main-menu li a {
	color: var(--c-primary);
}
.mobile-menu-open #desktop-main-menu li.current-menu-item a,
.mobile-menu-open #desktop-main-menu li a:hover,
.sticky-nav #desktop-main-menu li.current-menu-item a,
.sticky-nav #desktop-main-menu li a:hover,
.mobile-menu-open #main-menu li.current-menu-item a,
.mobile-menu-open #main-menu li a:hover,
.sticky-nav #main-menu li.current-menu-item a,
.sticky-nav #main-menu li a:hover {
	color: var(--c-primary);
}
.mobile-menu-open #main-menu li.button.current-menu-item a,
.mobile-menu-open #main-menu li.button.current-menu-item a:hover {
	color: var(--c-white);
}
.burger {
	display: inline-block;
	height: 56px;
	margin-left: 2rem;
}
.burger::before, .burger::after, .burger .patty {
	background-color: var(--c-white);
	width: 50px;
}
.burger::before {
	top: -18px;
}
.burger::after {
	bottom: -18px;
}
.burger:hover::before, .burger:hover::after, .burger:hover .patty {
	background-color: var(--c-lightest-gray);
}
.page-template-page-dark-header .burger::before, .page-template-page-dark-header .burger::after, .page-template-page-dark-header .burger .patty,
.mobile-menu-open .burger::before, .mobile-menu-open .burger::after, .mobile-menu-open .burger .patty,
.sticky-nav .burger::before, .sticky-nav .burger::after, .sticky-nav .burger .patty {
	background-color: var(--c-text);
}
.page-template-page-dark-header .burger:hover::before, .page-template-page-dark-header .burger:hover::after, .page-template-page-dark-header .burger:hover .patty,
.mobile-menu-open .burger:hover::before, .mobile-menu-open .burger:hover::after, .mobile-menu-open .burger:hover .patty,
.sticky-nav .burger:hover::before, .sticky-nav .burger:hover::after, .sticky-nav .burger:hover .patty {
	background-color: var(--c-primary-alt);
}
#mobile-menu-container {
	min-height:100px;
	width:auto;
	height:auto;
}
.mobile-menu-inner .container,
.mobile-menu-inner {
	height: 100%;
}
.mobile-menu-inner {
    bottom: auto;
    right: var(--gap-default);
    left: 0;
    background-color: var(--c-page-bg);
}
.menu-popup-menue-container {
	display: flex;
	height: 100%;
	width: 100%;
	justify-content: center;
	align-items: center;
}
#mobile-main-menu {
	list-style: none;
	opacity: 0;
	transform: translateY(20px);
	transition: all .2s ease;
	width: 100%;
	max-width: calc(100vw - calc(var(--gap-default) * 2));
}
@media (min-width: 1081px) {
	.mobile-menu-open #mobile-main-menu {
		opacity: 0;
		transform: translateY(20px);
	}
	.mobile-menu-open #mobile-menu-container {
	    opacity: 0;
	    pointer-events: none;
	    visibility: hidden;
	}
	#desktop-main-menu li.menu-item-1547 {
		display: none;
	}
}
@media (max-width: 1080px) {
	.mobile-menu-open #mobile-main-menu {
		opacity: 1;
		transform: translateY(0px);
		transition: all var(--a-timing-default) var(--a-easing-default) .2s;
	}
	.mobile-menu-open #mobile-menu-container {
	    opacity: 1;
	    pointer-events: all;
	    visibility: visible;
	}
}

#mobile-main-menu li {
	width: 100%;
	text-align: center;
	padding: 1.2rem 0;
}
#mobile-main-menu li a {
	padding: 1.2rem 0;
	position: relative;
	font-size: 2.2rem;
}
#mobile-main-menu li a::after {
	content: "";
	position: absolute;
	bottom: 1rem;
	left: 0;
	width: 0;
	height: 1px;
	background-color: currentColor;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
#mobile-main-menu li.current-menu-item a::after,
#mobile-main-menu li a:hover::after {
	width: calc(100% - 0rem);
}

/*@media (min-width: 768px) {*/
	#header .grid {
		grid-template-columns: 270px auto;
	}
	#header .grid .column {
		grid-column: span 1;
	}
/*}*/
header#header .menu-hauptmenue-container {
	display: block;
}
@media (max-width: 854px) {
	header#header .menu-hauptmenue-container {
		display: none;
	}
}

@media ( max-width: 767px ) {
	/*.header-top .grid {
		grid-template-columns: auto 60px;
	}*/
	.burger .patty,
	.burger::before,
	.burger::after,
	.burger {
		width: 40px;
	}
	#logo svg {
	    max-width: 200px;
	    height: auto;
	    width: 100%;
	}
	body {
		font-size: 1.6em;
	}
}

@media (max-width: 390px) {
	#header .grid {
	    grid-template-columns: auto 60px;
	}
}


/* Desktop toggle menu
--------------------------------------------------------- */
.header-top .menu-popup-menue-container {
	float: right;
	display: block;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	width: auto;
	overflow: hidden;
	max-width: 0;
	/*transition: opacity .2s var(--a-easing-default), max-width 1.2s ease;*/
}
#desktop-main-menu {
	float: left;
	list-style: none;
	height: 56px;
}
#desktop-main-menu li {
	float: left;
	display: inline-block;
}
#desktop-main-menu li a {
	position: relative;
}
@media (min-width: 1081px) {
	.mobile-menu-open .header-top .menu-popup-menue-container {
		max-width: 800px;
		opacity: 1;
		visibility: visible;
		pointer-events: all;
	}
}

/* Buttons
--------------------------------------------------------- */
.elementor-widget-button .elementor-button, input#submit, input[type="button"], input[type="submit"], .button,
.elementor-widget-button .elementor-button, .button {
	text-transform: uppercase;
	letter-spacing: var(--ls-m);
	font-weight: 300;
}
.elementor-widget-button.secondary .elementor-button, .button.secondary {
	color: var(--c-text) !important;
}
.icon-pos-icon_right .button-text {
	margin-right: 1rem;
}
.icon-pos-icon_left .button-text {
	margin-left: 1rem;
}


/* Widget: Parallax Image
--------------------------------------------------------- */
.pi-container {
	position: relative;
	overflow: hidden;
	width: 100%;
}
#content .pi-container img {
	position: relative;
	width: 140%;
	max-width: 140%;
	height: 140%;
	object-fit: cover;
	top: -20%;
	left: -20%;
}
.pi-container.pi-container-querformat.parallax-container {
	max-height: 70rem;
}

/* Widget: Projekte Slideshow Vollbild
--------------------------------------------------------- */
.nosun-projekte-slideshow-vollbild-widget {
	width: 100%;
	height: 100vh;
	position: relative;
}
.nosun-projekte-slideshow-vollbild-widget .container.xlarge {
	padding-left: 0;
	padding-right: 0;
	height: 100%;
}
.projekte-vollbild-swiper {
	height: 100%;
	z-index: 4;
}
.projekt-content-inner {
	padding: var(--gap-default);
	z-index: 3;
}
.projekt-image-container {
	width: 100%;
	height: 100%;
	position: relative;
}
.projekt-image-container img {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
}
.projekt-image-container .pic-inner {
	width: 100%;
	height: 100%;
	transform: scale(1);
	transition: all 1s ease-out .2s;
}
.swiper-slide-active .projekt-image-container .pic-inner {
	transform: scale(1.1);
}
.projekt-content-container {
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: absolute;
	z-index: 3;
	background-color: rgba(0,0,0,.2);
	text-align: center;
	color: #fff;
}
.projekt-content-container::after {
	/*content: "";*/
	position: absolute;
	z-index: 2;
	height: 100%;
	width: 100%;
	top: 0;
	left: 0;
	background: radial-gradient(transparent 68%, rgba(0,0,0,.4));
}
.nosun-projekte-slideshow-vollbild-widget h2.projekt-title {
	font-size: clamp(3rem, 8vw, 8rem);
	line-height: 1.2;
	color: #fff;
	transition: all var(--a-timing-slow) var(--a-easing-default) .2s;
}
.nosun-projekte-slideshow-vollbild-widget .projekt-kurzbeschreibung {
	opacity: 0;
	/*text-shadow: 1px 1px #000;*/
	transition: all var(--a-timing-slow) var(--a-easing-default) .2s;
}
.nosun-projekte-slideshow-vollbild-widget .swiper-slide-active .projekt-kurzbeschreibung,
.nosun-projekte-slideshow-vollbild-widget .swiper-slide-active h2.projekt-title {
	opacity: 1;
	transform: translateY(0px);
}
.projekt-content-container .button {
	margin-top: 4rem;
}

.swiper-button-prev,
.swiper-button-next {
	width:50px;
	height:50px;
	background: none;
}
.swiper-button-prev svg,
.swiper-button-next svg {
	display:inline-block;
	width:50px;
	height:18px;
}
.swiper-button-prev {
	left: calc(var(--gap-default) * 2);
}
.swiper-button-next {
	right: calc(var(--gap-default) * 2);
}
.swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction {
	bottom: 2rem;
}
.nosun-projekte-slideshow-vollbild-widget .swiper-pagination {
	text-align: right;
	padding: 0 var(--gap-default);
}
.nosun-projekte-slideshow-vollbild-widget .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
	opacity: 1 !important;
	color: var(--c-white);
	margin: 0 1rem;
	padding: 1rem;
	text-align: center;
	width: 2rem;
	height: 2rem;
	line-height: 2rem;
	background: none;
	box-sizing: content-box;
	outline: 0 !important;
	border-radius: 0;
}
.nosun-projekte-slideshow-vollbild-widget .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet.swiper-pagination-bullet-active {
	opacity: .35 !important;
}
.ps-video-popup {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	width: 100%;
	height: 100%;
	padding: var(--gap-default);
	background-color: rgba(0,0,0,.6);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
	z-index: 9910;
	transition: all .2s var(--a-easing-default);
}
.ps-video-popup.active {
	opacity: 1;
	pointer-events: all;
	visibility: visible;
}
.ps-video-wrapper {
	width: 100%;
	max-width: var(--container-width);
	position: relative;
	max-height: calc(100% - 100px);
	padding-top: var(--gap-default);
	padding-bottom: var(--gap-default);
}
.ps-popup-inner {
	width: 100%;
	padding-bottom: 56.25%; /* 16:9 */
	height: 0;
	position: relative;
}
.ps-video-wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.ps-video-wrapper video {
	width: 100%;
	height: auto;
}
.popup-close {
	position: absolute;
	top: 0px;
	right: -70px;
	height: 56px;
	width: 50px;
	z-index: 9920;
}
.popup-close::before, .popup-close::after {
	content: "";
	width: 50px;
	height: 2px;
	position: absolute;
	background-color: var(--c-white);
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	transition: all var(--a-timing-slow) var(--a-easing-default);
}
.popup-close::before {
	transform: rotate(45deg);
}
.popup-close::after {
	transform: rotate(-45deg);
}
@media (max-width: 767px) {
	.nosun-projekte-slideshow-vollbild-widget .swiper-button-prev, .nosun-projekte-slideshow-vollbild-widget .swiper-button-next {
		display: none;
	}
}

/* Widget: Projekt Grid
--------------------------------------------------------- */
.pg-unit {
	margin-bottom: 4rem;
	text-align: center;
}
.pg-image {
	overflow: hidden;
	width: 100%;
	display: block;
	margin-bottom: 4rem;
}
.pg-image img {
	width: 110%;
	max-width: 110% !important;
	height: 110%;
	object-fit: cover;
	float: left;
	transition: transform .6s cubic-bezier(.61,1,.88,1);
	transform: translateX(-5%);
}
.pg-image:hover img {
	transform: translateX(0%);
}
.pg-unit .pg-content-wrap .pg-title {
	margin-bottom: var(--gap-half);
}
.pg-unit .pg-link:hover
.pg-unit .pg-content-wrap .pg-title:hover {
	color: var(--c-primary-alt);
}
.pg-link {
	display: inline-block;
	position: relative;
	padding: 1rem 0;
}
.pg-link::before,
.pg-link::after {
	content: "";
	position: absolute;
	bottom: 1rem;
	left: 0;
	width: 0;
	height: 1px;
	background-color: var(--c-text);
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.pg-link::after {
	left: auto;
	right: 0;
	/*background-color: var(--c-white);*/
	width: 100%;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.pg-link:hover::before {
	width: 100%;
	transition: all var(--a-timing-default) var(--a-easing-default) var(--a-timing-default);
}
.pg-link:hover::after {
	width: 0;
}
.projekte-swiper .grid {
	display: flex;
	grid-gap: 0;
}
.projekte-swiper .swiper-slide {
	width: 320px;
}
@media (min-width: 768px) {
	.projekte-swiper .grid {
		display: grid;
		grid-gap: var(--gap-default);
	}
	.projekte-swiper .swiper-wrapper {
		transform: translate3d(0px, 0px, 0px) !important;
	}
	.projekte-swiper .swiper-slide {
		width: 100%;
	}
	.projekte-swiper .swiper-pagination,
	.projekte-swiper .swiper-button-prev,
	.projekte-swiper .swiper-button-next {
		display: none;
	}
}
/* Widget: Abstand
--------------------------------------------------------- */
.nosun-abstand-widget { min-height: 1px; }
.nosun-abstand-widget.abstand-size-xxl 		{ height: 60px; }
.nosun-abstand-widget.abstand-size-xl 		{ height: 40px; }
.nosun-abstand-widget.abstand-size-l 		{ height: 40px; }
.nosun-abstand-widget.abstand-size-m 		{ height: 40px; }
.nosun-abstand-widget.abstand-size-s 		{ height: 20px; }
.nosun-abstand-widget.abstand-size-xs 		{ height: 10px; }
@media (min-width: 768px) {
	.nosun-abstand-widget.abstand-size-xxl 	{ height: 180px; }
	.nosun-abstand-widget.abstand-size-xl 	{ height: 140px; }
	.nosun-abstand-widget.abstand-size-l 	{ height: 80px; }
	.nosun-abstand-widget.abstand-size-m 	{ height: 40px; }
	.nosun-abstand-widget.abstand-size-s 	{ height: 20px; }
	.nosun-abstand-widget.abstand-size-xs 	{ height: 10px; }
}
@media (min-width: 1081px) {
	.nosun-abstand-widget.abstand-size-xxl 	{ height: 220px; }
	.nosun-abstand-widget.abstand-size-xl 	{ height: 180px; }
	.nosun-abstand-widget.abstand-size-l 	{ height: 140px; }
	.nosun-abstand-widget.abstand-size-m 	{ height: 80px; }
	.nosun-abstand-widget.abstand-size-s 	{ height: 40px; }
	.nosun-abstand-widget.abstand-size-xs 	{ height: 20px; }
}

/* Widget: Partnerlogos
--------------------------------------------------------- */
.partnerlogo-grid {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 4rem;
}
.partnerlogo-grid:last-child {
	margin-bottom: 0;
}
.partnerlogo {
	width: calc((100% / 6) - 40px);
	margin: 20px;
	opacity: .5;
	transition: all var(--a-timing-slow) var(--a-easing-default);
	filter: grayscale(1);
}
.partnerlogo-bild {
	width: 100%;
	height: 92px;
	text-align: center;
}
.partnerlogo-bild svg,
.partnerlogo-bild img {
	width: 100%;
	max-width: 150px !important;
	height: 100% !important;
	object-fit: contain;
	display: inline-block;
}
.partnerlogo:hover {
	opacity: 1;
	filter: grayscale(0);
}
@media (max-width: 1080px) {
	.partnerlogo-grid {
		display: grid;
		grid-gap: 4rem;
		grid-template-columns: repeat(3, 1fr) !important;
	}
	.partnerlogo {
		width:100%;
		margin: 0;
	}
}


/* Widget: Kundenstimmen
--------------------------------------------------------- */
.nosun-kundenstimmen-widget {
	position: relative;
}
.nosun-kundenstimmen-widget .container::after {
	content: '"';
	position: absolute;
	pointer-events: none;
	z-index: -1;
	top: -8rem;
	left: -5rem;
	font-size: 50rem;
	opacity: .05;
	line-height: 1;
}
.kundenstimmen-swiper {
	padding-bottom: 7rem;
}
.kundenstimmen-swiper .swiper-button-prev {
	right: 70px;
	left: auto;
	bottom: 0;
	top: auto;
}
.kundenstimmen-swiper .swiper-button-next {
	right: 0px;
	left: auto;
	bottom: 0;
	top: auto;
}
@media (max-width: 767px) {
	.nosun-kundenstimmen-widget .container::after {
	    top: -4rem;
	    left: 1rem;
	    font-size: 24rem;
	}
}

/* Widget: Bild & Text
--------------------------------------------------------- */
.bt-stil2-content {
	width: 100%;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	z-index: 4;
	padding-left: calc(var(--gap-default) * 1);
	padding-right: calc(var(--gap-default) * 1);

	position: absolute;
	background: none !important;
}
.bt-stil2-content .column.text_align_center {
	text-align: center;
}
.bt-stil2-content .column.text_align_right {
	text-align: right;
}
.nosun-bild-text-widget.stil_2 .bt-stil2-content .button {
	margin-top: calc(var(--gap-default) * 2);
}
.bt-stil2-content h1,
.bt-stil2-content h2,
.bt-stil2-content h3,
.bt-stil2-content h4,
.bt-stil2-content h5,
.bt-stil2-content h6,
.bt-stil2-content .wysiwyg,
.bt-stil2-content p {
	color: var(--c-white);
	z-index: 4;
	position: relative;
}
.bt-stil2-content .button {
	z-index: 4;
	position: relative;
}
.bt-stil2-content h1,
.bt-stil2-content h2,
.bt-stil2-content h3,
.bt-stil2-content h4,
.bt-stil2-content h5,
.bt-stil2-content h6 {
	margin-top: var(--gap-default);
}
.bt-image-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 3;
	pointer-events: none;
}
@media (min-width: 768px) {
	.nosun-bild-text-widget .button {
		margin-top: var(--gap-default);
	}
}
@media (min-width: 768px) and (max-width:1080px) {
	.nosun-bild-text-widget .column.text_align_center {
		max-width: 70%;
		margin:auto;
	}
}
@media (min-width: 1081px) {
	.bt-stil2-content {
		padding-left: calc(var(--gap-default) * 4);
		padding-right: calc(var(--gap-default) * 4);
	}
}
@media (max-width: 1080px) {
	.nosun-bild-text-widget.stil_2 .column {
	    grid-column: span 6;
	}
	.bt-image-overlay.bt-image-overlay-mobile {
		background: rgba(0,0,0,.2) !important;
	}
	.nosun-bild-text-widget.stil_2 .container.xlarge {
		padding-left: 0;
		padding-right: 0;
	}
}
@media (max-width: 767px) {
	.bt-image-column {
		grid-row: 1;
	}
	.bt-text-column {
		grid-row: 2;
	}
	.bt-stil2-content .ueberschrift {
		font-size: var(--fs-m) !important;
	}
	.bt-stil2-content {
		padding-top: var(--gap-default);
		padding-bottom: var(--gap-default);
	}
	.nosun-bild-text-widget.stil_2 .column {
	    grid-column: span 1;
	}
}

/* Widget: Bilderkachel
--------------------------------------------------------- */
.bilderkachel-container .grid .column {
	cursor: pointer;
}

@media ( min-width: 1081px ) {
	.bilderkachel-container .column.one-by-one {
		grid-column: span 6;
		grid-row: span 1;
	}
	.bilderkachel-container .column.one-by-two {
		grid-column: span 6;
		grid-row: span 2;
	}
	.bilderkachel-container .column.two-by-two {
		grid-column: span 12;
		grid-row: span 1;
	}
}

.bilderkachel {
	width: 100%;
	height: 100%;
	position: relative;
	float: left;
	overflow: hidden;
}
.bilderkachel img {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
	float: left;
}
.bilderkachel h4 {
	margin-bottom: var(--gap-half) !important;
}
.bilderkachel .bilderkachel-content-wrap {
	position: absolute;
	bottom: var(--gap-half);
	left: var(--gap-half);
	padding: var(--gap-half);
}
@media (min-width: 768px) {
	.bilderkachel .bilderkachel-content-wrap {
		bottom: var(--gap-default);
		left: var(--gap-default);
		padding: var(--gap-default);
		background-color: rgba(255,255,255,.8);
	}
}


/* Widget: Bild mit Strukturen
--------------------------------------------------------- */
.nosun-bild-mit-strukturen {
	height: 100vh;
}
.bms-image-container {
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden;
}
.bms-scroll-container {
	width: auto;
	position: relative;
	height: 100%;
}
.bms-image-container {
	position: relative;
}
.bms-image-container img.bms-image {
    max-width: 100000% !important;
    width: auto;
    position: relative;
    float: left;
    top: 50%;
    min-height: 100vh;
    height: 100vh;
    left: 0%;
    transform: translate(0%, -50%);
}
.elementor-editor-active .bms-image-container img.bms-image {
	min-height: 1px;
    height: auto;
    width: 100%;
}
.bms-strukturen {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.struktur-dot {
	width: 10px;
	height: 10px;
	border-radius: 50px;
	position: absolute;
	top: 0;
	z-index: 10;
	background-color: #fff;
	cursor: pointer;
	box-shadow: 0 0 38px 22px rgb(0 0 0 / 26%);
}
.elementor-editor-active .struktur-dot {
	transform: translateY(0) !important;
}
.struktur-dot::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 30px;
	height: 30px;
	background-color: transparent;
	border: 1px solid #fff;
	border-radius: 50px;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.struktur-dot::after {
	width: 50px;
	height: 50px;
	background-color: rgba(255,255,255,.2);
}
.struktur-dot.active::before,
.struktur-dot.active::after,
.struktur-dot:hover::before,
.struktur-dot:hover::after {
	transform: translate(-50%, -50%) scale(1.4);
}
.struktur-infobox {
	width: 100%;
	max-width: 350px;
	position: absolute;
	right: 5%;
	bottom: 5%;
	padding: var(--gap-default);
	background-color: #fff;
	z-index: 13;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.struktur-infobox img {
	width: 100%;
	margin-bottom: 10px;
	max-height: 250px;
}
.struktur-infobox.active {
	opacity: 1;
	visibility: visible;
	pointer-events: all;
}
.strukturen-infobox-close {
	position: absolute;
	top: 10px;
	right: 10px;
	background-color: #fff;
	color: var(--c-text);
	text-align: center;
	padding: 5px;
	cursor: pointer;
} 
.strukturen-infobox-close svg {
	float: left;
}
.bms-scrollbar {
	display: none;
	position: absolute;
	bottom: 10%;
	left: 0;
	right: 0;
	margin: auto;
	width: 90%;
	max-width: 250px;
	height: 3px;
	background-color: rgba(255,255,255,.3);
	z-index: 12;
}
.bms-scrollbar-track {
	width: 15%;
	top: 50% !important;
	height: 20px;
	transform: translateY(-50%);
	float: left;
	position: relative;
	cursor: grab;
}
.bms-scrollbar-track::after {
	content: "";
	width: 100%;
	height: 5px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	background-color: rgba(255,255,255,1);
}

/* Banner Widget
--------------------------------------------------------- */
.nosun-banner-widget .container.xlarge {
	padding-left: 0;
	padding-right: 0;
	height: 700px;
	overflow: hidden;
}
.nosun-banner-widget .container video,
.nosun-banner-widget .container img {
	height: 100%;
	width: 100% !important;
	object-fit: cover;
}
.nosun-banner-widget .container h2 {
	color: var(--c-white) !important;
}

/* Footer
--------------------------------------------------------- */
footer#footer .footer-middle {
	background-color: var(--c-text);
	color: var(--c-white);
	border-bottom: 1px solid rgba(255,255,255,.2);
}
.footer-bild svg,
.footer-bild img {
	max-width: 300px;
	width: 100%;
	height: auto;
	margin-bottom: 10px;
}
.footer-linkliste {
	list-style: none;
}
.footer-linkliste li a {
	position: relative;
	color: var(--c-white);
}
.footer-linkliste li a::after {
	content: "";
	position: absolute;
	bottom: -.5rem;
	left: 0;
	width: 0;
	height: 1px;
	background-color: currentColor;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.footer-linkliste li a:hover::after {
	width: 100%;
}

.copyright {
	color: var(--c-light-gray);
}

.footer-social-media {
	width: 100%;
	list-style-type: none;
	margin-top: 2rem;
}
.footer-social-media li {
	float: left;
	margin-right: 2rem;
}
.footer-social-media li:last-child {
	margin-right: 0;
}
.footer-social-media li a {
	float: left;
	display: inline-block;
	width: 30px;
	height: 30px;
	line-height: 30px;
	text-align: center;
	color: var(--c-white);
}
.footer-social-media li a svg {
	display: inline-block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}
footer#footer a,
footer#footer h5 {
	color: var(--c-white);
}
footer#footer a:hover,
.footer-social-media li a:hover {
	color: var(--c-light-gray);
}

.meta-nav svg {
	height: 18px;
    display: inline-block;
    position: relative;
    top: 2px;
}
.nav-previous,
.nav-next {
	vertical-align: top;
	width: 50%;
	display: inline-block;
}
.nav-next {
	text-align: right;
}
.meta-nav-next svg {
    margin-left: 10px;	
}
.meta-nav-prev svg {
    margin-right: 10px;	
}
@media (max-width: 767px) {
	.footer-bild svg,
	.footer-bild img {
		max-width: 200px;
	}
	.page-template-page-dark-header #content {
		padding-top: 10rem;
	}
	.nav-next a, .nav-previous a {
		display: flex;
		flex-direction: column-reverse;
	}
	.nav-previous a {
		flex-direction: column;
	}
	.nav-below-p-title {
		margin-top: 2rem;
	}
}
@media (max-width: 320px) {
	.nav-previous,
	.nav-next {
		width: 100%;
		text-align: center;
	}
	.nav-previous {
		margin-bottom: 4rem;		
	}
}

/* Projekte
--------------------------------------------------------- */
/* single */
.banner-bild-wrapper {
	width: 100%;
	height: 100vh;
	overflow: hidden;
	position: relative;
}
.banner-bild-wrapper::after{
	content: "";
	top: 0;
	left: 0;
	background: linear-gradient(to top, rgba(0,0,0,.2) 20%, transparent, rgba(0,0,0,.3) 80%);
	z-index: 2;
	width: 100%;
	height: 100%;
	position: absolute;
}
.banner-bild-wrapper img {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
	position: relative;
	z-index: 1;
}
.spb-content-container {
/*.spb-title {*/
	z-index: 3;
	position: absolute;
	bottom: 8rem;
	left: 0;
	right: 0;
	margin: auto;
	text-align: center;
	padding: 0 var(--gap-default);
	max-width:1400px;
}
.spb-description h4,
.spb-title h1 {
	color: var(--c-white);
	line-height: 1.2;
}

.struktur {
	position: relative;
	width:100%;
}
.struktur-image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	float: left;
}
.struktur-content-wrap {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: var(--gap-default);
	overflow: scroll;
	background-color: rgba(58,58,58,.8);
	opacity: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	pointer-events: none;
	visibility: hidden;
	transition: all var(--a-timing-default) var(--a-easing-default);
}
.struktur:hover .struktur-content-wrap {
	opacity: 1;
	pointer-events: all;
	visibility: visible;
}
.struktur-content-wrap h4,
.struktur-content-wrap p {
	transform: translateY(40px);
	color: var(--c-white);
	opacity: 0;
	transition: all var(--a-timing-default) var(--a-easing-default) .1s;
}
.struktur-content-wrap p {
	transition-delay: .2s;
}
.struktur:hover .struktur-content-wrap h4,
.struktur:hover .struktur-content-wrap p {
	transform: translateY(0px);
	opacity: 1;
}

@media (min-width: 768px) {
	.struktur-content-wrap {
		padding: calc(var(--gap-default) * 2)
	}
}
@media (max-width: 767px) {
	.spb-description h4 {
		font-size:var(--fs-m);
	}
}
.cta-container {
	text-align: center;
	background-color: #f9f9f9;
}
.cta-container .button {
	margin-top: var(--gap-default);
}


/* Widget: Projekt Kacheln
--------------------------------------------------------- */
.projekte-kachel-grid {
	grid-template-columns: repeat(3, 1fr) !important;
/*	grid-auto-rows: 1fr;*/
	grid-gap: var(--gap-default);
}
.projekte-kachel-grid .column {
	/*padding: 50px;
	background-color: red;*/
	overflow: hidden;
}
.projekte-kachel-grid .column .pk-image-container,
.projekte-kachel-grid .column .pk-inner {
	width: 100%;
	height: 100%;
	position: relative;
	display: block;
}
.projekte-kachel-grid .column .pk-image-container img {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
	float: left;
	transition: all 1.2s var(--a-easing-default);
}
.projekte-kachel-grid .column:hover .pk-image-container img {
	transform: scale(1.1);
}
.projekte-kachel-grid .column .pk-content-container {
	position: absolute;
	bottom: -100px;
	height: 100%;
	padding: calc(var(--gap-default) * 2);
	width: 100%;
	left: 0;
	opacity: 0;
	display: flex;
	align-items: flex-end;
	background: linear-gradient(to top right, rgba(0,0,0,.4), transparent, transparent);
	transition: all .6s var(--a-easing-default);
}
.projekte-kachel-grid .column:hover .pk-content-container {
	bottom: 0;
	opacity: 1;
}
.projekte-kachel-grid .column .pk-content-container h5 {
	color: #fff;
	margin-bottom: 0 !important;
}
.projekte-kachel-grid .column .pk-content-container .pg-link {
	color: #fff;
}
.projekte-kachel-grid .column .pk-content-container .pg-link::before, .projekte-kachel-grid .column .pk-content-container .pg-link::after {
	background-color: #fff;
}
.projekte-kachel-grid .column.one-by-one {
	grid-column: span 1;
	grid-row: span 2;
	max-height: 465px;
}
.projekte-kachel-grid .column.one-by-two {
	grid-column: span 1;
	grid-row: span 4;
}
.projekte-kachel-grid .column.one-by-one-and-half {
	grid-column: span 1;
	grid-row: span 3;
	max-height: 708px;
}

.projekte-kachel-grid .column.two-by-one {
	grid-column: span 2;
	grid-row: span 2;
	max-height: 465px;
}
.projekte-kachel-grid .column.two-by-two {
	grid-column: span 2;
	grid-row: span 4;
}
.projekte-kachel-grid .column.two-by-one-and-half {
	grid-column: span 2;
	grid-row: span 3;
}

.projekte-kachel-grid .column.three-by-one {
	grid-column: span 3;
	grid-row: span 2;
	max-height: 465px;
}
.projekte-kachel-grid .column.three-by-two {
	grid-column: span 3;
	grid-row: span 4;
}
.projekte-kachel-grid .column.three-by-one-and-half {
	grid-column: span 3;
	grid-row: span 3;
}
.projekte-kachel-grid .column .pk-inner.pk-logo {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
} 
.projekte-kachel-grid .column .pk-inner.pk-logo svg {
	max-width: 80%;
}

@media (max-width: 767px) {
	.projekte-kachel-grid {
		grid-template-columns: repeat(1, 1fr) !important;
	}
	.projekte-kachel-grid .column {
		grid-column: span 1 !important;
		grid-row: span 1 !important;
		height: 465px !important;
		/*max-height: 465px !important;*/
	}
	.projekte-kachel-grid .column .pk-content-container {
		padding: var(--gap-default);
		bottom: 0;
		opacity: 1;
	}
}
@media (max-width: 695px) {
	.nosun-projekte-slideshow-vollbild-widget .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
		padding: 0rem;
	}
	.nosun-projekte-slideshow-vollbild-widget .swiper-pagination {
		text-align: center;
	}
}
/*@media (max-width: 375px) {
	.projekte-kachel-grid {
		grid-template-columns: repeat(1, 1fr) !important;
	}
}*/
.below-single-nav {
	margin-bottom: 6rem;
}

/* Contact Form 7
--------------------------------------------------------- */
.wp-cf7-row {
	width: 100%;
}
.wp-cf7-col {
	width: 100%;
	float: left;
	margin-bottom: var(--gap-default);
}
.wp-cf7-col textarea,
.wp-cf7-col input[type="text"],
.wp-cf7-col input[type="tel"],
.wp-cf7-col input[type="email"] {
	min-width: 100%;
	width: 100%;
	border-width: 0 0 1px 0;
	border-color: var(--c-light-gray);
	border-radius: 0;
	background: none;
	outline: 0 !important;
	padding: 9px 0 !important;
	font-family: var(--ff-default);
	cursor: pointer;
}
.wp-cf7-col textarea {
	height: 250px;
	line-height: 1.2;
}
.wp-cf7-col input[type="text"],
.wp-cf7-col input[type="tel"],
.wp-cf7-col input[type="email"] {
	height: 40px;
	line-height: 40px;
}
.wp-cf7-col textarea:focus,
.wp-cf7-col input[type="text"]:focus,
.wp-cf7-col input[type="tel"]:focus,
.wp-cf7-col input[type="email"]:focus {
	border-color: var(--c-text);
}
.wp-cf7-col textarea::placeholder,
.wp-cf7-col input[type="text"]::placeholder,
.wp-cf7-col input[type="tel"]::placeholder,
.wp-cf7-col input[type="email"]::placeholder {
	color: var(--c-text);
	opacity: .6;
	/*color: var(--c-light-gray);*/
}
.wp-cf7-col textarea:focus::placeholder,
.wp-cf7-col input[type="text"]:focus::placeholder,
.wp-cf7-col input[type="tel"]:focus::placeholder,
.wp-cf7-col input[type="email"]:focus::placeholder {
	opacity: .8;
}
.wpcf7-not-valid-tip {
    color: var(--c-danger);
    font-size: 1.4rem;
}
.data-privacy {
    font-size: 1.4rem;
}
.data-privacy a {
	text-decoration: underline !important;
}
.data-privacy a:hover {
	text-decoration: none !important;
}
input#submit, input[type="button"], input[type="submit"] {
	cursor: pointer;
	outline: 0 !important;
}
.wpcf7 form .wpcf7-response-output {
	background-color: #fff;
	color: var(--c-text);
}
.wpcf7 form .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
	border: none;
	float: left;
	background-color: var(--c-danger);
	color: #fff;
    font-size: 1.4rem;
}
.wpcf7 form.sent .wpcf7-response-output {
	background-color: var(--c-success);
}
@media (min-width: 1081px) {
	.wp-cf7-col.half {
		width: 50%;
		padding-left: var(--gap-half);
	}
	.wp-cf7-col.half.first {
		padding-left: 0;
		padding-right: var(--gap-half);
	}
}


/* lightGallery
--------------------------------------------------------- */
body .lg-backdrop {
	z-index: 9990;
}
body .lg-outer {
	z-index: 9991;
}
/*.lg-outer .lg-item.lg-complete {*/
.lg-outer .lg-item {
	background-color: var(--c-primary) !important;
}
.lg-outer .lg-thumb-item {
	border: 2px solid transparent !important;
	border-radius: 0 !important;
}
.lg-outer .lg-thumb-item.active, .lg-outer .lg-thumb-item:hover {
	border-color: var(--c-white) !important;
}
.lg-sub-html h4 {
	font-size: 2rem !important;
	color: var(--c-white) !important;
}

.galerie-item {
	cursor: pointer;
}

/* Animations
--------------------------------------------------------- */
/* default */
.elementor-widget-heading, .elementor-widget-text-editor, .animate {
	opacity: 0;
	/*transform: translateY(80px);*/
	transition: all var(--a-timing-slow) var(--a-easing-default) .2s;
}
.elementor-widget-button .elementor-button, .button {
	opacity: 0;
	/*transform: translateY(80px);*/
	transition: background-color var(--a-timing-default) var(--a-easing-default),margin var(--a-timing-default) var(--a-easing-default),border-color var(--a-timing-default) var(--a-easing-default),color var(--a-timing-default) var(--a-easing-default), opacity var(--a-timing-slow) var(--a-easing-default) .2s, transform var(--a-timing-slow) var(--a-easing-default) .2s;
}
/* only fade */
.fadeIn {
	opacity: 0;
	transition: all var(--a-timing-slow) var(--a-easing-default);
}
/* animation complete */
.elementor-editor-active .elementor-widget-heading,
.elementor-editor-active .elementor-widget-text-editor,
.elementor-editor-active .elementor-widget-button .elementor-button,
.elementor-editor-active .button,
.swiper-slide-active .animate,
.swiper-slide-next .animate,
.swiper-slide-prev .animate,
.elementor-editor-active .animate,
.elementor-widget-heading.inView,
.elementor-widget-text-editor.inView,
.elementor-widget-button .elementor-button.inView,
.button.inView,
.animate.inView {
	opacity: 1;
	transform: translateY(0px);
}
.elementor-editor-active .fadeIn,
.fadeIn.inView {
	opacity: 1;
}

.projekt-content-container .button {
	opacity: 0;
	/*transform: translateY(40px);*/
	transition: opacity var(--a-timing-slow) var(--a-easing-default) .4s, transform var(--a-timing-slow) var(--a-easing-default) .4s, color var(--a-timing-default) var(--a-easing-default) 0s, background-color var(--a-timing-default) var(--a-easing-default) 0s;
}
.elementor-editor-active .nosun-projekte-slideshow-vollbild-widget h2.projekt-title {
	opacity: 1;
	transform: translateY(0px);
}
.elementor-editor-active .projekt-content-container .button,
.swiper-slide-active .projekt-content-container .button {
	opacity: 1 !important;
	transform: translateY(0px) !important;
}

@media (max-width: 1189px) and (min-width: 1081px) {
	.mobile-menu-open #menu-item-75 {
		display: none;
	}
}

.elementor-editor-active #page {
	padding-top: 100px;
}

/* display none
--------------------------------------------------------- */
#desktop-main-menu .menu-item-500,
#elementor-lightbox-slideshow-single-img,
.swiper-button-prev::after,
.swiper-button-next::after {
	display: none !important;
}