/*	New Landingpage	---------------------------------------------------------------------------------------------------- */

section.wide {
	width:100%;
	padding:0 !important;
	margin:0 auto !important;
	max-width:1024px;
    box-sizing: border-box;
}
section.wide article {
	display:block;
	width:100%;
	float:none;
	margin:20px auto;
	padding:20px 0 !important;
    box-sizing: border-box;
}
section.wide article h3.tagline {
	font-family: 'bold', Helvetica Neue, Arial, Helvetica, sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 1.375em;
	text-align: center;
	color: #666;
	width:100%;
	margin:0 auto 40px;
	padding:40px 0 !important;
	border-bottom: 1px solid #CCC;
    box-sizing: border-box;
}
section.wide article h3.tagline span {
	display: block;
	font-family: 'bold', Helvetica Neue, Arial, Helvetica, sans-serif;
	font-size: 0.875em;
	color: #999;
}
section.wide article:first-of-type {
	border-top:none;
}
section.wide article ul {
	margin:20px auto;
	max-width:800px;
}
section.wide article h1 {
	font-family: '55', Helvetica Neue, Arial, Helvetica, sans-serif;
	font-size: 2.5em;
	color: #951543;
	letter-spacing: .1em;
	text-transform: uppercase;
	margin: 0 auto;
	padding: 0 !important;
}
section.wide article h1 em {
	font-family: 'italic', Helvetica Neue, Arial, Helvetica, sans-serif;
	font-size: 1.5em;
	padding-left: 1.5em;
}
section.wide article h1 strong {
	font-family: 'bold', Helvetica Neue, Arial, Helvetica, sans-serif;
	font-size: 1.375em;
}
section.wide article h2 {
	font-size: 1.5em;
	margin-bottom: 20px;
}
section.wide article p {
	max-width:800px;
	margin:20px auto;
	padding:0;
}
section.wide article p em {
	color: #999;
}
div.ctas {
	display: block;
	margin:0 auto;
	padding:20px 0;
	text-align: center;
}
a.cta {
	width:auto;
	height:30px;
	margin:0 10px 10px 0;
	padding:10px 15px;
	color: #FFF;
	background-color: #006699;
	font-family: '55', Helvetica Neue, Arial, Helvetica, sans-serif;
	font-size: 1em;
	line-height:30px;
	text-align: center;
	-webkit-transition: .5s;
	transition: .5s;
}
a.cta:hover {
	background-color: #951543;	
	-webkit-transition: .5s;
	transition: .5s;
}


section.wide article.banner {
    width: 100%;
	background-color: #006699;
}
section.wide article.banner.grey {
	background-color: #999;
}
section.wide article.banner h2 {
	font-family: 'bold', Helvetica Neue, Arial, Helvetica, sans-serif;
	font-size: 2em;
	color: #FFF;
	border-bottom: 0.5px solid #FFF;
	padding:0 0 20px;
	text-align: center;
}
section.wide article.banner h3 {
	font-family: 'bold', Helvetica Neue, Arial, Helvetica, sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 1em;
	color: #999;
	background-color: #CCC;
	width: 100%;
	border: none;
	padding:10px 20px;
	margin:-20px auto 20px;
	text-align: left;
    box-sizing: border-box;
}
section.wide article.banner p {
	color: #FFF;
	max-width:800px;
	margin:20px auto;
	padding:0;
}
section.wide article.banner a.cta {
	color: #006699;
	background-color: #FFF;
	border: 1px solid #FFF;
}
section.wide article.banner a.cta:hover {
	color: #FFF;
	background-color: #951543;	
	border: 1px solid #FFF;
}

section.flex {
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    padding: 0;
    box-sizing: border-box;
}
section.flex article {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    width: 100%;
    margin: 0 auto;
	padding:20px 0 !important;
	border: none;
    box-sizing: border-box;
}
section.flex article div {
    display: flex;
    flex-direction: column;
    min-width: 0;
    background: transparent;
    box-sizing: border-box;
}
section.flex article div h3 {
    font-family: 'bold', Helvetica Neue, Arial, Helvetica, sans-serif;
    font-size: 1.125em;
    color: #FFF;
    background-color: #951543;
    text-align: center;
    padding: 10px;
    margin: 0;
    box-sizing: border-box;
}
section.flex article div > a {
    display: block;
    width: 100%;
    line-height: 0;
    margin: 0;
    padding: 0;
    background: #FFF;
}
section.flex article div > a img {
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    border: 1px solid #CCC;
    border-top: none;
    box-sizing: border-box;
}
section.flex article div p {
    padding: 10px;
    margin: 0;
    border: 1px solid #CCC;
    border-top: none;
    background: #FFF;
	font-size: 1em;
    box-sizing: border-box;
}
/* Textbereich gleicht die Höhe der Karten aus */
section.flex article div p:not(.link) {
    flex: 1;
}
/* Linkbereich unten */
section.flex article div p.link {
    background-color: #EEE;
	text-align: center;
}
/* WICHTIG: Links in p.link dürfen keine Bildbox-Eigenschaften bekommen */
section.flex article div p.link a {
    display: inline;
    width: auto;
    line-height: normal;
    background: transparent;
}

@media only screen and (max-width: 1960px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */

section.flex {
	max-width:100%;
}
}


@media only screen and (max-width: 1280px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */


section.wide article h1 {
	font-size: 2.25em;
}
section.wide article h2 {
	font-size: 1.375em;
}
section.wide article.banner h2 {
	font-size: 1.75em;
}

section.flex article div h3 {
    font-size: 1em;
}

section.flex article div p.link a {
	display: block;
	line-height: 0.75;
}
}

@media only screen and (max-width: 1064px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */
	
section.wide {
	padding:0 20px !important;
	max-width:100%;
}

section.wide article h3.tagline {
	font-size: 1.25em;
	letter-spacing: 0.025em;
}

section.wide article ul,
section.wide article p,
section.wide article.banner p {
	max-width:800px !important;
	padding:0 20px;
}

section.flex {
	padding:0 20px !important;
}

}


@media only screen and (max-width: 1024px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */



section.wide article h1 {
	font-size: 2.125em;
}
section.wide article h2 {
	font-size: 1.25em;
}
section.wide article.banner h2 {
	font-size: 1.5em;
}
section.wide article.banner h3 {
	font-size: 0.9375em;
}

section.wide article p {
	max-width:100%;
}

section.flex article {
	grid-template-columns: repeat(2, 1fr);
}
section.flex article div h3 {
    padding: 10px;
}
section.flex article div p.link a {
	display: inline-block;
	line-height: inherit;
}

}



@media only screen and (max-width: 880px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */

section.wide article h3.tagline {
	font-size: 1.125em;
	letter-spacing: 0;
	margin:0 auto 30px;
	padding:30px 0 !important;
}

section.wide article ul,
section.wide article p,
section.wide article.banner p {
	max-width:100% !important;
}

}


@media only screen and (max-width: 768px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */

section.wide article h3.tagline {
	font-size: 1em;
}

}


@media only screen and (max-width: 640px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */

section.wide {
	padding:0 10px !important;
}

section.wide article h3.tagline {
	margin:0 auto 20px;
	padding:20px 0 !important;
	text-align: left;
}
section.wide article h3.tagline span {
	display: inline;
	font-size: 1em;
}

section.wide article h1 {
	font-size: 2em;
}
section.wide article h2 {
	font-size: 1.125em;
}
section.wide article.banner h2 {
	font-size: 1.25em;
	padding:0 20px 20px !important;
}
section.wide article.banner h3 {
	font-size: 0.875em;
}

section.flex {
    max-width: 100%;
	padding:0 10px !important;
}
section.flex article {
	grid-template-columns: repeat(1, 1fr);
}
section.flex article div h3 {
    padding: 10px;
}
section.flex article div p {
	font-size: 0.9375em;
}

}


@media only screen and (max-width: 580px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */


section.wide article h1 {
	font-size: 1.875em;
	padding: 0 !important;
}
section.wide article h1 em {
	font-size: 1em;
	padding-left:0;
}
section.wide article h1 strong {
	font-size: 1em;
}
section.wide article h2 {
	font-size: 1.125em;
}
section.wide article ul,
section.wide article p {
	margin:0 auto !important;
	padding:0 10px;
}
a.cta {
	display: block;
	margin:0 10px 10px;
	padding:5px 10px;
}
section.wide article.banner h2 {
	font-size: 1.125em;
}
section.wide article.banner a.cta {
	color: #006699;
	background-color: #FFF;
}

}


@media only screen and (max-width: 400px) {

/*	New Landingpage	---------------------------------------------------------------------------------------------------- */

section.wide article {
	margin:20px auto !important;
	padding:20px 0 !important;
}
section.wide article h1 {
	font-size: 1.75em;
}
section.wide article h2 {
	font-size: 1em;
}
section.wide article ul,
section.wide article p {
	padding:0;
}
a.cta {
	margin:0 0 10px;
	padding:5px;
}
section.wide article.banner h2 {
	font-size: 1em;
	padding:0 10px 20px !important;
}
section.wide article.banner h3 {
	letter-spacing: 0.05em;
	padding:10px;
}
section.wide article.banner p {
	padding:0 10px;
}
section.wide article.banner a.cta {
	margin:0 10px 10px;
}

}