
/* newapplication.css */

/*
- needs no apllication.css
- no conflict with application.css (only makes bigger fields)
- look like 2.0 makes grey background for fieldsets

old ids (#esv-nav_portal_detail, #esv-content_mitnav) are still supported here 

undo relation to data-component-id and fixes at the end

*/


/*the killer & savior of application.css */

/* look like 2.0
fieldset fieldset {
	background-color: rgb(242, 245, 245);
	padding: 10px;
}*/


.formelement label,
.formelement input,
.formelement select {
	max-width: none;
	min-width: 0;
}

.formular_baustein input:not([type='button']):not([type='submit']):not([type='reset']) {
	background: none;
}

.formular_baustein legend {
	padding: 15px 10px;
}

.formular_baustein fieldset {
	margin-top: 0;
}

.formular_baustein input[type='radio'] {
	margin-top: 7px;
}

input[type='radio'], input[type='checkbox'] {
	-moz-border-radius: 0;
	-webkit-border-radius: 0;
	-khtml-border-radius: 0;
	border-radius: 0;
	-webkit-box-shadow: none;
 	-moz-box-shadow: none;
  	box-shadow: none;
	padding: 0;
	border: 1px solid rgb(238, 238, 238);
}

input[type='radio'] {
	-webkit-appearance: radio;
	-webkit-border-radius: 50%;
}

input[type='checkbox'] {
	-webkit-appearance: checkbox;
	-webkit-border-radius: 20%;
}

/* ie 10 only */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    input[type='radio'], input[type='checkbox'] {
		border:  none;
	}
}

.error img {
    float: none;
    margin-left: 0;
    margin-right: 0;
}

.error img.ui-datepicker-trigger {
	float: left;
}

.esv_infobox.yellow {
	background-color: #FFFA9D;
	color: #475256;
}

.detail .esv_infobox h2 {
	margin-top: 0px;
}

/*the template*/
/*classes identify template*/

.no_sidebar .detail {
	width: 100%;
}

.no_sidebar .pagefooter {
	width: 100%;
}

.hide_subnavi #esv-navigation,
.hide_subnavi #esv-nav_portal_detail {
	display: none;
}

.hide_subnavi #esv-navigation.show,
.hide_subnavi #esv-nav_portal_detail.show {
	display: table-cell;
}

.text ul.formelement_group { 
	padding: 0;
}


/*app navigation*/

.app_navigation {
	border-bottom: 1px solid white;
	margin-bottom: 20px;
}

.detail .app_navigation {
	padding: 20px 0 80px;
	position: relative;
}

.detail .app_navigation ul {
	display: -webkit-flex;
  	display: flex;
	flex-wrap: wrap;
}

.detail .app_navigation li {
	-webkit-flex: 1;
    flex: 1;
	background: rgb(242, 245, 245);
	padding: 10px 15px;
	border: 1px solid #fff;
	border-bottom: none;
	border-right: none;
	white-space: nowrap;
	text-align: center;
}


.detail .app_navigation li:hover {
	background-color: #fff;
}

.detail .app_navigation li.current-menu-item {
	-webkit-flex: 3;
    flex: 3;
}


.detail .app_navigation li.current-menu-item {
	position: absolute;
	bottom: 0;
	left: 0;
	background: none;
	font-size: 22px;
    line-height: 27px;
	padding: 0;
}

.detail .app_navigation li a {
}

.detail .app_navigation li.current-menu-item a {
	color: rgb(0,142,92); /*sv*/
}


.detail .app_navigation li a {
	text-decoration: none;
}


/*tables*/

table td {
	border: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	padding: 4px;
	vertical-align: top;
}

table.alternate tr:nth-child(odd) {
    background-color: rgb(242, 245, 245);
}


table th, table caption {
	background-color: rgba(0, 100, 100, 0.1);  /*sv*/
	border: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	padding: 4px;
	vertical-align: top;
}

table th.horizontal, table.horizontal th {
	text-align: left;
	background: none;
}


table caption {
	border-bottom: none;
}

table.norespond {
	width: 100%;
}

.show_table {
	display: none;
}

.sort_icon img {
	float: right;
	margin: 5px 4px -5px 8px;
	width: 15px;
}



@media (max-width: 960px) {

	.show_table {
		display: block;
		font-family: "Roboto Condensed",sans-serif;
		letter-spacing: .05em;
		font-weight: 400;
		font-size: 13px;
		margin: 10px 0;
	}
	
	table.norespond caption {
		border: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	}
	
	table.norespond thead, table.norespond tbody, table.norespond th, table.norespond td, table.norespond tr { 
		display: none;
	}
	
	.lightbox {
		top: 0px;
		left: 0px;
		 position: fixed;
		 width: 100%;
		 height: 100%;
		 overflow: scroll;
		 background: rgba(242, 245, 245, 0.98);  /*sv*/
		 padding: 0;
		 z-index: 300;
	 }
	 
	 table.tablebox {
		margin: 30px auto;
		background: white;
		max-width: none;
	}
	
	table.tablebox caption {
		background: white;
	}

}


@media (max-width: 600px) {

	table.nocolumns_600px, 
	table.nocolumns_600px thead, 
	table.nocolumns_600px tbody, 
	table.nocolumns_600px th, 
	table.nocolumns_600px td, 
	table.nocolumns_600px tr, 
	table.nocolumns_600px caption {
		display: inline-block;
		width: 100% !important;
		min-height: 1px;
		vertical-align: top;
	}
	
	table.nocolumns_600px { 
		border-top: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	}
	
	table.nocolumns_600px caption { 
		border: none;
	}
	
	table.nocolumns_600px th,
	table.nocolumns_600px td { 
		border: none;
	}
	
	table.nocolumns_600px tr { 
		border-bottom: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	}
	
	table.nocolumns_600px th,
	table.nocolumns_600px td:nth-child(odd) {
		background-color: rgb(242, 245, 245);
	}
	
	table.alternate.nocolumns_600px tr:nth-child(odd) {
    background: none;
	}

}


@media (max-width: 400px) {

	table.nocolumns_400px, 
	table.nocolumns_400px thead, 
	table.nocolumns_400px tbody, 
	table.nocolumns_400px th, 
	table.nocolumns_400px td, 
	table.nocolumns_400px tr, 
	table.nocolumns_400px caption {
		display: inline-block;
		width: 100% !important;
		min-height: 1px;
		vertical-align: top;
	}
	
	table.nocolumns_400px { 
		border-top: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	}
	
	table.nocolumns_400px caption { 
		border: none;
	}
	
	table.nocolumns_400px th,
	table.nocolumns_400px td { 
		border: none;
	}
	
	table.nocolumns_400px tr { 
		border-bottom: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
	}
	
	table.nocolumns_400px th,
	table.nocolumns_400px td:nth-child(odd) {
		background-color: rgb(242, 245, 245);
	}
	
	table.alternate.nocolumns_400px tr:nth-child(odd) {
    background: none;
	}

}


@media 
only screen and (max-width: 760px),
(min-device-width: 768px) and (max-device-width: 1024px)  {

	table.respond, table.respond thead, table.respond tbody, table.respond th, table.respond td, table.respond tr, table.respond caption { 
		display: inline-block;
		width: 100% !important;
		min-height: 1px;
		vertical-align: top;
	}
	
	table.respond thead tr, table.respond th { 
		position: absolute;
		top: -9999px;
		left: -9999px;
	}
	
	table.respond caption { 
		border: none;
	}
	
	table.respond td { 
		border: none;
		border-bottom: 1px solid rgba(0, 100, 100, 0.2); /*sv*/
		position: relative;
		padding-left: 50%;
	}
	
	table.respond td:before { 
		content: attr(data-label);
		display: inline-block;
		vertical-align: top;
		box-sizing: border-box;
		font-weight: 500;
		width: 100%;
		margin-left: -100%;
		text-align: right;
		padding: 0 20px;
		font-size: 13px;
		line-height: 15px;
		color: rgb(118, 118, 118);
		padding-top: 5px;
	}
}


/*formelements*/

fieldset input:not([type='radio']):not([type='checkbox']):not([type='button']):not([type='submit']):not([type='reset']),
fieldset select,
fieldset textarea {
	font-family: 'Roboto', sans-serif;
	-moz-border-radius: 0;
	-webkit-border-radius: 0;
	-khtml-border-radius: 0;
	border-radius: 0;
	min-height: 35px;
	font-size: 16px;
	color: rgb(118, 118, 118);
	border: 1px solid rgb(221, 221, 221);
	-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.07) inset;
 	-moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.07) inset;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.07) inset;
	background: rgb(252, 252, 252);
}


fieldset .formelement input[type="file"] {
	padding: 0;
}

fieldset input[readonly]:not([type='radio']):not([type='checkbox']):not([type='button']):not([type='submit']),
fieldset input[disabled]:not([type='radio']):not([type='checkbox']):not([type='button']):not([type='submit']),
fieldset select[disabled], fieldset textarea[disabled]  {
	cursor: default;
	-webkit-box-shadow: none;
 	-moz-box-shadow: none;
  	box-shadow: none;
	color: rgb(118, 118, 118);
	background: none;
}


fieldset .formelement input[readonly]:not([type='radio']):not([type='checkbox']):focus {
	color: rgb(118, 118, 118);
}

fieldset .formelement input:not([readonly]):focus,
fieldset .formelement select:focus,
fieldset .formelement textarea:focus {
	background-color: rgb(242, 245, 245);
}

.formelement input,
.formelement textarea,
.formelement select {
	float: left;
	padding: 4px 10px;
}


fieldset {
	margin:20px 0;
	padding: 0px;
	border: 0px;
	float: left;
	width: 100%;
	min-height: 1px;
}

fieldset.light,
fieldset fieldset fieldset {
	margin:10px 0;
}

legend {
	clear: both;
	float: left;
	width: 100%;
	background-color: rgb(242, 245, 245);
	padding: 5px 10px;
	margin-bottom: 20px;
	font-family: "Roboto Condensed",sans-serif;
    font-size: 18px;
}

legend.title {
	background: none;
	font-size: 28px;
	padding-bottom: 10px; 
	margin-bottom: 2px;
}

legend.light, 
fieldset fieldset fieldset legend {
	background: none;
	border: none;
	font-weight: 500;
	padding: 5px 0;
	font-family: "Roboto",sans-serif;
	font-size: 15px;
	margin: 10px 0;
}


.formular_baustein label, .formelement label, .labelstyle {
	text-align: right;
	line-height: 16px;
	font-size: 15px;
	overflow: hidden;
	border: none;
	font-family: "Roboto",sans-serif;
	padding: 7px 10px 7px 0;
	background: none;
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
	float: left;
	margin: 0;
}

.formular_baustein label[class^="labelcheck"] {
	text-align: left;
	padding-left: 7px;
}

fieldset label .icon_small,
fieldset .labelstyle .icon_small {
	margin: -3px 4px -3px 0;
}

.icon_after {
	margin: 2px 0 0 5px;
	float: left;
}

select,
input[type='file'] {
	cursor: pointer;
}

input[type='reset'],
input[type='submit'],
input[type='button'],
input.button,
button {
	-webkit-appearance: none;
	letter-spacing: 0.03em;
    border: none;
    border-radius: 4px;
    color: rgb(255, 255, 255); /*sv*/
    cursor: pointer;
    font-family: "Roboto Condensed",sans-serif;
    font-size: 16px;
    height: auto;
	min-height: 38px;
	-webkit-box-shadow: none;
 	-moz-box-shadow: none;
  	box-shadow: none;
	margin-top: 0;
}

input.button.align_left,
input.button.align_right,
button.align_left,
button.align_right {
	margin-top: 4px;
	margin-bottom: 5px;
}

.buttons input[type='reset'],
.buttons input[type='submit'],
.buttons input[type='button'],
.buttons input.button,
.buttons button {
	margin-top: 4px;
	margin-bottom: 5px;
	padding: 0 8px;
}

.buttons {
	margin-top: 50px;
}

.buttons .button.grey, .buttons button.grey, .buttons input[type='reset'] {
	border: 1px solid rgb(221, 221, 221);
  	color: rgb(118, 118, 118);
	background: rgb(242, 245, 245);
}

.input_file input[type='submit'],
.input_file input[type='button'],
.input_file input.button,
.input_file button {
	border-radius: 0 4px 4px 0;
	margin-top: 0;
	margin-bottom: 4px;
	min-height: 37px;
}

/*Chrome only*/
.input_file input[type='button']:not(*:root),
.input_file button:not(*:root) {
	min-height: 35px;
}

.input_small {
	height: auto;

}

.input_small input {
	width: 30px;
	float: left;
	margin: 8px 0 0;
}

.input_small label {
	text-align: left;
	float: left;
}

.input_small.reverse label {
	text-align: right;
}

.asterisk {
	color: rgb(0, 116, 87); /*portal.css*/
	display: inline-block;
	padding: 0 3px;
}


/*formelement group*/

.detail .formelement_group .formelement_group,
.detail .formelement_group .formelement {
	display: inline;
	float: none;
}

.formelement_group, .formelement {
	width: 100%;
	clear: both;
	padding: 5px 0;
	float: left;
}

ul.formelement_group,
li.formelement {
	padding: 5px 0;
	list-style: none;
}

/*block_element*/

.floatblock {
	padding: 3px 0 5px;
	float: left;
	width: 100%;
}


/*text_styles*/


form hr {
	margin: 10px 0;
	width: 100%;
	float: left;
}

hr.empty {
	background: none;
	margin: 20px 0;
}

h1, h2 {
	clear: both;
}

fieldset p {
clear: both;
}

.textalign_right {
	text-align: right;
}

.textalign_left {
	text-align: left;
}

.textalign_center {
	text-align: center;
}



/*form multiple page steps*/

.steps {
	display: table;
	overflow: hidden;
	height: 40px;
	width: 100%;
	table-layout: fixed;
	padding: 0;
	margin: 0;
	font-family: "Roboto Condensed",sans-serif;
}

.steps li {
	display: table-cell;
	background: rgb(242, 245, 245);
	background: rgb(0, 142, 92); /*sv*/
	height: 40px;
	line-height: 17px;
	position: relative;
	vertical-align: middle;
	padding: 0 15px;
	text-align: center;
	-ms-hyphens: auto;
	-moz-hyphens: auto;
	-webkit-hyphens: auto;
	hyphens: auto;
	color: white;
	
}

.steps li.current {
	background: none;
	font-weight: 500;
	text-transform: uppercase;
	color: rgb(71, 82, 86);
}

.steps li.done a {
	text-decoration: none;
	color: rgba(71, 82, 86, .5);
	color: rgb(118, 118, 118);
	display: block;
}

.steps li.done a:hover {
	text-decoration: underline;
	color: rgb(71, 82, 86)
}

.steps li:before {
	content: '';
	display: block;
	background: rgb(242, 245, 245);
	background:  rgb(0, 142, 92); /*sv*/
	border-right: 3px solid white;
	border-top: 3px solid white;
	height: 23px;
	width: 23px;
	position: absolute;
	right: -11px;
	top: 7px;
	-webkit-transform: rotate(45deg) skew(15deg, 15deg);
	-moz-transform: rotate(45deg) skew(15deg, 15deg);
	-o-transform: rotate(45deg) skew(15deg, 15deg);
	transform: rotate(45deg) skew(15deg, 15deg);
	z-index: 5;
}

.steps li.done:before,
.steps li.done {
		background: rgb(242, 245, 245);
}

.steps li:last-child:before {
	content: '';
	display: none;
}

.steps li.current:before {
	content: '';
	background: white;
}

.stepnumber {
	font-size: 18px;
	display: none;
}

@media (max-width: 600px) {
	
	.steptext {
		display: none;
	}
	
	.stepnumber {
		display: block;
	}
}


/*date-component*/
/*undo relation to data-component-id*/

.std_datum .sv-date,
.formelement[data-component-id='datum'] .sv-date {
	font-size: 1.6rem;
	margin-left: -30px;
	vertical-align: -10px;
}

.std_datum input,
.formelement[data-component-id='datum'] input {
	padding-right: 30px;
}


/*form info*/

.help .columns,
.element_infobox {
	display: none;
	background: #FFFA9D;
	clear: both;
	float: left;
	width: 100%;
	-moz-border-radius: 0px;
	-webkit-border-radius: 0px;
	-khtml-border-radius: 0px;
	border-radius: 0px;
	padding: 25px 15px 15px;
	font-size: 13px;
	line-height: 17px;
	position: relative;
	margin-top: 10px;
}

.help .columns:before,
.element_infobox:before {
	content: '';
	display: block;
	position: absolute;
	top: -7px;
	left: 30%;
	width: 0;
  	height: 0;
	border-left: 7px solid transparent;
	border-right: 7px solid transparent;
	border-bottom: 7px solid #FFFA9D;
}

.help .columns:before {
	left: 8.3%;
}

.formelement_group .formelement .element_infobox:before {
	left: 50%;
}

.formelement_group .formelement:last-child .element_infobox:before {
	left: auto;
	right: 30%;
}

.formelement_group .formelement:first-child .element_infobox:before {
	left: 49%;
}

.show_info span {
	display: inline-block;
	font-size: 1.6rem;
	margin-top: -4px;
	vertical-align: -4px;
}

.show_info.open .sv-o_answer1:before,
.show_info:hover .sv-o_answer1:before {
	content: '\e927';
}

.show_info.open .sv-o_info1:before,
.show_info:hover .sv-o_info1:before {
	content: '\e929';
}

.show_info {
	text-decoration: none;
}

.close_info {
	position: absolute;
	top: 0px;
	right: 0px;
}

.info {
	background: none;
    float: left;
    font-size: 13px;
    line-height: 20px;
    margin-bottom: 4px;
    min-height: 1px;
    padding: 8px 8px 0 0;
    width: 100%;
}

/*form help*/

.help {
	margin: 0 0 30px;
	float: left;
	width: 100%;
	font-size: 13px;
	line-height: 17px;
}

.detail .help h3 {
	padding: 0 8px 8px 0;
	margin: 0;
	font-size: 13px;
}

.help h3 a.open .sv-answer1:before,
.help h3 a:hover .sv-answer1:before {
	content: '\e94d';
}


.info .icon_small, /*version 2 only*/
.help .icon_small {
	margin: -5px 4px -5px 0;
}

.help .columns {
	margin-top: 10px;
	padding: 20px 10px 10px 10px;
}

.help .column1, .help .column2 {
	display: block;
	width: 50%;
	float: left;
	padding-left: 8px;
}

.help p {
	display: table;
}

.help p span {
	display: table-cell;
}

.help p span:first-child {
	width: 25px;
}

.help span[class^="sv-"] {
	display: inline-block;
	font-size: 1.6rem;
	margin-right: 5px;
	vertical-align: -6px;
}

@media (max-width: 600px) {

	.help .column1, .help .column2 {
		width: 100%;
	} 

}


/*form errors*/

.errorform label[class*='column_correct'] {
		margin-left: 0;
}

.error {
	background: #FFEDDB;
	color: #C73700;
	width: 100%;
	float: left;
	font-size: 13px;
	margin-bottom: 4px;
	min-height: 0;
	padding: 8px;
}

.detail .error h3 {
	margin-top: 0px;
}

fieldset .error input:not([type='radio']):not([type='checkbox']),
fieldset .error select,
fieldset .error textarea {
	border-color: rgba(238, 67, 0, .2);
}

.error a {
	color: #C73700;
}

.detail .formelement.error,
.detail .formelement_group.error {
	padding: 5px;
	display: inline-block;
	margin-top: 3px;
}

.error_label {
	display: inline-block;
	padding-right: 5px;
	font-weight: 700;
	text-transform: uppercase;
	color: #C73700;
	font-family: "Roboto Condensed",sans-serif;
}

.error_label img.icon_small {
	float: left;
}

.error .element_infobox {
	display: block;
	background: white;
}

.formelement_group .formelement.error .element_infobox:before,
.formelement_group.error .formelement .element_infobox:before,
.error .element_infobox:before {
	border-bottom: 7px solid white;
	left: 30%;
}


/*result*/

.detail .result h3 {
	clear: both;
	float: left;
	width: 100%;
	background-color: rgb(242, 245, 245);
	padding: 10px;
	margin-bottom: 20px;
	font-family: "Roboto Condensed",sans-serif;
    font-size: 15px;
	line-height: 18px;
}

.detail .result h4 {
    font-size: 15px;
    font-weight: 400;
    line-height: 18px;
    margin: 15px 0 5px;
	padding: 5px 0 0 10px;
	border-top: 2px solid rgb(242, 245, 245);
}

.result {
	font-size: 13px;
}

.result .value {
	display: inline-block;
	padding: 10px 0 10px 12px;
	font-size: 15px;
	line-height: 18px;
	font-weight: 500;
	width: 65%;
	vertical-align: top;
}

.result .key {
	display: inline-block;
	width: 33%;
	vertical-align: top;
	padding: 10px 0 10px 10px;
}

@media (max-width: 400px) {
	
	.result .key,
	.result .value {
		display: block;
		width: 100%;
		padding: 0 0 0 10px;
	}
	
	.result .value {
		display: block;
		width: 100%;
		padding-bottom: 10px;
		border-bottom: 1px solid rgb(242, 245, 245);
	}

}



/*width classes*/

.width12 {
	width: 100%;
}

.width11 {
	width: 91.6%;
}

.width10 {
	width: 83.3%;
}

.width9 {
	width: 75%;
}

.width8 {
	width: 66.6%;
}

.width7 {
	width: 58.3%;
}

.width6 {
	width: 50%;
}

.width5 {
	width: 41.6%;
}

.width4 {
	width: 33.3%;
}

.width3 {
	width: 25%;
}

.width2 {
	width: 16.6%;
}

.width1 {
	width: 8.3%;
}


.column_correct11 {
	margin-left: 91.6%;
}

.column_correct10 {
	margin-left: 83.3%;
}

.column_correct9 {
	margin-left: 75%;
}

.column_correct8 {
	margin-left: 66.6%;
}

.column_correct7 {
	margin-left: 58.3%;
}

.column_correct6 {
	margin-left: 50%;
}

.column_correct5 {
	margin-left: 41.6%;
}

.column_correct4 {
	margin-left: 33.3%;
}

.column_correct3 {
	margin-left: 25%;
}

.column_correct2 {
	margin-left: 16.6%;
}

.column_correct1 {
	margin-left: 8.3%;
}

/*/with classes*/


/*input_small elementclear*/

.formelement_group.input_small.elementclear {
	clear: none;
	display: block;
}

.formelement_group.input_small.elementclear .formelement,
.formelement_group .formelement_group.input_small.elementclear {
	float: left
}



/*labelclear_always*/

	.labelclear_always .formelement:not(.labelclear_never):not(.small_input) label,
	.labelclear_always .formelement:not(.labelclear_never) input:not(.precise):not([type='radio']):not([type='checkbox']),
	.labelclear_always .formelement:not(.labelclear_never) textarea,
	.labelclear_always .formelement:not(.labelclear_never) select,
	.labelclear_always .labelstyle,
	.labelclear_always.formelement label,
	.labelclear_always.formelement input:not([type='radio']):not([type='checkbox']),
	.labelclear_always.formelement textarea,
	.labelclear_always.formelement select {
		width: 100%;
		text-align: left;
		margin-bottom: 3px;
	}
	
	.labelclear_always .formelement_group.labelclear_never .formelement label,
	.labelclear_always .formelement_group.input_small .formelement label {
		width: auto;
	}
	
	.labelclear_always .formelement_group button,
	.labelclear_always .formelement button,
	.labelclear_always .formelement_group.buttons input {
		text-align: center;
		width: 100%;
	}
	
	.labelclear_always .formelement.has_icon_after {
		padding-right: 30px;
	}
	
	.labelclear_always .formelement.has_icon_after input,
	.labelclear_always .formelement.has_icon_after select,
	.labelclear_always .formelement.has_icon_after textarea {
		float: none;
	}
	
	.labelclear_always .icon_after {
		margin-right: -30px;
	}
	
	.labelclear_always .formelement:not(.input_small) label, 
	.labelclear_always .labelstyle {
		text-align: left;
	}
	
	.labelclear_always *[class*='column_correct'] {
		margin-left: 0;
	}


@media (max-width: 960px) {
	
	.formelement_group.elementclear_960px, 
	.formelement_group.elementclear_960px .formelement {
		display: block;
		width: 100%;
		clear: both;
	}
	
	.formelement_group.elementclear_960px .formelement {
		display: flex;
		flex-wrap: wrap;
	}
	
	.formelement_group.elementclear_960px label {
		flex-grow: 0;
	}
	
	.formelement_group.elementclear_960px input {
		flex-grow: 1;
		height: 35px;
	}
	
	.formelement_group.elementclear_960px .input_small input {
		flex-grow: 0;
		margin-top: 0px;
	}
	
	.formelement_group.elementclear_960px .element_infobox {
		flex-grow: 0;
	}
	
	.elementclear_960px label[class*='column_correct'] {
		margin-left: 0;
	}
	
	

	.labelclear_960px label, 
	.formelement.labelclear_960px:not(.input_file) input:not([type='radio']):not([type='checkbox']),
	.formelement.labelclear_960px  textarea,
	.formelement.labelclear_960px  select {
		width: 100%;
		text-align: left;
		margin-bottom: 3px;
	}
	
	
}


@media (max-width: 600px) { /*50/50 layout*/
	

	.formelement_group ul.formelement_group:not(.elementclear_never) .formelement {
		display: block;
		width: 100%;
		clear: both;
	}
	
	.formelement_group {
		display: block;
	}
	
	.formelement_group:not(.elementclear_never) .formelement {
		display: inline-block;
	}
	
	.formelement_group .formelement_group,
	.formelement_group .formelement_group .formelement {
		display: inline;
	}
	
	.formelement.has_icon_after {
		padding-right: 30px;
	}
	
	.icon_after {
		margin-right: -30px;
		float: none;
	}
	
	
	.formelement input:not(.precise):not([type='radio']):not([type='checkbox']), 
	.formelement textarea,
	.formelement select,
	.formelement label,
	.floatblock:not(.no50_50):not(.no_clear),
	.labelstyle {
		width: 50%;
	}
	
	.floatblock.no50_50:not(.no_clear) {
		width: 100%;
	}
	
	.formelement_group.input_small.elementclear {
	width: 50%;
	}
	
	.input_small input {
		width: 30px;
	}
	
	.input_small label {
		width: auto;
		padding-left: 4px;
	}
	
	.input_small.reverse label {
		width: 50%;
		padding-left: 0;
	}
	
	.input_file label,
	.labelstyle {
		text-align: right;
	}
	
	.formelement.labelclear_960px.input_file label {
		width: 100%;
		text-align: left;
	}
	
	.input_file input[type='submit'], 
	.input_file input[type='button'], 
	.input_file input.button, 
	.input_file button {
		width: 50%;
		float: right;
	}
	
	.input_file:not(.labelclear_960px):not(.labelclear_600px) input[type='submit'], 
	.input_file:not(.labelclear_960px):not(.labelclear_600px) input[type='button'], 
	.input_file:not(.labelclear_960px):not(.labelclear_600px) input.button, 
	.input_file:not(.labelclear_960px):not(.labelclear_600px) button {
		border-radius: 4px;
	}
	
	.formelement_group button {
		width: 48%;
	}
	
	.formelement *[class*='column_correct'] {
		margin-left: 50%;
	}
	
	.formelement .floatblock[class*='column_correct'],
	.formelement .labelstyle[class*='column_correct'],
	.formelement label[class*='column_correct'] {
		margin-left: 0;
	}
	
	
	
	.formelement.labelclear_600px label, 
	.formelement.labelclear_600px  input:not([type='radio']):not([type='checkbox']),
	.formelement.labelclear_600px  textarea,
	.formelement.labelclear_600px  select {
		width: 100%;
		text-align: left;
		margin-bottom: 3px;
	}
	
	.formelement.labelclear_600px.input_file input:not([type="radio"]):not([type="checkbox"]) {
		width: 50%;
	}
	
	
	
	/*skip the 50/50 step by using labelclear 600px for all*/

	
	.labelclear_600px .formelement:not(.labelclear_never):not(.input_small) label,
	.labelclear_600px .formelement:not(.labelclear_never) input:not(.precise):not([type='radio']):not([type='checkbox']),
	.labelclear_600px .formelement:not(.labelclear_never) textarea,
	.labelclear_600px .formelement:not(.labelclear_never) select,
	.labelclear_600px .formelement:not(.labelclear_never) .labelstyle,
	.labelclear_600px .formelement_group button,
	.labelclear_600px .labelstyle {
		width: 100%;
		text-align: left;
		margin-bottom: 3px;
		float: none;
	}
	
	.labelclear_600px .formelement_group.labelclear_never .formelement label,
	.labelclear_600px .formelement_group.input_small .formelement label {
		width: auto;
		float: left;
	}
	
	.labelclear_600px .formelement_group button {
		text-align: center;
		margin-left: 0;
		margin-right: 0;
	}
	
	.labelclear_600px .formelement label, 
	.labelclear_600px .labelstyle {
		text-align: left;
	}
	

	
}


@media (max-width: 400px) {
	
	.formelement:not(.labelclear_never) input:not(.precise):not([type='radio']):not([type='checkbox']),
	.formelement:not(.labelclear_never) textarea,
	.formelement:not(.labelclear_never) select,
	.formelement:not(.labelclear_never) label,
	.formelement_group button, 
	.formelement_group input.button,
	.formelement button,
	.formelement input.button,
	.formelement .floatblock:not(.no_clear),
	.labelstyle {
		width: 100%;
		text-align: left;
		margin-bottom: 3px;
		float: none;
		display: block;
	}
	
	.formelement.labelclear_600px.input_file input:not([type="radio"]):not([type="checkbox"]) {
		width: 100%;
	}
	
	.input_file input[type='submit'], 
	.input_file input[type='button'], 
	.input_file input.button, 
	.input_file button {
		border-radius: 4px;
	}

	
	.labelclear_never .labelstyle {
		width: 50%;
		float: left;
	}
	
	
	.formelement_group.input_small input,
	.formelement.input_small input {
		width: 30px;
		margin-right: 0;
	}
	
	.formelement_group.input_small label,
	.formelement.input_small label {
		width: auto;
		padding-left: 4px;
		float: left;
	}
	
	.formelement_group.input_small.elementclear {
		width: 100%;
	}
	
	
	.formelement *[class*='column_correct'] {
		margin-left: 0;
	}
	
	.labelstyle {
		padding: 5px 0 5px;
	}
	
	.formelement input.button,
	.formelement button,
	.formelement_group input.button,
	.formelement_group button  {
		text-align: center;
		margin: 0 0 5px 0;
	}
	
}

/* CAPTCHA START */

.captcha-container .formelement {
       width: 260px;
}

.captcha-container .formelement label {
       width: 40%;
}

.captcha-container .formelement input {
       width: 60%;
}

.float-left {
    float:left;
}

.captcha-image {
    border: none;
}

#visual_captcha_container .float-left {
    margin-top: 1em;
    margin-bottom: 1em;
}

.float-left:nth-child(odd) {
    margin-right: 1em;
}

#captcha_image {
    height: 60px;
    width: 180px;
    border: 1px solid #e6e6e6;
}

#captcha_links {
    height: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}


#captcha_links a img {
    height: 20px;
    width: 20px;
    margin-right: 0.5em;
    margin-left: 0em;
    border: none;
}

#input_captcha_container .captcha-input {
    width: 180px;
    box-sizing: border-box;
}

/* CAPTCHA END */
/* Applikation Workarounds Start */
/* OEKO Zeilenumbruch CMS-11552*/

.esv-application .oEko_detail_formular ul { 
	display: block; 
	padding: 0 0 0 22px; 
	margin: 0; 
}

/* services - sprechtagskalender svs */
body.portal-svs.esv-application div.detail.onlydetail div.text img {
    max-width: none;
}


/* Applikation Workarounds End */

/* Erweiterungen fuer flex-Layout der Web-Applikationen START */


/*download box*/
	
.download_box a,
.download_box {
	min-height: 90px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
}

.download_box:before {
	content: '\e95b';
	font-family: 'sv_icons' !important;
	color: rgb(242, 245, 245);
	font-size: 8rem;
	position: absolute;
	display: block;
	left: 0;
	top: calc(50% - 64px);
	  speak: none;
	  font-style: normal;
	  font-weight: normal;
	  font-variant: normal;
	  text-transform: none;
	  line-height: 1;
	  /* Better Font Rendering =========== */
	  -webkit-font-smoothing: antialiased;
	  -moz-osx-font-smoothing: grayscale;
}

.download_box a {
	width: 100%;
	padding: 25px;
}

.download_box .icon {
	font-size: 60px;
}

.download_box .linkbutton {
	min-width: 300px;
}

.download_box.slim {
	min-height: 70px;
	align-items: flex-end;
}

.download_box.slim a {
	width: auto;
	padding: 0 25px;
	min-height: 50px;
}

.download_box.slim:before {
    font-size: 6rem;
    top: calc(50% - 48px);
}

.buttons {
	float: left;
	width: 100%;
}


@media (max-width: 960px) {

.download_box .linkbutton {
	min-width: 250px;
}

}

@media (max-width: 600px) {

	.buttons.elementclear_600px .button {
		width: 100%;
	}

}	
							
.card {
    box-shadow: 0px 2px 4px rgb(0 0 0 / 40%);
}

.cardcontent_container {
	width: 100%;
	display: flex;
	flex-direction: column;
	padding: 25px;
}

.card_data {
    margin-bottom: 15px;
    font-size: 1rem;
    padding-bottom: 30px;
}

.card_content h4 {
    font-size: 1.125rem;
    line-height: 1.4rem;
    margin: 0;
}

.card .text {
	font-size: 1rem;
	line-height: 1.5rem;
}

.card .indent {
    padding-left: 25px;
    padding-right: 25px;
}

.badge {
    font-size: .75rem;
    text-transform: uppercase;
    margin-bottom: 20px;
}

/*sv-easyflex*/

.flexbox {
	display: flex;
	position: relative;
}

.flexbox.rowlayout {
	flex-direction: column;
}

.flexbox.columnlayout {
	flex-direction: row;
}

.flex_v_center {
	align-items: center;
}

.flex_v_baseline {
	align-items: baseline;
}

.flex_h_center {
	justify-content: center;
}

.flexbox.rowlayout.flex_v_center {
	justify-content: center;
	align-items: flex-start;
}

.flexbox.rowlayout.flex_h_center {
	align-items: center;
	justify-content: flex-start;
}

.flexbox.flex_h_between {
	justify-content: space-between;
}

.flexbox.flex_h_around {
	justify-content: space-around; 
}


@media (max-width: 960px) {
	
	.flexwrap_960px {
		flex-wrap: wrap;
	}
	
	.flexbox.elementclear_960px {
		flex-wrap: wrap;
	}
	
	.flexbox.elementclear_960px > * {
		width: 100%;
	}
	
	.flexbox > .elementclear_960px {
		width: 100%;
	}
}

@media (max-width: 600px) {
	
	.flexwrap_600px {
		flex-wrap: wrap;
	}
	
	.flexbox.elementclear_600px {
		flex-wrap: wrap;
	}
	
	.flexbox.elementclear_600px > * {
		width: 100%;
	}
	
	.flexbox > .elementclear_600px {
		width: 100%;
	}
}

/*lists*/

.card_content div[role='row'].outline,
div[role='row'].outline {
	border: 1px solid #DDDDDD;
	padding: 25px;
	margin-bottom: 15px;
	align-items: flex-start;
}

div[role='gridcell'] {
	position: relative;
}

.outline {
    border: 1px solid #DDDDDD;
    padding: 25px;
}

.cardcontent_container .card_content > .split[role='row'] {
    padding: 15px 0;
}

.split {
	border-bottom: 1px solid #DDDDDD;
}

/*elements in lists*/

.textlabel {
    font-weight: 300;
    padding-right: 15px;
    font-size: .85rem;
}

.detail_button {
    background: rgb(242, 245, 245);
    padding: 10px 5px 10px 15px;
    white-space: nowrap;
    border-radius: 15px;
    text-decoration: none;
    text-align: center;
}

.texticon_link {
    font-size: 0.625rem;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.texticon_link > span {
    font-size: 3rem;
    display: inline-block;
}

.close_info {
    text-decoration: none;
    color: #475256;
    font-size: 1.5rem;
}

/*buttons*/

/*linkbutton*/

a .linkbutton,
a.linkbutton {
    letter-spacing: 0.03em;
    border: none;
    border-radius: 2px;
    color: white;
    font-family: "Roboto Condensed",sans-serif;
    font-size: 1rem;
	line-height: 1rem;
    min-height: 50px;
	background: #008e5c;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 10px 25px;
	text-decoration: none;
}

.linkbutton.outline {
    border: 1px solid #008e5c;
    background: transparent;
	color: #008859;
}

a:hover .linkbutton.outline,
.linkbutton.outline:hover {
	border: 1px solid #008e5c;
    background: #008e5c;
	color: white;
}

label, input, select { 
	min-width: 1px;
	max-width: none;
}

input[type='button'],
input[role='button'] {
	padding: 0 25px;
	min-width: 142px;
}

.button.outline {
	border: 1px solid #008859;
	color: #008859;
	background: transparent;
}

.button.outline:hover {
	border: 1px solid #008859;
	color: white;
	background-color: #008859;
}

a .linkbutton.with_icon,
a.linkbutton.with_icon {
	flex-direction: row;
}

a .linkbutton.with_icon span[class*="sv-"],
a.linkbutton.with_icon span[class*="sv-"]   {
	font-size: 2rem;
}

/*icons*/

.checkicon {
	font-size: 5rem;
}

/* ENDE */

/* undo fix interaction card margins */
.widgetzone .int_widget.card_container li h3 { 
	margin: 0 0 5px 0; 
}

/* 
	undo fix healthcheck fontsize and padding
	wird nach Produktivsetzung von ESVA-10183 wieder entfernt
*/

.healthcheck.card_content {
	font-size: 1rem;
	line-height: 1.4rem;
}

.healthcheck .autro { /*out sic!*/
	padding: 25px 25px 0 25px;
} 

