/* RWD Ausrichtung Formularfelder-Beschriftungen */
@media (min-width: 992px) {

	.form-label {
		width: 30%;
		float: left;
	}

	.form-field {
		width: 70%;
		float: left;
		position: relative;
	}

}

@media (max-width: 991px) {

	.form-label {
		width: 100%;
	}

	.form-field {
		width: 100%;
		position: relative;
	}

}
/* Ende RWD Ausrichtung Formularfelder-Beschriftungen */


/* Hinweistexte */
.form-success, .form-error {
	width: 100%;
	height: auto;
	display: block;
	color: #c00;
	font-weight: bold;
	font-size: 1em;
}

.form-alert {
	border: solid 2px #c00 !important;
}

.required-text {
	font-style: italic;
	font-size: 1em;
	color: #555;
}
/* Ende Hinweistexte */


/* Zusammenfassung form-label & form-field  */
.form-group {
	width: 100%;
	display: block;
	float: left;
	padding: 5px 0 5px 0;
	margin: 0 0 10px 0;
}
/* Ende Zusammenfassung form-label & form-field  */



/* Input, Textarea & Select Design  */
.form-control {
	/*
	width: 100%;
	padding: 10px 15px;
	outline: 0;
	border-radius: 0;
	background: #fff;
	color: #2A4194 !important;
	font-size: 1em;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	resize: none;
	border: 2px solid #2A4194;
	font-family: 'Source Sans 3',arial,sans-serif;
	*/
width: 100%;
padding: 8px 15px;
outline: 0;
border-radius: 0;
background: #F0F1F1;
color: #2A4194 !important;
font-size: .8em;
appearance: none;
-webkit-appearance: none;
-moz-appearance: none;
resize: none;
border: 1px solid #2A4194;
font-family: 'Source Sans 3',arial,sans-serif;
}

.form-control:hover, .form-control:focus  {
	/*
	background: #eee;
	color: #2A4194 !important;
	outline: 2px solid #2A4194;
	*/
background: #fff;
color: #2A4194 !important;
border: 1px solid #2A4194;
outline: 2px solid #2A4194 !important;
}

/* Ende Input, Textarea & Select Design  */



/* Submit-Button Design  */
input[type="submit"], .button-submit, .cta-link a:link, .cta-link a:visited, .cta-btn {
	font-family: 'Source Sans 3',arial,sans-serif;
	cursor: pointer;
	padding: 5px 15px 4px 15px;
	outline: 0;
	border: 5px solid #2A4194;
	border-radius: 0;
	background: #2A4194;
	color: #fff;
	font-size: 1em;
	line-height: 1.6875em;
	text-decoration: none;
	display: inline-block;
	text-align: center !important;
	font-weight: 600;
}

input[type="submit"]:hover, .button-submit:hover, .cta-link a:hover, .cta-link a:active, .cta-link a:focus, .cta-btn:focus, .cta-btn:hover {
	background: #2A4194;
	color: #FFCC01 !important;
	border: 5px solid #fff;
	outline: 2px solid #2A4194 !important;
}

input[type="submit"]:focus, .button-submit:focus {
	/*outline: 3px solid orange !important;*/
	background: #2A4194;
	color: #FFCC01 !important;
	border: 5px solid #fff;
	outline: 2px solid #2A4194 !important;
}

input[type="submit"]:disabled, button:disabled {
	background: #bbb !important;
	color: #2A4194 !important;
	cursor: default !important;
	border: 1px solid #bbb;
}
/* Ende Submit-Button Design  */



/* Buttons Spezial Anpassungen */
.button-red {
	background: #c00 !important;
	color: #fff !important;
}

.button-red:hover {
	background: #f00 !important;
	color: #fff !important;
}

.button-green {
	background: #090 !important;
	color: #fff !important;
}

.button-green:hover {
	background: #0c0 !important;
	color: #fff !important;
}
/* Ende Buttons Spezial Anpassungen */



/* Spezielle Abstände */
.checkbox-radio-extra-distance {
	margin-right: 25px !important;
}
/* Ende Spezielle Abstände */


.form-check-text {
	font-size: .8em !important;
	line-height: 150% !important;
}


/* Radios Design */
.control {
	font-family: 'Source Sans 3',arial,sans-serif;
	/* display: block; -> wenn untereinander sein soll */
	display: inline-block;
	position: relative;
	padding-left: 31px;
	margin-bottom: 31px;
	padding-top: 6px;
	cursor: pointer;
	font-size: .8em;
	line-height: 150%;
}

.control input {
	position: absolute;
	z-index: -1;
	opacity: 0;
}

.control-indicator {
	position: absolute;
	top: 6px;
	left: 0;
	height: 25px;
	width: 25px;
	background: #F0F1F1;
	border: 1px solid #2A4194;
}

.control-radio .control-indicator {
	border-radius: 50%;
}

.control:hover input ~ .control-indicator, .control input:focus ~ .control-indicator {
	background: #fff;
	outline: 3px solid #2A4194 !important;
}

.control input:checked ~ .control-indicator {
	background: #eee;
}

.control:hover input:not([disabled]):checked ~ .control-indicator, .control input:checked:focus ~ .control-indicator {
	background: #eee;
}

.control input:disabled ~ .control-indicator {
	background: #ddd;
	opacity: 0.6;
}

.control input:focus ~ .control-indicator {
	outline: 3px solid #2A4194 !important;
}

.control-indicator:after {
	box-sizing: unset;
	content: '';
	position: absolute;
	display: none;
}

.control input:checked ~ .control-indicator:after {
	display: block;
}

.control-radio .control-indicator:after {
	left: 8px;
	top: 8px;
	height: 12px;
	width: 12px;
	border-radius: 50%;
	background: #2A4194;
}

.control-radio input:disabled ~ .control-indicator:after {
	background: #888;
}
/* Ende Radios */



/* Checkboxen Spezial (Das meiste wird über die Radio Styles geregelt) */
.control-checkbox .control-indicator:after {
	left: 7px;
	top: 0px;
	width: 6px;
	height: 16px;
	border: solid #2A4194;
	border-width: 0 3px 3px 0;
	transform: rotate(45deg);
}

.control-checkbox input:disabled ~ .control-indicator:after {
	border-color: #888;
}

.control-radio .ctext, .control-checkbox .ctext {
	margin-top:6px !important;
	float:left;
}
/* Ende Checkbox */



/* Zusatz Select Design */
.form-field select,
.form-content-field select {
	/*
	font-size: 1em;
	display: inline-block;
	width: 100%;
	cursor: pointer;
	padding: 10px 15px;
	outline: 0;
	border: 2px solid #2A4194;
	border-radius: 0;
	background: transparent;
	color: #2A4194;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	*/
width: 100%;
padding: 8px 15px;
outline: 0;
border-radius: 0;
background: #F0F1F1;
color: #2A4194 !important;
font-size: .8em;
appearance: none;
-webkit-appearance: none;
-moz-appearance: none;
resize: none;
border: 1px solid #2A4194;
font-family: 'Source Sans 3',arial,sans-serif;
}

.form-field select::-ms-expand,
.form-content-field select::-ms-expand {
	display: none;
}

.form-field select:hover,
.form-field select:focus,
.form-content-field select:hover,
.form-content-field select:focus {
	/*
	border: 2px solid #2A4194;
	background: #eee;
	color: #2A4194;
	*/
background-color: #fff !important;
color: #2A4194 !important;
border: 1px solid #2A4194;
outline: 2px solid #2A4194 !important;
}

.form-field select:disabled,
.form-content-field select:disabled {
	opacity: 0.5;
}

.form-field .select-arrow,
.form-content-field .select-arrow {
	position: absolute;
	top: 16px;
	right: 15px;
	width: 0;
	height: 0;
	border: solid #2A4194;
	border-width: 0 3px 3px 0;
	display: inline-block;
	padding: 3px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
}

.form-field select:hover ~ .select-arrow,
.form-field select:focus ~ .select-arrow,
.form-content-field select:hover ~ .select-arrow,
.form-content-field select:focus ~ .select-arrow {
	border-top-color: #2A4194;
}

.form-field select:disabled ~ .select-arrow,
.form-content-field select:disabled ~ .select-arrow {
	border-top-color: #2A4194;
}

.select-arrow-icon {
	background-image: url(../images/icon-select-arrow.gif) !important;
	background-repeat:  no-repeat;
	background-position: 70% 50%;
}

.select-arrow-x {
	background: #F0F1F1 url(../images/icon-select-arrow.gif) no-repeat 99% 14px !important;
}

/* Ende Zusatz Select Design */



/* Platzhaltertext */
::-webkit-input-placeholder {
	font-style: italic;
}

:-moz-placeholder {
	font-style: italic;
}

::-moz-placeholder {
	font-style: normal;
	color: #2A4194;
	opacity: 1;

}

:-ms-input-placeholder {
	font-style: italic;
}
/* Ende Platzhaltertext */



/* Datepicker Fahrplanauskunft */
input[type="date"]::-webkit-calendar-picker-indicator {
	opacity: 1;

}

input[type="date"]::-webkit-calendar-picker-indicator:hover {
	opacity: 1;

}
