@charset "utf-8";

/*********
Allgemein
*********/
* {
	font-family: "proxima-nova-condensed-light", Helvetica, Arial, sans-serif;
}

html {
	height: 100%;
}

a:link,
a:visited,
a:hover,
a:active {
	outline: 0;
}

/*********
Allgemeine Responsive Klassen für Geräte
*********/
/* Desktop */
@media 
only screen and (min-width : 880px) {
	.desktop-off, 
	.tablet-on,
	.phone-on {
		display: none;
	}
	.desktop-on, 
	.tablet-off, 
	.phone-off {
		display: block;
	}
}
/* Tablets */
@media 
only screen and (min-width : 600px) and (max-width : 879.9px) {
	.tablet-off,
	.desktop-on, 
	.phone-on {
		display: none;
	}
	.tablet-on,
	.desktop-off, 
	.phone-off {
		display: block;
	}
}
/* Mobile */
@media 
only screen and (min-width : 220px) and (max-width : 599.9px) {
	.phone-off,
	.desktop-on, 
	.tablet-on
	 {
		display: none;
	}
	.phone-on, 
	.desktop-off, 
	.tablet-off {
		display: block;
	}
}

/*********
Allgemeine Content Styles
*********/
h1, h2, h3, p {
	margin: 0;
	padding: 0;
}

h1 {
    font-family: "proxima-nova-condensed-semibold";
	font-size: 2rem;
	font-weight: normal;
	color: rgb(192, 0, 0);
	margin-bottom: 30px;
    text-transform: uppercase;
}

h2 {
    font-family: "proxima-nova-condensed-semibold";
	font-size: 1.7rem; /* 30px 32/16 = 2 */
	font-weight: normal;
    text-transform: uppercase;
	color: #000;
	margin-bottom: 10px;
	margin-top: 60px;
}

p + h3 {
    margin-top: 25px;
}

h3 {
    font-family: "proxima-nova-condensed-semibold";
	font-size: 1.5rem;
    color: rgb(192, 0, 0);
	margin-bottom: 10px;
	margin-top: 0px;
}

h4 {
	font-size: 1.5rem;
    font-weight: bold;
    color: #000;
	margin-bottom: 10px;
	margin-top: 0px;
	text-transform: uppercase;
}

h2:first-child, 
h3:first-child {
	margin-top: 0;	
} 

p {
	font-size: 1.5rem; /* 12px 12/16 = 0.75 */
	margin-bottom: 15px;
}

p:last-child {
	margin-bottom: 0;
}

p#date-place {
	text-align: center;
	font-size: 2.4rem;
	font-weight: bold;
	text-transform: uppercase;
    color: #fff;
	text-shadow: rgba(0, 0, 0, 0.75) 2px 2px 10px, 
		rgba(0, 0, 0, 0.75) -2px 2px 10px, 
		rgba(0, 0, 0, 0.75) 2px -2px 10px, 
		rgba(0, 0, 0, 0.75) -2px -2px 10px; 
	/*text-shadow: #000 1px 1px, #000 -1px 1px, #000 1px -1px, #000 -1px -1px;*/
	margin-bottom: 10px;
	margin-top: 90px;
}

hr {
    border: 1.5px solid rgb(192, 0, 0);
    background-color: rgb(192, 0, 0);
    margin-top: 30px;
    margin-bottom: 30px;
}

ul li {
    list-style-type: none;
    margin-left: 0px;
    font-size: 1.5rem;
    padding-left: 20px;
}

ul li::before {
    content: '-';
    padding-right: 10px;
    margin-left: -16px;
}

ul.cards li::before {
	content: '';
	padding: 0;
	margin: 0;
}

ul.cards {
	display: flex;
	flex-wrap : wrap;
	gap: 40px 20px;
}

ul.cards li {
	display: flex;
	flex-direction: column;
	margin: 0;
	padding: 0;
	width: calc((100% - 3 * 20px) / 4);
}

ul.cards li h3 {
	margin-top: 5px;
	margin-bottom: 5px;
	color: #000000;
}

ul.cards li h3 span {
	font-family: "proxima-nova-condensed-light", Helvetica, Arial, sans-serif;
	color: #000000;
}

ul.cards li img {
	border: 1.5px solid #000;
	width: 100%;
	height: auto;
}

div.inline {
    margin-bottom: 20px;
}

div.inline * {
    display: inline;
}

span.bold, p.bold {
    font-family: "proxima-nova-condensed-semibold";
}

address {
	font-style: normal;
}

img {
	border: 0;
}

img.full {
	width: 100%;
	height: auto;
	display: block;
}

.img-right {
	float: right;
	margin-left: 15px;
	margin-bottom: 15px;
}

.img-left {
	float: left;
	margin-right: 15px;
	margin-bottom: 15px;
}

@media 
only screen and (min-width : 220px) and (max-width : 599.9px) {
	.img-right {
		float: none;
		display: block;
		width: 100%;
		margin-left: 0px;
	}
	.img-left {
		float: none;
		display: block;
		width: 100%;
		margin-right: 0px;
	}
}

ul, ol {
	padding: 0;
	margin: 0;
	margin-bottom: 15px;
} 

li {
	padding-bottom: 10px;
	padding-left: 0px;
	margin-left: 15px;
	list-style-type: disc;
	font-size: 1rem; /* 12px 12/16 = 0.75 */
}

ol li {
	list-style-type: decimal;
}

/*Links*/
a {
	color: #000;
	text-decoration: underline;
}

a:hover {
	color: #333;
	text-decoration: none;
}

a[href^="mailto:"],
a[href^="tel"] {
	color: #000;
}

img.sold-out {
	height: 55.6px;
	float: right;
}

@media 
only screen and (max-width : 800px) {
	img.sold-out {
		height: 44.0833px;
	}
}

/* Buttons */
.btn a {
	display: block;
	padding: 14px 10px;
	background: rgb(192, 0, 0);
	color: #fff;
	text-align: center;
	text-decoration: none;
	transition: all .5s;
}

@media 
only screen and (max-width : 800px) {
	.btn a {
		padding: 11px 8px;
	}
}

.btn a:hover {
	background: #333;
}

.btn.inline a {
	display: inline-block;
}

.btn.inline.right {
	float: right;
}


/*********
Raster-Styles
*********/
body {
	font-size: 100%; /* 16px = 1rem */
    overflow: visible;
/*	height: 100%;*/
}

body, img, p, tr, td {
	color: #000;
}

header {
	height: 40vh;
	min-height: 350px;
	position: relative;
	background-image: url(../img/layout/header.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position:  center center;
	display: grid;
}

.sponsor-grid {
	margin-bottom: 75px;
    display: grid;
    grid-template-columns: 9% repeat(5, 7%);
    column-gap: 10px;
    row-gap: 10px;
}

.sponsor-grid a {
	display: inherit;
	align-self: end;
}

.sponsor-grid a img {
	background-color: #fff;
    border: 1.5px solid #000;
}

.infos-site header {
	background-image: url(../img/layout/header-infos.jpg);
}

.daten-tickets-site header {
	background-image: url(../img/layout/header-daten-tickets.jpg);
}

.partner-site header {
	background-image: url(../img/layout/header-partner.jpg);
}

.logo {
	position: absolute;
	width: 300px;
	margin-top: 50px;
	z-index: 110;
	filter: drop-shadow(0 0 8px rgba(0, 0, 0, .75));
}

.header-image {
	display: none;
}

@media 
only screen and (max-width : 1200px) {
	header {
		height: calc((100vw - 18px) / 3 * 2);
	}

	.logo {
		width: 220px;
		margin-top: 20px;
	}

	.header-image {
		display: block;
		width: 100%;
		height: auto;
		position: absolute;
		z-index: -1;
	}
}

.content-block-center {
	width: 100%;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}

.content {
    padding-top: 50px;
    padding-bottom: 50px;
}

div.list-grid {
    display: grid;
    grid-template-columns: 200px auto;
    row-gap: 20px;
}

div.getraenke-grid {
    display: grid;
    grid-template-columns: 50% 25% 25%;
    max-width: 700px;
    margin-right: 100px;
    margin-bottom: 30px;
}

div.food-grid {
    display: grid;
    grid-template-columns: 75% 25%;
    max-width: 700px;
    margin-right: 100px;
}

div.glace-grid {
    display: grid;
    grid-template-columns: calc((100% - 100px)*0.75) calc((100% - 100px)*0.25) 100px;
    max-width: 800px;
}

div.getraenke-grid p,
div.food-grid p,
div.glace-grid p {
    margin-bottom: 0;
}

div.food-grid p.food-icon-container {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
}

div.food-grid img.food-icon {
    height: 1.5rem;
    padding-left: 10px;
}

div.getraenke-grid p:nth-child(3n),
div.food-grid p:nth-child(even),
div.glace-grid p:nth-child(2) {
    text-align: right;
}

div.glace-grid p#glace {
    font-size: 1rem;
    padding-left: 10px;
    /* margin-bottom: 15px; */
    align-self: center;
}

div.glace-grid span#glace-mobile {
    font-size: 1rem;
    display: none;
}

div.food-legende {
    display: grid;
    grid-template-columns: 30px 200px;
    align-items: center;
    column-gap: 5px;
    row-gap: 5px;
    margin-top: 20px;
}

div.food-legende img {
    width: 100%;
}

div.food-legende p {
    margin-bottom: 0;
    color: rgb(192, 0, 0);
}

.angebot-site p.bold {
    margin-bottom: 5px;
}

div.partner-grid {
    display: grid;
    grid-template-columns: repeat(5, calc((100% - 40px)/5));
    column-gap: 10px;
    row-gap: 10px;
}

div.partner-grid.sponsoren {
    grid-template-columns: repeat(6, calc((100% - 50px)/6));
}

div.partner-grid.presenting-partner {
    grid-template-columns: repeat(4, calc((100% - 30px)/4));
}

div.partner-grid.partner,
div.partner-grid.medienpartner {
    grid-template-columns: repeat(8, calc((100% - 140px)/8));
    column-gap: 20px;
    row-gap: 20px;
}

div.partner-grid.partner a,
div.partner-grid.medienpartner a {
	align-self: end;
}

/*
div.partner-grid > * {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
}
*/
div.partner-grid a {
	text-decoration: none;
}

div.partner-grid a img {
    display: block;
    max-width: 100%;
    max-height: 100%;
}

div.partner-grid a div {
	margin-top: -19px;
	text-align: center;
	color: grey;
	font-size: 85%;
}

div.partner-grid.presenting-partner a img,
div.partner-grid.hauptsponsoren a img,
div.partner-grid.sponsoren a img {
    border: 1.5px solid rgb(192, 0, 0);
}

span.highlight {
	color: rgb(192, 0, 0);
}

ul.lines li:first-child {
	border-top: 1.5px solid #c20000;
}

ul.lines li {
	border-bottom: 1.5px solid #c20000;
	padding-top: 10px;
}

@media 
only screen and (max-width : 800px) {
	.sponsor-grid {
		margin-bottom: 20px;
		grid-template-columns: 17% repeat(5, 14%);
	}

	div.partner-grid {
		grid-template-columns: repeat(3, calc((100% - 20px)/3));
	}

	div.partner-grid.presenting-partner {
		grid-template-columns: repeat(2, calc((100% - 10px)/2));
	}

	div.partner-grid.sponsoren {
		grid-template-columns: repeat(4, calc((100% - 30px)/4));
	}
	
	div.partner-grid.partner,
	div.partner-grid.medienpartner {
		grid-template-columns: repeat(5, calc((100% - 80px)/5));
	}
    
    div.list-grid {
        grid-template-columns: 1fr;
        row-gap: 0;
    }
    
    div.list-grid p.bold {
        margin-top: 15px;
        margin-bottom: 5px;
    }
    
    h1 {
        font-size: 1.5rem;
        margin-bottom: 0;
    }

    h2 {
        font-size: 1.3rem;
    }

    h3 {
        font-size: 1.2rem;
    }

    h4 {
        font-size: 1.2rem;
    }

    p, li {
        font-size: 1.2rem !important;
    }
    
    div.glace-grid p#glace {
        display: none;
    }
    
    div.glace-grid span#glace-mobile {
        display: block;
    }
    
    div.getraenke-grid, div.food-grid {
        margin-right: 0;
    }
    
    div.glace-grid {
        grid-template-columns: 75% 25%;
    }

	ul.cards li {
		width: calc((100% - 1 * 20px) / 2);
	}
}

@media 
only screen and (min-width : 600px) and (max-width : 1108px) {
	.content-block-center {
		margin-left: 45px;
		margin-right: 45px;
		width: auto;
	}
}

@media 
only screen and (min-width : 220px) and (max-width : 599.9px) {
	body {
		font-size: 90%; 
	}
	.content-block-center {
		margin-left: 20px;
		margin-right: 20px;
		width: auto;
	}
	div.partner-grid {
		grid-template-columns: repeat(2, calc((100% - 10px)/2));
	}

	div.partner-grid.presenting-partner {
		grid-template-columns: repeat(1, calc((100% - 0px)/1));
	}

	div.partner-grid.sponsoren {
		grid-template-columns: repeat(3, calc((100% - 20px)/3));
	}
	
	div.partner-grid.partner,
	div.partner-grid.medienpartner {
		grid-template-columns: repeat(4, calc((100% - 60px)/4));
	}

	.mobile-break:before {
		content: "";
	}
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : landscape) {
}

footer {
	position: relative;
	padding-top: 20px;
    padding-bottom: 20px;
	width: 100%;
}

footer p {
    font-size: 1rem;
    margin-bottom: 0;
}

footer a[href^="mailto:"],
footer a[href^="tel"] {
	color: #fff;
	text-decoration: none;
}

footer .logo-khur {
	width: 100px;
}

.skipp {
	position: absolute;
	right: 23px;
	bottom: 23px;
}

.skipp img {
	display: block;
	/* IE 8 */
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
	/* IE 5-7 */
	filter: alpha(opacity=70);
	/* Netscape/FireFox */
	-moz-opacity: 0.7;
	/* Safari 1.x */
	-khtml-opacity: 0.7;
	/* aktuelle Browser */
	opacity: 0.7;
}

/*********
Tools & spezifische Content-Styles
*********/
a {
    color: rgb(192, 0, 0);
}

ul.list {
	margin: 0;
	padding: 0;
	overflow: hidden;
}

.list > li {
	margin: 0;
	padding: 0;
	list-style-type: none;
	margin-right: 0%;
	margin-bottom: 3.5%;
}

.list > li::before {
	content: none;
	padding-right: 0;
	margin-left: 0;
}

.list > li a {
	text-decoration: none;
	display: block;
}

.list.vier-spalten > li {
	width: 22.375%;
	margin-right: 3.5%;
	margin-bottom: 3.5%;
	float: left;
}

.list.zwei-spalten.no-padding > li:nth-last-child(2) {
	margin-bottom: 0;
}

.list.drei-spalten > li {
	width: 31%;
	margin-right: 3.5%;
	margin-bottom: 3.5%;
	float: left;
}

.list.zwei-spalten > li, 
.list.zwei-spalten.news.front > li {
	width: 48.25%;
	margin-right: 3.5%;
	margin-bottom: 3.5%;
	float: left;
}

.list.vier-spalten > li:nth-child(4n),
.list.drei-spalten > li:nth-child(3n), 
.list.zwei-spalten > li:nth-child(2n), 
.list.zwei-spalten.news.front > li:nth-child(2n) {
	margin-right: 0;
}

@media 
only screen and (min-width : 600px) and (max-width : 879.9px) {
	.list.vier-spalten > li, 
	.list.vier-spalten > li:nth-child(4n), 
	.list.drei-spalten > li, 
	.list.drei-spalten > li:nth-child(3n) {
		width: 48.25%;
		margin-right: 3.5%;
	}
	.list.vier-spalten li:nth-child(2n), 
	.list.drei-spalten li:nth-child(2n) {
		margin-right: 0;
	}
	
}

@media 
only screen and (min-width : 220px) and (max-width : 599.9px) {
	.list.zwei-spalten > li, 
	.list.zwei-spalten.news.front > li, 
	.list.zwei-spalten > li:nth-child(2n), 
	.list.zwei-spalten.news.front > li:nth-child(2n),
	.list.drei-spalten > li, 
	.list.drei-spalten > li:nth-child(3n), 
	.list.drei-spalten > li:nth-child(2n), 
	.list.vier-spalten > li, 
	.list.vier-spalten > li:nth-child(4n), 
	.list.vier-spalten > li:nth-child(2n) {
		width: 100%;
		margin-right: 0%;
		float: none;
		display: block
	}
}

/*********
Accordion und Tab/Register
*********/
.ui-corner-all, 
.ui-corner-top, 
.ui-corner-left, 
.ui-corner-tl,
.ui-corner-bottom {
	border-top-right-radius: 0px;
	border-top-left-radius: 0px;
	border-bottom-right-radius: 0px;
	border-bottom-left-radius: 0px;
}

.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover,
.ui-state-active:focus {
	border:none;
	background:#C00003;
	font-weight:normal;
	color:#fff;
	outline: none;
}

.ui-tabs {
    padding: 0;
}

.ui-tabs .ui-tabs-nav {
    border: none;
	border-bottom: 1px solid #ddd;
}


.accordion {
	margin-bottom: 20px;
}

.accordion h3 {
	outline: none;
}

.accordion .ui-icon, 
.accordion .ui-widget-header .ui-icon, 
.accordion .ui-state-hover .ui-icon, 
.accordion .ui-state-focus .ui-icon, 
.accordion .ui-button:hover .ui-icon, 
.accordion .ui-button:focus .ui-icon, 
.accordion .ui-state-highlight .ui-icon, 
.accordion .ui-button .ui-state-highlight.ui-icon, 
.accordion .ui-state-error .ui-icon, 
.accordion .ui-state-error-text .ui-icon, 
.accordion .ui-button .ui-icon, 
.accordion .ui-icon, 
.accordion .ui-widget-header .ui-icon, 
.accordion .ui-state-hover .ui-icon, 
.accordion .ui-state-focus .ui-icon, 
.accordion .ui-button:hover .ui-icon, 
.accordion .ui-button:focus .ui-icon, 
.accordion .ui-state-highlight .ui-icon, 
.accordion.service .ui-button .ui-state-highlight.ui-icon, 
.accordion.service .ui-state-error .ui-icon, 
.accordion.service .ui-state-error-text .ui-icon, 
.accordion.service .ui-button .ui-icon {
	/*background-image: url(../img/layout/skipp-anker.svg);
	background-size: 10px;
	background-position: 0px 3px;*/
	outline: none;
}

.accordion .ui-state-active .ui-icon, 
.accordion .ui-button:active .ui-icon, 
.accordion .ui-state-active .ui-icon, 
.accordion .ui-button:active .ui-icon {
	/*background-image: url(../img/layout/skipp-anker-weiss.svg);*/
	outline: none;
}

/*********
Navigation
*********/
div.nav-background {
    background-color: #000;
	position: absolute;
	bottom: 0;
	width: 100%;
}

.main-nav ul {
	margin: 0;
	padding: 0;
	overflow: hidden;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.main-nav ul li {
	margin: 0;
	padding: 0;
	list-style-type: none;
	float: left;
}

.main-nav li::before {
    content: none !important;
}

.main-nav li a {
	display: block;
	background: #000;
	padding: 0px;
    margin: 15px;
	color: #fff;
	font-size: 1.5rem;
	text-decoration: none;
    text-transform: uppercase;
    
    position: relative;
}

.main-nav li:first-of-type a {
    margin-left: 0;
}

.main-nav li:last-of-type a {
    margin-right: 0;
}

.main-nav li a::after {
    content: '';
    position: absolute;
    height: 2px;
    width: 100%;
    left: 0;
    bottom: 0;
    opacity: 0;
    transform: translateY(3px);
    background: rgb(192, 0, 0);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.main-nav li a.active::after,
.main-nav li a:hover::after {
    opacity: 1;
    transform: translateY(0);
}

/*********
Sub-Navigation (DropDown)
*********/
.main-nav ul ul {
	clear: both;
	display: none;
}

.main-nav ul li:hover ul {
	display: block;
	position: absolute;
	text-align: left;
	z-index: 50;
}

.main-nav ul ul li {
	clear: both;
	display: block;
}

.main-nav ul li ul li a {
	background-color: #333333;
}

.main-nav ul li ul li a.active,
.main-nav ul li ul li a:hover {
	background-color: #92150d;
}


/*********
Tabellen
*********/
table, tbody, thead {
	width: 100%;
	padding: 0;
	margin: 0;
	border: 0px;
	margin-bottom: 15px;
}

tr, td, th {
	border: 0px;
}

tr {
	padding: 0px;
	margin: 0px;
}

tr:hover {
	background-color: #A4A4A4;
}

th {
	padding: 8px;
	border-bottom: 1.5px solid #000;
	vertical-align: top;
	text-align: left;
	color: #fff;
	font-weight: bold;
	background-color: #333;
}


td {
	margin: 0;
	padding: 8px;
	border-bottom: 1.5px dotted #000;
	vertical-align: top;
	text-align: left;
}

/*********
Formulare
*********/
form {
	overflow: hidden;
}

fieldset {
	border: 0;
	margin: 0;
	padding: 0;
}

form p {
	padding-bottom: 10px;
}

legend {
	padding: 0;
	margin: 0;
	margin-bottom: 7px;
	font-size: 1rem;
	text-transform: uppercase;
}

label {
	display: block;	
	margin-bottom: 5px;
}

label.inline {
	display: inline;
}

input, 
select, 
textarea {
	background-color: #A4A4A4;
	color: #000;
	border: 0;
	padding: 8px;
	width: 100%;
	margin-bottom: 8px;
}

/* Autocomplete Chrome*/
input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus
input:-webkit-autofill, 
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  border: 0;
  -webkit-text-fill-color: #000;
  -webkit-box-shadow: 0 0 0 0 #000 inset;
  transition: background-color 5000s ease-in-out 0s;
}

input, 
textarea {
	width: 90%;
	width: calc(100% - 16px);
}

textarea {
	height: 120px;
}

input:focus {
	/*border-color: #2A8E01;*/
}

input[type="checkbox"], 
input[type="radio"] {
	width: auto;
	margin-right: 5px;
	border: 0;
}

input[type="checkbox"] {
	border: 0;
	background: #fff;
	padding: 0px;
}

input[type="submit"], 
button[type="submit"] {
	width: 100%;
	background: #333;
	color: #fff;
}

input[type="submit"]:hover {
}

input.pflicht, 
textarea.pflicht {
	/*border-right: 3px solid #000;*/
}

.validationerror {
	background: #CB0003;
	color: #fff;
	padding: 8px;
	margin-bottom: 1px;
	width: 100%;	
}

@media 
only screen and (min-width : 220px) and (max-width : 879.9px) {
	input, 
	select,
	textarea,
	input[type="submit"],
	button[type="submit"],
	input[type="submit"]:hover, 
	.validationerror
	 {
		width: 90%;
		width: calc(100% - 16px);
	}

	input, 
	select, 
	input[type="submit"],
	button[type="submit"],
	input[type="submit"]:hover {
		width: 100%;
	}
}

/*********
Masonry Box-System
*********/
.masonry-box {
	overflow: hidden;
	margin: 0;
	padding: 0;
}

.masonry-box .box-item {
	margin-bottom: 35px;
	
}

/* Salvattore - Masonry */
/* These are the classes that are going to be applied: */
.masonry-box .column { 
	float: left;
}

.masonry-box .size-1of4, 
.masonry-box .size-1of3, 
.masonry-box .size-1of2 { 
	margin: 0;
	padding: 0;
	float: left;
	width: 22.375%;
	margin-right: 3.5%;
}

.masonry-box .size-1of3 { 
	width: 31%;
}

.masonry-box .size-1of2 {
	width: 48%;
	margin-right: 4%;
}

.masonry-box .size-1of1 {
	width: 100%;
	margin-right: 0;
}

.masonry-box .size-1of4:nth-child(4n), 
.masonry-box .size-1of3:nth-child(3n), 
.masonry-box .size-1of2:nth-child(2n) {
	margin-right: 0;
}

@media screen and (min-width: 880px) and (max-width: 5000px) {
	.masonry-box[data-columns]::before {
		content: '3 .column.size-1of3';
	}
	.vier-spalten.masonry-box[data-columns]::before {
		content: '4 .column.size-1of4';
	}
}
@media screen and (min-width: 600px) and (max-width: 879.9px) {
	.masonry-box[data-columns]::before {
		content: '2 .column.size-1of2';
	}
}
@media screen and (max-width: 599.9px){
	.masonry-box[data-columns]::before {
		content: '1 .column.size-1of1';
	}
}
