html, body, div{
	margin: 0px;
	padding: 0px;
	font-family: 'Open Sans', sans-serif;
	font-size: 14px;	
	color: #333;
}

.page {
	display: flex;
}

.navigation {
	flex: 0 0 250px;
	width: 250px;
	min-height: 100vh;	
	background-color: #efefef;	
}

.nav_entry {
	margin-top: 150px;
}

.content {
	width: auto;
	padding: 50px 2%;	
}

.content_header {
	min-height: 100px;
}

.option_top {
	display: flex;
	height: 50px;
	width: 100%;
	margin-bottom: 10px; 
}

.option_container {
	margin-right: 1.2vw;
}

.table.align_right {
	float: right;
	margin-top: 2vw;	
	text-align: right;
	font-weight: bold;	
}

.container_new {
	margin-top: 40px;
	margin-bottom: 40px;
/*style="background-color: #F5F5F5;padding: 10px;margin: 20px 0px;"	*/
}

.float_clear {
	clear: both;
}

.colspan {
	width: 20vw;
}

/* Menu  */

.navigation a:hover {
	text-decoration: none;
}

.menu, .sub_menu, .sub_menu_1 {
	display: flex;	
	width: auto;	
	min-height: 25px;
	background: #d4d4d4;
	padding: 10px;
	margin-left: 1px;	
	margin-bottom: 1px;
}

.menu i {
	font-size: 16px;
	width: 18px;
}

.menu_text {
	font-size: 15px;
	font-weight: 400;
	margin-left: 20px;
}

.menu:hover {
	text-decoration: none !important;	
	/* background: #BFD25E; * in config.color definiert */
	color: #FFF;	
}

.menu.accent {
	/* background: #BFD25E; * in config.color definiert */
	color: #FFF !important;
}

.menu.accent:hover {
	/* background: #BFD25E; * in config.color definiert */
}

.menu.accent.dark {
	font-weight: 500;	
	background: #83903f;		
}

.menu.accent.dark .menu_text {
	color: #fff !important;	
}

.menu.accent i {
	color: #fff !important;
}

.sub_menu, div.sub_menu_1 {
	width: auto;	
	height: 20px;
	background: #e6e6e6;
	padding: 10px;
	margin-left: 1px;
	font-size: 15px;
	margin-bottom: 1px;
	padding-left: 30px;
}

.sub_menu:hover, div.sub_menu_1:hover {
	/* background: #BFD25E; * in config.color definiert */
	color: #FFF;
}

.sub_menu_1 {
	background: #fbfbfb;
}

.item_logout, .item_first {
	margin-top: 20px;
}

.login_container {
	width: 545px;
	margin: auto;
	margin-top: 20vh;
}

.login {
	border-radius: 5px;
	margin: auto;
	padding: 20px 20px;
	background-color: #FFF;
	border: 1px solid #333;
}


/* generic styles */

h1 {
	margin-top: 0px;
	font-size: 28px;
}

h2 {
	margin-top: 0px;
	font-weight: 700;
}

p {
    margin-block-start: 0;
    margin-block-end: 0;	
}

i.fa:hover {
	color: #8da223;
}

.tab i.fa, .tab i.fas, .tab i.far {
	font-size: 15px;
}

i.fas.fa-trash {
	color: #5e3f3f;
}

i.fas.fa-edit {
	color: #2db53f;
}

i.far.fa-copy {
	color: #389489;
}

i.fas.fa-file-pdf {
	color: #f30b0b;	
}

i.fa.fa-list {
	color: #1870cc;
}

i.fa.fa-tasks {
	color: #1997cc;	
}

i.fa.fa-user {
	color: #5719cc;	
}

i.fas.fa-user-clock {
	color: #dd1450;
}

i.far.fa-envelope-open, i.fas.fa-envelope {
	color: #0c80ed;
}

.far.fa-layer-plus {
	color: #1397a5;	
}

i.fa.fa-info {
	color: #BFD25E;
}

a:link {color: #333333;text-decoration: none;font-weight: 300;}
a:visited {color: #333333;text-decoration: none;font-weight: 300;}
a:active {color: #333333;text-decoration: none;font-weight: 300;}
a:hover {color: #333333;text-decoration: underline;font-weight: 300;}

/* table styles */

.table.light_grey input {
	color: #333;
}

.table dl, .table dt, .limit dl, .limit dt {
	margin: 2px 0;
	padding: 11px 12px;	
	background-color: #f0f0f0;
	border: 1px solid #FFF;
	vertical-align: top;
	border-radius: 4px;
}

.table.white dl, .table.white dt, .limit dl, .limit dt {
	background-color: rgba(255, 255, 255, 0) !important;
	border: 0px;
}

.table.light_grey dl, .table.light_grey dt {
	background-color: #f1f1f1;	
} 


.table_form dl, .table_form dt {
	margin: 2px 0;
	padding: 10px 10px;	
	vertical-align: top;	
	background-color: #e9e9e9;
	border: 1px solid #FFF;
	border-radius: 4px;	
} 

dl {
	display: table-row;
}

dl.content_entry:hover > dt {
	background-color: #f2f2f2;
	color:333 !important;
}

dt {
	display: table-cell;
}

.table_invoice {
	display: table;	
}

.table_head dt {
	/*background-color: #BFD25E; in color.config.php definiert */ 
	color: #fff;

}

.table_search > dt {
	width: 100%;
}

/* div styles */
.search_box {
	display: flex;
}

.cell_50_vw {
	width: 50vw;
}

.cell_15_vw {
	width: 15vw;
}

.cell_50 {
	width: 50%;
}

.cell_100 {
	width: 100%;
}

.cell_33 {
	width: 33%;
}

#slide_button {
	cursor: pointer;	
}

.slide {
	display: none;	
}

.slide.open {
	display: block;
}

.slide_icon:before {
	display: inline-block;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Pro"; 
	font-weight: 900; 
	content: "\f105";
	font-size: 22px;
	position: relative;
	top: 2px;	
	transition: all 0.5s;	
}

.slide_icon.down:before {
	content: "\f107";
}

#slide_button:hover .slide_icon:before {	
	transform: translateX(10px) rotate(90deg);	
}

.invoice_limit {
	display: flex;
	justify-content: space-between;	
}

.limit {
	background-color: #efefef;	
	width: 28%;
	padding: 1% 2%;	
	border-radius: 4px;
}

.limit input[type="text"], .limit input[type="date"], .limit select  {
	/*width: 2vw !important;*/
}

/* input styles */

.table input, .input_100, select, .limit input {
	width:100%;
	font-size: 16px;
	padding: 4px 4px;
	box-sizing: border-box;	
}

.limit_reset {
	font-size: 16px;
	padding: 4px 4px;
}


.limit input:hover, .limit_reset:hover {
	cursor: pointer;	
}


input.project_title {
	height: 28px;
	display: inline;
	margin-left: 10px;
	width: 95%;
	font-size: 22px;
	position: relative;
	top: 6px;
	border: 0px;
	border-bottom: 1px solid;
}

input.search_field {
	height: 28px;
	font-size: 14px;
}

.search_field {
	width: 24vw;
}

.search_button {
	height: 34px;
	width: 34px;
	margin-left: 2px;
	font-size: 14px;	
}

.archiv_button {
	height: 34px;
	width: 111px;
	font-size: 14px;	
}

.archiv_button:hover {
	cursor: pointer;
}

.table_form input.form_content {
	height: 28px;
	font-size: 16px;
	padding: 4px 4px;
	box-sizing: border-box;		
	margin: 2px 0;
	width: 100%;
}

button.inline {
	font-size: 14px;
	width: 100%;
	padding: 8px 7px;
	background-color: #ffffff;
	border: 0px;
	cursor: pointer;
	text-align: center;
	border-radius: 4px;
}

button.inline:hover {
	background-color: #cfcfcf;
}

input.speichern, div.speichern, div.print, button.speichern {
    width: auto;
    float: right;
    padding: 13px;
    font-weight: bold;
	font-size: 14px;
    border-width: 1px;
    color: #FFF;
    border: 0px;
    text-transform: uppercase;
    border-radius: 3px;
    background: #96c44d;
	cursor: pointer;
}

input.speichern:hover, div.speichern:hover, div.print:hover, button.speichern {
	background: #709338;
}

input.abbrechen, div.abbrechen, input.add_artikel, button.abbrechen{	
    width: auto;
    float: right;
    padding: 11px 13px;
    font-weight: bold;
    border-width: 1px;
	font-size: 14px;
    color: #fff;
    border: 0px;
    text-transform: uppercase;
    border-radius: 3px;
    background: #389489;
    cursor: pointer;
}

input.option, button.option {
    height: 40px;	
    background: #dbdbdb;
    border: 0px;
    padding: 5px 15px;
	border-radius: 4px;
    font-family: inherit;
	font-size: 14px;
    font-weight: 400;
    color: rgba(51, 51, 51, 0.98);	
    cursor: pointer;
}

input.option:hover, button.option:hover {
	/*background: #BFD25E; in config.color definiert */
	color: #FFF;	
}


div.errormsg {	
	padding: 20px;
	background-color: #ffe5e5;
	margin-bottom: 20px;
}

img.icon {
	position: relative;
	top:2px;
}
p.msg {
	width: 100%;
	margin-bottom: 0px !important;
 	border-bottom-left-radius: 2px 2px;
	border-bottom-right-radius: 2px 2px;
 	border-top-left-radius: 2px 2px;
	border-top-right-radius: 2px 2px;
	-moz-border-radius-bottomleft: 2px;
	-moz-border-radius-bottomright: 2px;
	-moz-border-radius-topleft: 2px;
	-moz-border-radius-topright: 2px;	
}

.eckdaten_erstellt {
	font-style: italic;
	font-size: 12px;
	color: #767575;
}

.button {
	padding: 8px;	
	cursor: pointer;
	transition: background-color 0.5s ease-in-out;	
	border-radius: 2px;
}

.button:hover {
	background-color: #d5d5d5;
}

#anredeText {
   display: none;   
   margin-bottom: 20px;
}

@media only screen and
(max-width:1300px) {
	
	/*
	.content_header {
		height: auto;
		padding-bottom: 25px;	
	}
	*/
}


@media only screen and
(max-width:1000px) {
	
	
	.navigation {
		width: auto;
		flex: auto;
	}
	
	.content {
		width: 100%;
	}
	
	.sub_menu, .sub_menu_1 {		
		padding-left: 12px;
	}
	
	.menu_text {
		display: none;
	}

	/*
	.table dl {
		display: flex;		
		flex-wrap: wrap;
		border: 0px;		
	}
	
	.table dt {
		width: 100%;
		border: 0px;
	}
	*/
		
}













