/* Var Definitions */
.pixNav {
	--bg-color: var(--logo-color-1-dark, #888888);
	--font-color: var(--logo-color-1, #ffffff);		/* Schriftfarbe im Menü*/
	--hover-color: var(--logo-color-2, #ffffff);	/* Hover Linkfarbe im Menü*/
	--h1-color: var(--logo-color-1);
	--h2-color: var(--logo-color-1);
	--h3-color: var(--logo-color-1);
  --num-cols: 4;
  --gap-width: 20px;
  --top-margin: 10px;
}

.pixNav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: var(--top-margin);
	column-gap: var(--gap-width);
}

.pixNav .item {
	display: inline-block;
	vertical-align: top;
	position: relative;
	overflow: hidden;
	margin-bottom: var(--gap-width);
}

.pixNav .item.filler { visibility: hidden; margin-bottom: 0; }
/* .pixNav .item.filler { display: none; }		disable filler divs for fluid layouts */

.pixNav .item img { width: auto; max-width: 100%; height: auto; object-fit: cover; transform-origin: bottom center;}
.pixNav .item .text { pointer-events: none; }
.pixNav .item .icon { pointer-events: none; }

@media all and (max-width: 1000px) { .pixNav { --num-cols: 2 !important; } }
@media all and (max-width: 500px) { .pixNav { --num-cols: 1 !important; } }


/*-------------------------------*/
/*---------- fixwidth -----------*/
/*-------------------------------*/

.pixNav.fixwidth .item {
	transition: 0.2s;
	border-radius: 10px;
  flex-grow: 1;
  flex-basis: calc( (100% / var(--num-cols)) - ( var(--gap-width) * (var(--num-cols) - 1) / var(--num-cols)));
  box-shadow: 0px 0px 4px rgba(0, 0, 0, .6); 
}

.pixNav.fixwidth .item .link { /* cursor: url('../../images/layout/cursor_link.png') 0 35, auto; */ }

.pixNav.fixwidth .item a,
.pixNav.fixwidth .item .text { width: 100%; }

.pixNav.fixwidth .item img { border-radius: 10px; }

.pixNav.fixwidth .text {
	position: absolute;
	bottom: 7%;
	left: 0px;
	text-align: center;
	padding: 10px 0;
	transition: all 600ms;
	background: rgba(255, 255, 255, 0.8);
}
.pixNav.fixwidth .item:hover .text {
}
.pixNav.fixwidth .text h1 {
	margin: 0;
	text-transform: uppercase;
	color: var(--h1-color);
}

.pixNav.fixwidth .icon {
	content: '';
	display: block;
	position: absolute;
	width: 74px;
	height: 74px;
	border-radius: 37px;
	top: -21px;
	left: 11px;
	background-color: #fff;
	transition: all 50ms;
}
.pixNav.fixwidth .icon img {
	position: absolute;
	left: 5px;
	top: 5px;
	width: 64px;
	height: 64px;
	border-radius: 32px;
	background-color: #fff;
	box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.5) inset;
	transition: all 250ms;
}

/* Animation */
.pixNav.fixwidth .item img { transition: transform var(--transition-time) ease; }
.pixNav.fixwidth .item:hover img { transform: scale(1.1,1.1); }

.pixNav.fixwidth .item:hover .icon img {
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.25) inset;
}

.pixNav.fixwidth .item:hover .icon {
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.5) inset;
}

.pixNav.fixwidth .item { overflow: hidden; }
.pixNav.fixwidth { --top-margin: -100px; border: 20px solid rgba(255,255,255,0.6); border-bottom: 0; border-radius: 15px; background: rgba(255,255,255,0.6); }
.pixNav.fixwidth .item .text { bottom: 0; width: 100%; }
.pixNav.fixwidth .item .text p { position: relative; padding: 5px; color: var(--font-color-dark); 
								transition: all calc(var(--transition-time)*2); }
.pixNav.fixwidth .item .text .title { position: absolute; right: 20px; bottom: 20px; margin: 0; width: auto; padding: 5px 10px; color: var(--font-color-light); 
								background-color: var(--h3-color); border-radius: 5px; z-index: 2; transition: all calc(var(--transition-time)*2); }

.pixNav.fixwidth .icon { top: 8px; left: 9px; background: rgba(0,0,0,0.5); transition: transform calc(var(--transition-time)*2); }
.pixNav.fixwidth .icon img { background-color: initial; transition: transform calc(var(--transition-time)*2); }

.pixNav.fixwidth .item .text p { position: absolute; left: 50%; transform: translate(-50%, -50%); margin-top: 50%; color: var(--font-color-light); opacity: 0; }


@media all and (max-width: 1200px) { .pixNav.fixwidth .item .text p { font-size: 16px; line-height: 140%; } }
@media all and (max-width: 1000px) { .pixNav.fixwidth .item .text p { font-size: 18px; line-height: 180%; } }
@media all and (max-width: 800px) { .pixNav.fixwidth .item .text p { font-size: 16px; line-height: 160%; } }
@media all and (max-width: 500px) { .pixNav.fixwidth .item .text p { font-size: 18px; line-height: 180%; } }

/* Animation */
.pixNav.fixwidth .item:hover img { transform: none; }
.pixNav.fixwidth .item:hover .icon { transform: scale(16); transition: transform calc(var(--transition-time)*2) ease-in-out; }
.pixNav.fixwidth .item:hover .icon img { transform: scale(0.071); transition: transform calc(var(--transition-time)*2) ease-in-out; }
.pixNav.fixwidth .item:hover .text { padding: 0; }
.pixNav.fixwidth .item:hover .titel { margin-bottom: -100%; transition: margin calc(var(--transition-time)*2); }
.pixNav.fixwidth .item:hover .text p { opacity: 1; transition: opacity calc(var(--transition-time)*2); }


/*-------------------------------*/
/*----------- cards -------------*/
/*-------------------------------*/

.pixNav.cards .item {
	transition: 0.2s;
	border-radius: 10px;
  flex-grow: 0.4;				/* limit width of orphans for fluid layouts */
  flex-basis: calc( (100% / var(--num-cols)) - ( var(--gap-width) * (var(--num-cols) - 1) / var(--num-cols)));
  box-shadow: 0px 0px 4px rgba(0, 0, 0, .6); 
}

.pixNav.cards .item .link { /* cursor: url('../../images/layout/cursor_link.png') 0 35, auto; */ }

.pixNav.cards .item a,
.pixNav.cards .item .text { width: 100%; }

.pixNav.cards .item img { border-radius: 10px; }

.pixNav.cards .text {
	position: absolute;
	bottom: 7%;
	left: 0px;
	text-align: center;
	padding: 10px 0;
	transition: all 600ms;
	background: rgba(255, 255, 255, 0.8);
}

.pixNav.cards .item:hover .text { z-index: 1; }

.pixNav.cards .text .titel, .pixNav.cards .text h1 {
	margin: 0;
	text-transform: uppercase;
	color: var(--h1-color);
}

.pixNav.cards .icon {
	content: '';
	display: block;
	position: absolute;
	width: 74px;
	height: 74px;
	border-radius: 37px;
	top: -21px;
	left: 11px;
	background-color: #fff;
	transition: all 50ms;
	z-index: 1;
}
.pixNav.cards .icon img {
	position: absolute;
	left: 5px;
	top: 5px;
	width: 64px;
	height: 64px;
	border-radius: 32px;
	background-color: #fff;
	box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.5) inset;
	transition: all 250ms;
}

/* Animation */
.pixNav.cards .item img { transition: transform var(--transition-time) ease; }
.pixNav.cards .item:hover img { transform: scale(1.1,1.1); }

.pixNav.cards .item:hover .icon img {
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.25) inset;
	/*-ms-transform: scale(1.1,1.1);
	-webkit-transform: scale(1.1,1.1);
	transform: scale(1.1,1.1);*/
}

.pixNav.cards .item:hover .icon {
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.5) inset;
}

.pixNav.cards .item { overflow: hidden; }
.pixNav.cards { --top-margin: -100px; border: 20px solid rgba(255,255,255,0.6); border-bottom: 0; border-radius: 15px; background: rgba(255,255,255,0.6); }
.pixNav.cards .item .text { bottom: 0; width: 100%; }
.pixNav.cards .item .text p { position: relative; padding: 5px; color: var(--font-color-dark); 
								transition: all calc(var(--transition-time)*2); }
.pixNav.cards .item .text .title { position: absolute; right: 20px; bottom: 20px; margin: 0; width: auto; padding: 5px 10px; color: var(--font-color-light); 
								background-color: var(--h3-color); border-radius: 5px; z-index: 2; transition: all calc(var(--transition-time)*2); }

.pixNav.cards .icon { top: 8px; left: 9px; background: rgba(0,0,0,0.5); transition: transform calc(var(--transition-time)*2); }
.pixNav.cards .icon img { background-color: initial; transition: transform calc(var(--transition-time)*2); }

.pixNav.cards .item .text p { position: absolute; left: 50%; transform: translate(-50%, -50%); margin-top: 50%; color: var(--font-color-light); opacity: 0; }


@media all and (max-width: 1200px) { .pixNav.cards .item .text p { font-size: 16px; line-height: 140%; } }
@media all and (max-width: 1000px) { .pixNav.cards .item .text p { font-size: 18px; line-height: 180%; } }
@media all and (max-width: 800px) { .pixNav.cards .item .text p { font-size: 16px; line-height: 160%; } }
@media all and (max-width: 500px) { .pixNav.cards .item .text p { font-size: 18px; line-height: 180%; } }

/* Animation */
.pixNav.cards .item:hover img { transform: none; }
.pixNav.cards .item:hover .icon { transform: scale(16); transition: transform calc(var(--transition-time)*2) ease-in-out; }
.pixNav.cards .item:hover .icon img { transform: scale(0.071); transition: transform calc(var(--transition-time)*2) ease-in-out; }
.pixNav.cards .item:hover .text { padding: 0; }
.pixNav.cards .item:hover .titel { margin-bottom: -100%; transition: margin calc(var(--transition-time)*2); }
.pixNav.cards .item:hover .text p { opacity: 1; transition: opacity calc(var(--transition-time)*2); }


/*-------------------------------*/
/*------------ free -------------*/
/*-------------------------------*/

.pixNav.free { text-align: center; }
.pixNav.free .header { background-color: #f1dbba; }
.pixNav.free .header h1 { text-align: left; }

.pixNav.free .item {
	display: inline-block;
	vertical-align: middle;
	transition: 0.2s;
	width: 15%;
	margin-right: 2%;
}
.pixNav.free .item:last-of-type { margin-right: 0; }
.pixNav.free .item:hover {
	-webkit-transform: scale(1.1,1.1);
	-ms-transform: scale(1.1,1.1);
	transform: scale(1.1,1.1);
}

.pixNav.free .item a,
.pixNav.free .item img {
	max-width: 100%;
}

.pixNav.free .text { display: none; text-align: left; }
.pixNav.free .text h1 {
	text-transform: none;
	font-size: 100%;
	font-weight: normal;
}

.pixNav.free .icon {
	content: '';
	display: block;
	position: absolute;
	width: 74px;
	height: 74px;
	border-radius: 37px;
	top: -21px;
	left: 11px;
	background-color: #fff;
	transition: all 50ms;
}
.pixNav.free .icon img {
	position: absolute;
	left: 5px;
	top: 5px;
	width: 64px;
	height: 64px;
	border-radius: 32px;
	background-color: #fff;
	box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.5) inset;
	transition: all 250ms;
}

.pixNav.free .item:hover .icon img {
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.25) inset;
	/*-ms-transform: scale(1.1,1.1);
	-webkit-transform: scale(1.1,1.1);
	transform: scale(1.1,1.1);*/
}

.pixNav.free .item:hover .icon {
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.5) inset;
}

/*-------------------------------*/
/*----------- logos -------------*/
/*-------------------------------*/

.pixNav.logos {
	justify-content: flex-end;
}
.pixNav.logos .h1s {
	font-size: 14px;
	color: #3b3b3b;
}
.pixNav.logos .header {
	width: 25%;
}
.pixNav.logos .items {
	width: 75%;
	text-align: right;
}