*, *:before, *:after {
	box-sizing: border-box;
}
html, body {
	font-family: Arial, sans-serif;
	color: #20242B;
}
body {
	margin: 0;
	padding: 0;
	overflow-x: hidden;
}
.header {
	position: relative;
	padding-bottom: 40px;
}
.header .logo-holder {
	position: relative;
	max-width: 790px;
	margin: 0 auto;
	padding: 0 20px;
}

.header .header-wrapper {
	position: relative;
}
.header .header-wrapper .content-background {
	height: 100%;
	position: absolute;
	width: 50%;
	background: #EEEFF0;
}
.header .header-wrapper .image-background {
	background: url(https://fil-fondsbank.inxshare.com/anmeldeformulare/ffb_roadshow-anmeldung_header_neu.jpg) no-repeat;
	position: absolute;
	width: 50%;
	height: 100%;
	right: 0;
	/*background-repeat: no-repeat;*/
	background-position: 50%;
	background-size: cover;
}
.header .header-wrapper .content {
	position: relative;
	max-width: 790px;
	margin: 0 auto;
}
.header .header-wrapper .content-left {
	position: relative;
	background: #EEEFF0;
	z-index: 1;
	padding: 42px 50px 42px 20px;
	box-sizing: border-box;
	max-width: 50%;
}
.header .header-wrapper .content-left:after {
	content: ' ';
	position: absolute;
	background: #EEEFF0;
	width: 210%;
	height: 100%;
	top: 0;
	right: -60px;
	z-index: -1;
	transform: skewX(-15deg);
	/*transform-origin: top right;*/
	/* right: -30%; */
	transform-origin: right;
}
.header .header-wrapper h1 {
	width: 100%;
	height: auto;
	background: transparent;
	color: #20242B;
	padding: 0;
	margin-bottom: 25px;
}
.header .header-wrapper h1:after {
	content: none;
}
.header .header-wrapper p {
	margin: 0;
}

@media screen and (max-width: 767px) {
	.header .header-wrapper .content-background {
		display: none;
	}
	.header .header-wrapper .image-background {
		position: relative;
		width: 100%;
		height: auto;
		padding-bottom: 66.6666666%;
	}
	.header .header-wrapper .content-left {
		max-width: 100%;
	}
	.header .header-wrapper .content-left:after {
		content: none;
	}
}


.header .tooltip {
	position: absolute;
	right: 30px;
	top: calc(100% + 50px);
	padding: 28px 30px;
	width: 360px;
	border: 1px solid #DCDEE1;
	border-radius: 4px;
	text-align: center;
}
.header .tooltip:after {
	bottom: 100%;
	left: 50%;
	border: 16px solid transparent;
	border-bottom-color: #F5F5F5;
	/*content: " ";*/
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	margin-left: -16px;
}
.header .tooltip h3 {
	font-size: 16px;
	line-height: 24px;
	/*color: #333333;*/
	margin: 0 0 10px 0;
	position: relative;
	padding-bottom: 20px;
}
.header .tooltip h3:after {
	display: block;
	position: absolute;
	left: 50%;
	margin-left: -1.5625rem;
	bottom: 0;
	content: "";
	height: 2px;
	width: 31px;
	background-color: #016195;
}
.header .tooltip p {
	font-size: 15px;
	line-height: 26px;
	/*color: #333333;*/
	margin: 0;
}

@media screen and (max-width: 767px) {
	.header .tooltip {
		position: relative;
		right: initial;
		top: initial;
		max-width: calc(100% - 40px);
		width: 100%;
		margin: 30px 20px 0 20px;
	}
}

#logo {
	margin: 60px 0 52px 0;
}

@media screen and (max-width: 767px) {
	#logo {
		margin: 20px 0 20px 0;
	}
}

#visual {
	width: 100%;
	margin: 0 0 30px 0;
}

h1 {
	width: 569px;
	max-width: 100%;
	height: 74px;
	background-color: #006193;
	position: relative;
	color: #ffffff;
	font-size: 28px;
	line-height: 32px;
	font-weight: bold;
	padding: 21px 30px;
	margin-top: 0;
	margin-bottom: 30px;
}

h1:after {
	content: '';
	position: absolute;
	display: block;
	top: 0;
	bottom: 0;
	line-height: 0;
	box-sizing: border-box;
	width: 34px;
	right: -18px;
	margin-right: 18px;
	border-bottom: 74px solid #ffffff;
	border-left: 34px solid transparent;
	border-top: 0;
	border-right: 0;
}

@media screen and (max-width: 480px) {
	h1 {
		height: auto;
		font-size: 24px;
		line-height: 28px;
		padding: 21px 30px 21px 20px;
	}
	h1:after {
		border-bottom-width: 98px;
	}
}

h2 {
	font-size: 20px;
	margin-bottom: 32px;
}

p {
	font-size: 16px;
	line-height: 24px;
	color: #20242B;
}
a {
	color: #00A6E3;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

ul {
	padding-left: 20px;
}
ul li {
	font-size: 16px;
	line-height: 26px;
}

input[type="radio"], input[type="checkbox"], .reset_button {
	display: none !important;
}


form.inxform {
	position: relative;
	max-width: 790px;
	padding: 10px 20px 0 20px;
	margin: 0 auto 70px auto;
}

form.inxform > div {
	margin-bottom: 6px;
}
form.inxform > div > label {
	margin-bottom: 4px;
}

form.inxform .heading {
	position: relative;
	padding-bottom: 30px;
	font-size: 28px;
	line-height: 26px;
	margin-bottom: 40px;
	font-weight: bold;
}

form.inxform .heading:after {
	display: block;
	position: absolute;
	bottom: 0;
	content: "";
	height: 4px;
	width: 64px;
	background-color: #016195;
}

label {
	font-size: 16px;
	line-height: 24px;
}
.error:not(.focus) > label {
	color: #EE3127;
}
.error:not(.focus) > input[type="text"] {
	border: 2px solid #EE3127;
}

.message_missing {
	display: none;
	position: relative;
	font-size: 16px;
	line-height: 24px;
	background-color: #006193;
	color: #ffffff;
	padding: 20px;
	text-align: center;
}
.message_missing:before {
	content: "";
	display: block;
	position: absolute;
	width: 0;
	height: 0;
	border-left: 15px solid transparent;
	border-right: 15px solid transparent;
	border-bottom: 15px solid #006193;
	top: -15px;
	left: 5%;
}
.message_missing > span > span {
	display: none;
	color: #ffffff;
}

.message_missing.show,
.message_missing .empty.show,
.message_missing .emailformat.show {
	display: block;
}

.message_missing span.show + span.show {
	margin-top: 5px;
}

.submit_validator_wrapper {
	margin-top: 40px;
}

div.listfield, div.textfield, div.textarea, div.passfield, div.paragraph, div.radiobutton, div.checkboxfield, div.submit, div.subscription {
	display: block;
}

form > .radiobutton,
form > .radiobutton > .radiobutton:nth-child(2),
form > .radiobutton > .radiobutton:nth-child(3) {
	display: inline-block;
}
form > .radiobutton > .radiobutton:nth-child(1) > label {
	margin-bottom: 10px;
}
form > .radiobutton > .radiobutton:nth-child(2) > label,
form > .radiobutton > .radiobutton:nth-child(3) > label {
	display: inline-block;
	cursor: pointer;
	position: relative;
	padding-left: 46px;
	margin-right: 15px;
}

form > .radiobutton > .radiobutton:nth-child(2) > label:after,
form > .radiobutton > .radiobutton:nth-child(3) > label:after {
	border: 1px solid #B0B0AF;
	content: "";
	display: block;
	position: absolute;
	top: -1px;
	left: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #fff;
	-moz-transition: all .2s ease-in;
	-o-transition: all .2s ease-in;
	-webkit-transition: all .2s ease-in;
	transition: all .2s ease-in;
}

.radiobutton.checked > label:before {
	content: '';
	position: absolute;
	top: 7px;
	left: 8px;
	width: 12px;
	height: 12px;
	z-index: 1;
	border-radius: 100%;
	background: #006193;
}


.checkboxfield {
	display: block !important;
}
.checkboxfield label {
	display: inline-block;
	cursor: pointer;
	position: relative;
	padding-left: 46px;
	margin-right: 15px;
}

.checkboxfield label:after {
	content: "";
	display: block;
	position: absolute;
	top: -1px;
	left: 0;
	width: 28px;
	height: 28px;
	background: #fff;
	border: 1px solid #DCDEE1;
	-moz-transition: all .2s ease-in;
	-o-transition: all .2s ease-in;
	-webkit-transition: all .2s ease-in;
	transition: all .2s ease-in;
}

.checkboxfield.checked label:before {
	content: '';
	display: block;
	position: absolute;
	width: 13px;
	height: 10px;
	top: 8px;
	left: 7px;
	z-index: 1;
	background-image: url('https://fil-fondsbank.inxshare.com/anmeldeformulare/haken.png');
}
.textfield + .checkboxfield {
	margin-top: 45px;
}
.checkboxfield + .checkboxfield {
	margin-top: 32px;
}
.radiobutton + .textfield {
	margin-top: 10px;
}

.textfield label {
	margin-bottom: 2px;
}

input[type="text"] {
	display: block;
	box-sizing: border-box;
	width: 100%;
	height: 41px;
	margin: 0 0 1rem;
	padding: 8px;
	border-radius: 0;
	background-color: #fff;
	/*box-shadow: inset 0 1px 2px rgba(0,0,0,.1);*/
	font-size: 16px;
	font-weight: normal;
	line-height: 1.45;
	color: #333333;
	transition: box-shadow .5s,border-color .25s ease-in-out;
	appearance: none;
	border: 1px solid #DCDEE1;
}
input[type="text"]:focus {
	outline: 0;
	border: 1px solid #8a8a8a;
	background-color: #fff;
	/*box-shadow: inset 0 1px 2px rgba(0,0,0,.1);*/
	transition: box-shadow .5s,border-color .25s ease-in-out;
}

input[type="submit"] {
	display: inline;
	/*width: 151px;*/
	height: auto;
	padding: 16px 24px;
	cursor: pointer;
	transition: background-color .15s ease-out, color .15s ease-out, border-color .15s ease-out;
	white-space: nowrap;
	color: #20242b;
	/*background: url('https://extern.bippesbrandao.de/ffb/anmeldeseiten/arrowBtn.png') no-repeat #006193;*/
	/*background-position: 87% 11px;*/
	background-color: #82c823;
	font-size: 16px;
	line-height: normal;
	border: none;
	outline: 0;
	appearance: none;
}

input[type="submit"]:hover {
	text-decoration: none;
	/*color: #FFFFFF;*/
	background-color: #a2d830;
}

.listfield select {
	display: block;
	box-sizing: border-box;
	width: 50%;
	height: 41px;
	margin: 0 0 1rem;
	padding: 8px;
	border-radius: 0;
	background-color: #fff;
	/* box-shadow: inset 0 1px 2px rgb(0 0 0 / 10%); */
	font-size: 16px;
	font-weight: normal;
	line-height: 1.45;
	color: #333333;
	transition: box-shadow .5s,border-color .25s ease-in-out;
	border: 1px solid #DCDEE1;
	outline: none;

	background-image: url('https://fil-fondsbank.inxshare.com/anmeldeformulare/pfeil.svg');
	background-repeat: no-repeat;
	background-position-x: 96%;
	background-position-y: 50%;

	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	-ms-appearance: none !important;
	-o-appearance: none !important;
	appearance: none !important;
}

.listfield select::-ms-expand {
	display: none;
}

.listfield select[multiple] {
	display: block;
	box-sizing: border-box;
	width: 50%;
	height: auto;
	margin: 0 0 1.5rem;
	padding: 0;
	border-radius: 0;
	background-color: #fff;
	/* box-shadow: inset 0 1px 2px rgb(0 0 0 / 10%); */
	font-size: 16px;
	font-weight: normal;
	line-height: 1.45;
	color: #333333;
	transition: box-shadow .5s,border-color .25s ease-in-out;
	appearance: none;
	overflow-y: auto;
	border: 1px solid #DCDEE1;
	background-image: none;
}

.listfield select[multiple] option {
	padding: 8px;
}

.listfield select[multiple] option:not(:last-child) {
	border-bottom: 1px solid #DCDEE1;
}

@media screen and (max-width: 520px) {
	.listfield select,
	.listfield select[multiple] {
		width: 100%;
	}
}

.submit {
	margin-top: 26px;
}

.disclaimer {
	font-size: 14px;
	line-height: 22px;
}

.disclaimer .inner {
	max-width: 790px;
	margin: 0 auto;
	padding: 0 20px;
}
.disclaimer > .inner {
	margin-bottom: 46px;
}
.footer .inner:after, .footer .right:after {
	display: block;
	content: "";
	clear: both;
}

.footer {
	background: #F5F5F5;
	margin-top: 66px;
}
.footer > div {
	padding: 21px 0;
}
.footer .inner {
	padding: 32px 20px 20px 20px;
}

.footer .footer-menu {
	display: flex;
}
@media screen and (max-width: 520px) {
	.footer .footer-menu {
		flex-direction: column;
	}
}
.footer .footer-menu > div {
	flex: 1 1 0px;
}
.footer .footer-menu h2 {
	font-size: 28px;
	line-height: 26px;
	color: #20242B;
	border-bottom: 1px solid #DCDEE1;
	padding-bottom: 20px;
	margin: 10px 20px 20px 0;
}
.footer .footer-menu ul li {
	float: none;
	padding-bottom: 5px;
}
.footer .footer-menu ul li a {
	float: none;
	font-size: 16px;
	line-height: 24px;
	color: #016fad;
}

.footer .footer-bottom {
	background-color: #414956;
	padding: 0;
}
.footer .footer-bottom .footer-bottom-content {
	max-width: 790px;
	margin: 0 auto;
	padding: 14px 20px;
}
.footer .footer-bottom .footer-bottom-content p {
	font-size: 16px;
	line-height: 22px;
	color: #ffffff;
	font-weight: bold;
	margin: 0;
}

.footer a {
	float: left;
	display: block;
	font-size: 15px;
}
.footer a + a:before {
	content: '';
	border-left: 1px solid #979DA6;
	margin: 0 8px;
	padding: 2px 0;
}

.footer ul {
	margin: 0;
	padding: 0 0 20px 0;
}
.footer ul li {
	list-style: none;
	float: left;
	margin-right: 12px;
}
.footer ul li a, .footer p {
	font-size: 13px;
	line-height: 23px;
	color: #333333;
}
.footer ul:after, .footer ul:after {
	display: block;
	content: "";
	clear: both;
}

@media screen and (max-width: 480px) {
	.footer ul {
		padding: 0 0 20px 0;
	}
	.footer ul li {
		display: block;
		width: 100%;
	}
}
