
/*GENERAL*******************************************************/

a.active{text-decoration: none!important;}
#nav a:hover{text-decoration: none!important;}

.upper {text-transform:uppercase;}
.flex {display: flex;}
.note {font-style: italic;font-size: 12px;}
.bold {font-weight: bold;}
.noborder {border: none!important;}
.nopadding {padding: 0px!important;}
.red{color: #E30613;}
.black{color: #333333;}
.none{display: none!important;}

.navaside { background-color: #F2F2F2; display: block; /*flex: 1*/; width: 100% /*min-width: 100%; max-width: 100%;*/ }
.navaside .nav__element {display: none; }
.navaside.navasideopen .nav__element:not(.active) {display: block; }
.navaside .nav__element { border-bottom: 1px solid #D3D3D3; }
#section2 { padding: 0!important; flex: 4; }
.nav-content-wrap{display: block; align-content:stretch;}
.content-bannerimg{width: 100%;}
#fpbannerimg {padding: 0;}
#fpbannerimg img {min-width: 100%;}

.module_cal .nobooking {margin: 10px;}
.module_bookcal .nobooking {margin: 10px;}

#navasideanchor {display: flex; justify-content: space-between; padding: 15px 25px; background-color: #E9BB24; font-weight: bold;}

#navasideanchoricon.open:after {
	transform: rotateX(180deg);
}
.downarrowicon.open:after {
	transform: rotateX(0deg);
}

.navaside.navasideopen {
	box-shadow: 0px 5px 5px #707070;
}

#navasideanchoricon:after {
	background-image: url("/_assets/content/dhw_icons/arrow.svg");
	background-size: 12px 12px;
	background-repeat: no-repeat;
	width: 12px;
	height: 12px;
	position: relative;
	display: inline-block;
	content: "";
	/*right: 25px;*/
	transition: 0.3s ease;
}

.downarrowicon:after {
	background-image: url("/_assets/content/dhw_icons/arrow.svg");
	background-size: 12px 12px;
	background-repeat: no-repeat;
	width: 12px;
	height: 12px;
	display: inline-block;
	content: "";
	transition: 0.3s ease;
	transform: rotateX(180deg);
	position: relative;
	filter: invert(28%) sepia(7%) saturate(4296%) hue-rotate(199deg) brightness(94%) contrast(81%);
}

.module_onepage ul {padding: 0px!important;}
.module_onepage .module .inner{margin: 0 auto!important;}
.module_onepage section.simple {margin: 0 auto!important; max-width: 969px !important;}
.module_onepage section img {position: relative;}




.tenmargin{margin: 10px;}

/*NAVIGATION / HEADER */
.userbanner{
	height: 45px;
	background-color: #F9EBBD;
	padding: 7px 100px;
	justify-content: flex-end;
}
.navaside li.nav__element.active{background-color: #E9BB24!important; text-decoration: none!important;}
.navaside li.nav__element{color: #333333!important; text-decoration: none!important; text-transform: uppercase!important;}
#header .inner{margin: 0px!important; max-width: 100%!important; display: flex; justify-content: flex-end; /*height: 85px;*/ height: 65px; align-items: center}
#logo {
	position: absolute;
	top: -5px;
	left: -5px;
	z-index: 99;
}
#logo img {max-width: 100%!important; /*width: 145px;*/ width: 115px; }
.navigation h2 {display: none;}
/*.meta-above {background-color: transparent;} Nesli: brauchen wir nur mobil und dort weiß */
.meta-above nav {/*margin-top: 30px;*/margin-right: 90px;} /* Nesli: hab margin-top auskommentiert; flex-elemente lassen dich durch align-items:center vertikal zentrieren*/
.meta-above * {color:#333333!important; font-weight: bold; text-decoration: none;}
#nav a {color: #333333!important; font-weight: bold;}
.angemeldet {display: none;}
.logoutbtn {display: none;}
.userbanner {padding: 7px 7px;}
.userbanner p {padding-top: 5px;}

#navwrap {
	display: block;
	margin-top: 0px!important;
	text-align: left!important;
	vertical-align: top;
	width: 100%!important;
}
#navwrap .navigation_link {
	padding-left: 25px;
}
ul.nav__list{padding: 0!important;}

.headerusername {padding: 0px 20px;}

.meta-above-logout {
	background-color: #F9EBBD;
	display: flex;
	justify-content: space-between;
	padding: 50px 25px 30px;
	text-align: right;
}
.ma-angemeldet *{
	font-weight: normal;
}
.meta-above-logout img {
	padding-top: 7px;
}
#husername {
	display: inline-block;
	height: 20px;
	text-align: right;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}

.inner {max-width: 969px!important;}



.calelement .genbtn, .loginbtn, .loginresetbtn, .loginchangebtn {
	color: #ffffff;
	background-color: #494C80;
	text-decoration: none;
	padding: 15px;
	border: none;
}
.btn-wrap{margin: 30px 0px;}

#grayout{
	display: none;
	background-color: #707070;
	opacity: 0.6;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 500;
}
#main-grayout{
	background-color: #707070;
	opacity: 0.6;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 40;
}


.module_asks select, .module_appointments select {
  background-color: #494C80;
}

.deny-edit-btn:hover, .undo-selection:hover {color: #8789AA; cursor: pointer;}
.deny-edit-btn{
	color: #494C80;
	text-decoration: underline;
}

/*.statusinner{text-align: center;}*/

.bodydiv {margin: 10px 0px 30px;}

tbody:last-child {border-bottom: 1px solid #D3D3D3;}

/* ICONS */

.successicon{
	width: 50px;
	margin: 10px;
	filter: invert(17%) sepia(0%) saturate(0%) hue-rotate(71deg) brightness(101%) contrast(91%);
}

.csvlink{
	width: 180px;
	display: block;
	color: #494C80;
	text-decoration: underline;
	padding-left: 20px;
}

.csvlink:before{
	content: url("/_assets/content/dhw_icons/csv.svg");
	width: 20px; 
	height: 20px; 
	left: -20px;
	top: 8px;
	filter: invert(28%) sepia(14%) saturate(1824%) hue-rotate(199deg) brightness(97%) contrast(87%);
	position: relative;
	display: inline-block;
}

.csvlink:hover{
	color: #8789AA;
	cursor: pointer;
}

.oa-deny {
	background-image:url("/_assets/content/dhw_icons/deleteCircle.svg");
	background-repeat: no-repeat;
	background-size: 30px;
	filter: invert(57%) sepia(0%) saturate(1580%) hue-rotate(249deg) brightness(94%) contrast(87%);
}
.oa-confirm {
	background-image:url("/_assets/content/dhw_icons/checkCircleFull.svg");
	background-repeat: no-repeat;
	background-size: 30px;
	filter: invert(28%) sepia(14%) saturate(1824%) hue-rotate(199deg) brightness(97%) contrast(87%);
}

.pop-deny {
	background-image:url("/_assets/content/dhw_icons/deleteCircle.svg");
	background-repeat: no-repeat;
	background-size: 30px;
	filter: invert(100%) sepia(9%) saturate(7464%) hue-rotate(179deg) brightness(109%) contrast(107%);
}
.pop-confirm {
	background-image:url("/_assets/content/dhw_icons/checkCircleFull.svg");
	background-repeat: no-repeat;
	background-size: 30px;
	filter: invert(100%) sepia(9%) saturate(7464%) hue-rotate(179deg) brightness(109%) contrast(107%);
}

.oa-deny:hover, .pop-deny:hover{
	background-image:url("/_assets/content/dhw_icons/deleteCircleFull.svg");
	filter: invert(14%) sepia(99%) saturate(6355%) hue-rotate(353deg) brightness(88%) contrast(103%);
}
.oa-confirm:hover, .pop-confirm:hover {
	/*background-color: #76AC38;*/
	filter: invert(58%) sepia(9%) saturate(2729%) hue-rotate(46deg) brightness(103%) contrast(85%);
}

.slotbtn {
	background-image:url("/_assets/content/dhw_icons/deleteCircleFull.svg");
	background-repeat: no-repeat;
	background-size: 20px;
	rotate: 45deg;
	filter: invert(100%) sepia(9%) saturate(7464%) hue-rotate(179deg) brightness(109%) contrast(107%);
}

li.slot:hover .slotbtn{
	background-image:url("/_assets/content/dhw_icons/deleteCircleFull.svg");
	filter: invert(89%) sepia(16%) saturate(241%) hue-rotate(202deg) brightness(91%) contrast(87%);
}

.angefragt, .bestaetigt {padding-left: 10px;}
.angefragt:before{
	background-image: url("/_assets/content/dhw_icons/info.svg");
	background-size: 20px 20px;
	background-repeat: no-repeat;
	width: 20px;
	height: 20px;
	left: -10px;
	top: 3px;
	filter: invert(78%) sepia(91%) saturate(2303%) hue-rotate(338deg) brightness(95%) contrast(92%);
	position: relative;
	display: inline-block;
	content: "";
}
.bestaetigt:before{
	background-image: url("/_assets/content/dhw_icons/checkCircle.svg");
	background-size: 20px 20px;
	background-repeat: no-repeat;
	width: 20px;
	height: 20px;
	left: -10px;
	top: 3px;
	filter: invert(58%) sepia(9%) saturate(2729%) hue-rotate(46deg) brightness(103%) contrast(85%);
	position: relative;
	display: inline-block;
	content: "";
}

.editicon, .infoicon {
	filter: invert(57%) sepia(0%) saturate(1580%) hue-rotate(249deg) brightness(94%) contrast(87%);
	width: 20px;
	margin-top: 5px;
}

.closepopupicon {
	filter: invert(100%) sepia(91%) saturate(0%) hue-rotate(246deg) brightness(104%) contrast(101%);
	width: 15px;
}

.closedenyicon img{
	width: 12px;
}
.closedenyicon{
	width: 12px;
	position: absolute;
	right: 10px;
	top: 5px;
}

.removeslot{
	filter: invert(100%) sepia(91%) saturate(0%) hue-rotate(246deg) brightness(104%) contrast(101%);
	width: 10px;
}

.dateicon{
	filter: invert(100%) sepia(91%) saturate(0%) hue-rotate(246deg) brightness(104%) contrast(101%);
	position: absolute;
	top: 56px;
	left: 280px;
	width: 20px;
}

.dateicon:hover, input#showdate:hover, .editicon:hover, .calelement ul li:hover, .relaodasks, .quartal:hover {
	cursor: pointer;
}


.loginbtn:hover{cursor: pointer; background-color: #8789AA; }

.forwardicon{
	width: 15px;
	rotate: 270deg;
	
}
.backicon{
	width: 15px;
	rotate: 90deg;
}




/*CALNEDER********************************************************/

.monthheadinner b {font-size: 20px;}

.calday.active{
	background-color: #C9C9DB;
	border: 2px solid #494C80 !important;
}

li.active, .calelement .confirm-btn, .calelement .submitbtn {
	background-color: #494C80 !important;
	color: #ffffff;
}

li.bookedslot{
	border-bottom: 1px solid #ffffff;
}

.calelement #confirm {
	color: #ffffff;
}
.calelement #confirm .svg{
	background-image:url("/_assets/content/dhw_icons/check.svg");
	background-repeat: no-repeat;
	background-size: 20px;
	height: 20px;
	width: 20px;
	float: right;
	top: 2px;
	right: 10px;
	position: relative;
	filter: invert(100%) sepia(91%) saturate(0%) hue-rotate(246deg) brightness(104%) contrast(101%);
}

.calelement #confirm, .calelement .confirm-btn {
	padding: 15px;
}

.calelement .confirm-btn {
	max-width: 200px;
	margin: 30px auto;
}

.calelement #confirm:hover, .calelement .confirm-btn:hover, .calelement .genbtn:hover {
	background-color: #8789AA;
	cursor: pointer;
}

.calelement .deny-denying-btn{
	color: #494C80;
	text-decoration: underline;
}
.calelement .deny-denying-btn:hover, .deny-edit-btn:hover {color: #8789AA; cursor: pointer;}
#confirm-edit-btn:hover {cursor: pointer;}

.calelement #confirm-wrap {
	display: none;
	background-color: #494C80;
	color: #ffffff;
	/*position: absolute;*/
	position: fixed;
	right: 0;
	width: 100%;
	text-align: center;
	z-index: 300 ;
}
.calelement #slotselect * {font-size: 14px; font-weight: bold;}

.calelement #slotselect, .calelement #hide-slotselection {
	display: none;
}

.calelement .slotsection {
	border-bottom: 1px solid #ffffff;
	/*padding: 15px;*/
}

#askeditformsubmit{font-weight: bold;}

#slotsemptymessage {text-align: left; color:#C9C9DB; }

.calelement .slotsection *, .calelement .askeditsection * {
	color: #ffffff;
}

.calelement li.slot, .calelement li.popup-slot {
	align-items: center;
	gap: 10px;
	margin: 5px 0px;
}

.calelement li.slot:hover, .calelement li.pickedslot:hover, .calelement li.popup-slot:hover {
	color: #C9C9DB;
	/*background-color: #494C80;*/
}

.calelement li.pickedslot, .calelement li.popup-pickedslot {
	justify-content: space-between;
	padding: 5px 15px;
}
li.popup-pickedslot:first-of-type {
	padding-top: 15px;
}
li.popup-pickedslot:last-of-type {
	padding-bottom: 15px;
}

.calelement .popup-header {
	justify-content: space-between;
	padding: 15px;
}

.calelement .slotsection, .calelement ul.popup-slotselection, .module_onepage ul.popup-slotselection {
	padding: 15px;
}

.askeditsubmit {padding:15px; border: none; border-top: 1px solid #ffffff;}
.forminner {padding:15px;}



.module_onepage ul.popup-slotselection {
	padding: 15px!important;
}

.nav_oacount_wrap, .oacount_wrap{
	display: inline-block;
	position: absolute;
}
.nav_oacount{
	display: inline-block;
	position: relative;
	margin-left: 20px;
	width: 28px;
	height: 28px;
	border-radius: 28px;
	background-color: #E30613;
	color: #ffffff;
	text-align: center;
	top: -5px;
	padding-top: 4px;
	font-size: 16px;
}
.oacount{
	display: inline-block;
	position: relative;
	margin-left: 20px;
	width: 28px;
	height: 28px;
	border-radius: 28px;
	background-color: #E30613;
	color: #ffffff;
	text-align: center;
	top: -3px;
	padding-top: 3px;
	font-weight: bold;
}

.calelement ul#slotlist, .calelement ul#popup-slotlist {
	padding: 0!important;
	text-align: left;
}

.calelement ul#popup-slotlist li.bookedslot {
	padding: 15px;
}

.calelement .popup-confirm-wrap {justify-content: space-between;}

.calelement .popup-confirm, .calelement .oa-conordeny {column-gap: 5px; padding: 5px;}

.calelement .slotbtn {
	width: 20px;
	height: 20px;
	border-radius: 50px;
	padding-right: 5px;
}
.calelement .popup-btn, .calelement .oa-btn {
	width: 30px;
	height: 30px;
	border-radius: 50px;
}

.calelement .popup-btn {
	/*background-color: #ffffff;*/
}

.calelement table{
	border-spacing: 5px;
	table-layout:fixed;
	padding: 0px 10px;
}

.calelement tbody{
}

.calelement td.calday {
	width:50px;
	max-width:50px;
	height:50px;
	max-height:50px;
	white-space: nowrap;
	overflow-x: hidden;
	font-size:14px;
	font-weight:bold;
	padding: 5px;
	vertical-align: bottom;
}

.calelement.module_cal td.calday.open {
	border: 1px solid #D3D3D3;
	color: #000000;
}

.calelement.module_cal td.calday.open:hover {
	border: 1px solid #494C80;
	cursor: pointer;
}

.calelement td.calday.empty {
	background-color: #F2F2F2!important;
	border: none!important;
}

.calelement td.calday.feiertag {
	background-color: #D3D3D3;
	color:#888888;
}

.calelement .filter-wrap{
	border: 1px solid #D3D3D3;
	border-radius: 15px;
	padding: 30px;
	margin: 30px 10px 10px;
}

.calelement .quickstitle {
	margin: 0 0 20px 5px;
	color: #494C80;
}

.calelement ul.quickselect li {
	background-color: #F2F2F2;
	border-radius: 50px;
	text-align: center;
	width:125px;
	margin: 5px;
  	padding: 4px 10px;
}

.calelement ul {
	color: #000000;
}

.calelement .askmonth {
	width:300px;
	height:400px;
	display: inline-block;
	border: 1px solid #D3D3D3;
	margin: 10px;
	/*padding: 10px;*/
}

.calelement .calmonth {
	display: inline-block;
	border: 1px solid #D3D3D3;
	/*padding: 10px;*/
}

.calelement .monthhead{
	border-bottom: 1px solid #D3D3D3;
	padding: 10px;
}
.calelement .monthheadinner{
	justify-content: space-between;
}

.calelement .calmonth th {
	padding: 10px 0 5px;
}

.calelement .month{
	cursor: pointer;
	position: relative;
	top: -25px;
}

.calelement .month.active{
	background-color: #494C80;
}

.calelement .weekheading th {
	text-align: center;
	color: #000000;
}

.calelement .monthtoggle{
	background-color: #D3D3D3;
	border-radius: 30px;
	width: 35px;
	height: 20px;
}


.calelement .monthtoggle.active .togglecircle{background-color: #C9C9DB; left: 17px;}

.calelement .togglecircle{
	background-color: #888888;
	border-radius: 30px;
	width: 15px;
	height: 15px;
	position: relative;
	top: 2.7px;
	left: 3px;
	transition: left 0.5s;
}

.undo-selection {
	display: none;
	color: #494C80;
	text-decoration: underline;
	margin: 30px 10px;
	text-align: right;
	position: relative;
}

.legende-wrap {align-items: center; justify-content: space-between;}

/**/

.calelement .calday .marks p, .legende .marks p{display: inline; height: 8px; position: relative;}
.calelement .calday .marks p:after{
	content: "\2022";
	position: relative;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	font-size:25px;
	right: -28px;
	top: -27px;
}
.calelement .calday .marks {display: flex; flex-direction: column; position: absolute;}


.calelement .calday .marks2 p:after{right: -20px;}
.calelement .calday .marks3 p:after{right: -14px;}


.legende .marks {position: absolute;}
.legende .marks p:after{
	content: "\2022";
	position: relative;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	font-size: 35px;
	left: 15px;
}


.module_cal .calday .set, .module_asks .calday .set, .module_appointments .calday .set, .legende .set{color: #494C80;}
.module_cal .calday.set, .module_asks .calday.set, .module_appointments .calday.set{background-color: #C9C9DB;}

.calelement .calday .gebucht, .legende .gebucht{color: #E6C927;}
.calelement .calday.gebucht{background-color: #F8EEBE!important;}

.calelement .calday .confirmed, .legende .confirmed{color: #76AC38;}
.calelement .calday.confirmed{background-color: #C8E0AC!important;}


.calelement #statusmessage{
	background-color: #F8EEBE;
	padding: 30px;
	display: none;
	gap: 20px;
	align-items: center;
}
.calelement.module_cal #statusmessage{
 	margin: 10px;
}
.calelement.module_bookcal #statusmessage{
 	margin: 10px 0 30px;
}

.calelement #errormessage{
	display: none;
}

.calelement #denypopup, .calelement #editconfirmpopup{
	background-color: #ffffff;
	display: none;
	position: fixed;
	padding: 40px 50px;
	top: 5vh;
	z-index: 600;
	text-align: center;
	max-height: 90vh;
	overflow: scroll;
}
.calelement #denypopup h3, .calelement #editconfirmpopup h3{
	color: #333333;
	margin-bottom: 40px;
}

.calelement #edit-popup, .calelement .info-popup{
	background-color: #494C80;
	display: none;
	position: absolute;
	z-index: 200;
	width: 280px;
	border-radius: 15px;
}

.calelement .info-popup{
	padding: 20px;
}
.calelement .info-popup p{
	color: #ffffff;
}


.calelement #edit-popup.active, .calelement .info-popup.active{
	display: block !important;
}
.calelement #edit-popup:before, .calelement .info-popup:before {
	content: "";
	color: #494C80;
	width: 0; 
	height: 0; 
	border-left: 20px solid transparent;
	border-right: 20px solid transparent;
	border-bottom: 20px solid #494C80;
	position: absolute;
	top: -10px;
}
.askeditsection #popup-exit, .info-popup .infopopup-exit{position: absolute; top: 15px; right: 15px;}
.calelement #popup-exit:hover, .info-popup .infopopup-exit:hover{
	cursor: pointer;
}

.calelement .flip-btn{
	display: block;
}
.calelement .flip-btn:hover{
	cursor: pointer;
}




/*BOOKING*/

.module_bookcal #cal-wrap{
	display: inline-block;
}

.module_bookcal #bookform-wrap{
	display: inline-block;
}

.module_bookcal .submitbtn{
	width: 200px;
	padding: 15px!important;
	margin: 10px 0 20px!important;
}
.module_bookcal .submitbtn *{font-weight: bold;}

.module_bookcal .formelement, .module_asks .formelement, .module_appointments .formelement{
	border: 1px solid #D3D3D3;
	margin-bottom: 10px;
	padding: 10px;
}
.module_bookcal .custom-select-wrapper {
	margin-bottom: 10px;
}

.module_bookcal #bookform-wrap{
	border: 1px solid #D3D3D3;
}

.module_bookcal .bookfrom-heading{
	border-bottom: 1px solid #D3D3D3;
	padding: 10px 20px;
}

.module_bookcal .bookform{
	padding: 20px 30px;
}

.module_bookcal .bookform label{
	margin: 0px;
	color: #888888;
	font-size: 14px;
	padding-top: 10px;
}
.module_bookcal .bookform label.message{
	color: #333333;
	margin: 10px 0;
}

.module_bookcal .legende, .module_cal .legende {
	margin: 0px 0px 10px 0px;
}
.module_bookcal .legende .legel {
	margin: 5px 0px;
}
.module_cal .legende {
	flex-direction: column;
	margin: 30px 10px;
	gap: 10px;
}

.module_bookcal .legende .legel, .module_cal .legende .legel{
	align-items: center;
}

.module_bookcal .legende .nv-square{ width: 15px; height: 15px; background-color: #D3D3D3; margin-right: 30px; flex-shrink: 0; }
.module_bookcal .legende .ft-square{ width: 15px; height: 15px; border: 1px solid #D3D3D3; margin-right: 30px; flex-shrink: 0; }
.module_bookcal .legende .bo-square{ width: 15px; height: 15px; background-color: #F9EBBD; margin-right: 30px; flex-shrink: 0; }
.module_bookcal .legende .bs-square{ width: 15px; height: 15px; background-color: #C8E0AC; margin-right: 30px; flex-shrink: 0; }

.module_cal .legende .nv-square{ width: 15px; height: 15px; background-color: #D3D3D3; margin-right: 30px; flex-shrink: 0; }
.module_cal .legende .ft-square{ width: 15px; height: 15px; background-color: #C9C9DB; margin-right: 30px; flex-shrink: 0; }
.module_cal .legende .bo-square{ width: 15px; height: 15px; background-color: #F9EBBD; margin-right: 30px; flex-shrink: 0; }
.module_cal .legende .bs-square{ width: 15px; height: 15px; background-color: #C8E0AC; margin-right: 30px; flex-shrink: 0; }


.calelement.module_bookcal td.calday.free {
	border: 1px solid #D3D3D3;
	color: #888888;
	background-color: #D3D3D3;
}

.calelement.module_bookcal .calday .set{color: #494C80;}
.calelement.module_bookcal .calday:hover .set{color: #494C80;}
.calelement.module_bookcal .calday.active .set{color: #494C80;}
.calelement.module_bookcal .calday.set{border: 1px solid #D3D3D3;}
.calelement.module_bookcal .calday.set:hover { border: 1px solid #494C80; cursor: pointer;}


.calelement.module_bookcal .calmonth{
	margin: 0px 0px 10px 0px!important;
	/*padding: 10px;*/
}

.module_bookcal input::placeholder, .module_bookcal textarea::placeholder, .module_bookcal .pholder {
	font-weight: normal;
	font-style: italic;
	color: #888888!important;
}


/*VIEWASKS*/

/*.module_onepage #asktable{margin: 30px 10px; width: 949px;}*/
body.org .module_onepage .cwrap {margin: 10px 10px 0px;}

.calelement table.asktable{
	width: 100%;
	border-collapse: collapse;
	margin: 40px 0px;
}

.calelement table.asktable tr.asktablehead:not(.onepagehead), .module_billing table.billingtable tr.asktablehead{
	border-top: 1px solid #D3D3D3;
}

/*.asktablesingle*/
.calelement table.asktable td{
	vertical-align: top;
	padding: 20px 0;
	word-wrap: break-word;
}

.module_viewasks table.asktable tr.asktablehead th, .module_billing table.asktable tr.asktablehead th, .module_billing table.billingtable tr.asktablehead th {
	height: 45px;
}
.module_viewasks table.asktable tr {
	/*height: 65px;*/
}
.module_viewasks table.asktable tr.noborder {
	height: 50px;
}

.calelement table.asktable tr.noborder td {
	padding-top: 0px;
}

.calelement table.asktable tr{
	border-bottom: 1px solid #D3D3D3;
	position: relative;
}

.calelement table.asktable a{text-decoration: underline;}
.calelement table.asktable a:hover{cursor: pointer;}


/*OFFENE ANFRAGEN*/

.module_asks tr.onepagehead {
	border:1px solid #E9BB24;
}
.module_viewasks tr.onepagehead {
	border:1px solid #494C80;
}

.alleterminea {float: right; /*margin-right: 20px;*/}

.logintoptext {display: none;}

.calelement .oa-btn {
	/*background-color: #494C80;*/
}

.module_asks option, .calelement option {
	left: 50px;
	top: -50px;
}

.calelement.module_asks .calday{border:1px solid #ffffff; }
.calelement.module_asks .calday.open {border: 1px solid #D3D3D3; }
.calelement.module_asks .calday.set:hover { border: 1px solid #494C80; cursor: pointer;}

.calelement.module_appointments .calday{border:1px solid #ffffff; }
.calelement.module_appointments .calday.open{border: 1px solid #D3D3D3; }
.calelement.module_appointments .calday.set:hover { border: 1px solid #494C80; cursor: pointer;}

.calelement option:hover {
	background-color: #8789AA;
}

.tdhide {display: none;}

.asktable {}

.calelement table.asktable tr:not(.onepagehead), .module_billing table.billingtable tr{
	border-top: 1px solid #D3D3D3;
	border-bottom: 0px;
}

.module_asks #edit-popup, .module_appointments #edit-popup, .calelement .info-popup{
	background-color: #494C80;
	display: none;
	position: absolute;
	z-index: 200;
	border-radius: 15px;
	width: 330px;
}

/*.calelement td.nothide {display: flex;}*/
.module_onepage .calelement tr.asktablehead {display: table-row;}
.module_viewasks tr.asktablehead th,.module_appointments tr.asktablehead th,.module_billing tr.asktablehead th,.module_asks tr.asktablehead th:not(.onepagetheader) {
	font-weight: normal; 
	color: #888888; 
	padding: 5px 0px;
}

.module_billing table.billingtable{
	width: 100%;
	border-collapse: collapse;
	margin: 0px 0px;
	display: block;
	overflow-x: auto;
	white-space: nowrap;
}

.module_billing table.billingtable tbody {
    display: table;
    width: 100%;
}

/*.asktable td.asktableslot {padding: 0px!important;}*/
.asktable td.asktableklasse {}

.asktable td.oa-confirm-wrap {position: absolute;}



#editcal-wrap .calmonth, #editcal-wrap .askmonth{margin: 0px 0px 10px 0px!important;}
#editcal-wrap {
	display: none;
	position: absolute;
	z-index: 300;
	background-color: #ffffff;
}


/*ONEPAGE TABLE STUFF*/

.calelement.viewasksmodule .onepagetheader * {
	color: #ffffff!important;
}

.calelement table.onepagetable tr.asktablehead{
	background-color: #E9BB24!important;
}

 .onepagetheader .opttitle {
	width: 300px;
}
 .onepagetheader .alleterminediv {
	position: relative;
	width: 300px;
	left: -270px;
}
.calelement.viewasksmodule .onepagetheader {
	padding: 10px 30px!important;
	background-color: #494C80!important;
}
.calelement.asksmodule .onepagetheader {
	background-color: #E9BB24!important;
}
.calelement .onepagetable {
	margin: 10px;
	border: 1px solid #D3D3D3;
}

.calelement .onepagetable .asktabledatum {
	padding-left: 30px!important;
}


/*LOGIN*/

form.smallform{
	padding: 30px 40px 20px;
}
#bgimg{
	background-image: url("/_assets/content/dhw_icons/dhw_background.png");
	background-repeat: no-repeat;
	background-size: cover;
	filter: blur(8px);
  	-webkit-filter: blur(8px);
	width: 100%;
	position: absolute;
	left: 0px;
	top: 65px;
	z-index: -100;
}
#helpheader{
	height: 65px;
	width: 100%;
	position: absolute;
	left: 0px;
	top: 0px;
	z-index: -10;
	background-color: #ffffff;
}
body.module_login #section2 {
	height: calc(100vh - 85px);
	min-height: 850px;
}

.logospace {
	border-top: 1px solid #D3D3D3;
	width: 100%;
	background-color: #fff;
	padding: 40px;
	margin-top: 30px;
	text-align: center;
}

.module_login .logospace {display: none;}
body:not(.module_login) .loginlogospace {display: none;}
.module_login .loginlogospace {
	width: 100%;
	background-color: #fff;
	padding: 40px;
	margin: 0;
	text-align: center;
}


.module_login .inner-sm{
	background-color: #ffffff;
	margin-top: 10vh!important;
	max-width: 500px!important;
}

.module_login .logintop, .module_login .loginbottom, .module_login .loginblock {
	padding: 10px;
}

.module_login .logintop {
	text-align: center;
	text-transform: uppercase;
	background-color: #494C80;
}
.module_login .logintop *{
	color: #ffffff;
}

.module_login .loginbottom, .module_login .loginblock {
	background-color: #F9EBBD;
	padding: 40px;
}

.module_login input {
	border: 1px solid #D3D3D3!important;
	padding: 10px;
	margin: 5px 0px;
}

.module_login input::placeholder {
	font-weight: normal;
	font-style: italic;
	color: #000000!important;
}

.loginbtn {
	width: 140px;
}

.loginresetbtn {
	width: 300px;
}

.module_login a{color: #494C80;}

.logolist{
	list-style: none;
	text-align: center;
	margin-bottom: 30px;
	padding: 20px 0 30px;
}
.logolist-mid{
	list-style: none;
	text-align: center;
	padding: 20px 0 0px;
}
.module_login .logolist{
	border-bottom: 1px solid #D3D3D3;
}

.logolist img, .logolist-mid img{height:60px;}
.logolist img.mid, .logolist-mid img.mid{height:50px;}
.logolist img.small, .logolist-mid img.small{height:40px;}

.forgotpsw{display: block; margin-bottom: 20px;}
.forgotpsw a{float: none;}

/*BILLING*/
.billingmonth *, .quartal * {
	color: #333333;
}
.billingmonth, .quartal {
	margin: 50px 0px 10px;
	display: flex;
	justify-content: space-between;
	width: 100%;
}
.billingtable td {
	word-wrap: break-word;
	vertical-align: top;
  	padding: 20px 15px 20px 0px;
}
.billingtable td.whitespacewrap {
	white-space: normal;
}

.quartal {
	/*border: 1px solid #D3D3D3;*/
	background-color: #F9EBBD;
	padding: 10px;
}

.quartal div.flex {
	gap: 15px;
}
.quartal div.flex * {
	font-size: 18px;
}

.billingbtn{
	display: flex;
	margin-top: 50px;
	justify-content: flex-end;
}
.billingbtn .genbtn{
	text-align: center;
}

.calelement.module_bookcal .booking-wrap{margin: 30px 0;}


/*RESPONSIVE***********************************************************************************/


/*LOGIN*****************************/

@media screen and (min-height: 790px) {
	@media screen and (min-width: 500px) {
		/*TALLER AND WIDER*/
		.module_login .nav-content-wrap {
			height: calc(100vh - 85px);
		}
		#bgimg{
			height: calc(100vh - 65px);
		}
	}
	@media screen and (max-width: 499px) {
		/*NARROWER AND TALLER*/
		.module_login .nav-content-wrap {
			height: 1015px;
		}
		#bgimg{
			height: 1120px;
		}
	}
}
@media screen and (max-height: 789px) {
	@media screen and (max-width: 500px) {
		/*NARROWER AND SHORTER*/
		.module_login .nav-content-wrap {
			height: 1015px;
		}
		#bgimg{
			height: 1120px;
		}
	}
	@media screen and (min-width: 499px) {
		/*SHORTER AND WIDER*/
		.module_login .nav-content-wrap {
			height: 670px;
		}
		#bgimg{
			height: 690px;
		}
	}
}

@media screen and (max-width: 369px) {
	#husername {
		width: 150px;
	}
}
@media screen and (min-width: 370px) {
	@media screen and (max-width: 420px) {
		#husername {
			width: 200px;
		}
	}
}
@media screen and (min-width: 421px) {
	@media screen and (max-width: 500px) {
		#husername {
			width: 270px;
		}
	}
}

/*365/364************* KALENDER ****************/
@media screen and (min-width: 365px) {
	.calelement .calmonth, .calelement .askmonth {
		width:300px;
		height:400px;
	}
	/*HERE*/
	.module_appointments #editcal-wrap, .module_asks #editcal-wrap {
		width: 300px;
	}
}
@media screen and (max-width: 364px) {
	.module_appointments #editcal-wrap, .module_asks #editcal-wrap {
		width: 260px;
	}
	.calelement .calmonth, .calelement .askmonth {
		width:260px;
		height:360px;
	}
	.calelement .calmonth table, .calelement .askmonth table {
		padding: 0px 0px;
	}
	.calelement td.calday {
		width: 46px;
		max-width: 46px;
		height: 46px;
		max-height: 46px;
	}
	.calelement .month {
		left: 185px;
	}
	.calelement .calday .marks p::after {
		right: -25px;
		top: -24px;
	}
	.calelement .calday .marks2 p::after {
	  right: -18px;
	}
	
	.module_asks #edit-popup, .module_appointments #edit-popup, .calelement .info-popup {
		width: 290px;
	}
	.dateicon {
	  left: 245px;
	}
	
	.calelement #edit-popup:before{
		right: 120px;
	}
	.calelement .info-popup:before{
		right: 80px;
	}
	.calelement #edit-popup, .calelement .info-popup{
		right: -265px;
		top: -4px;
	}
	
}

/*589/590*****************************/

@media screen and (max-width: 589px) {
	.module_login .inner-sm{
		margin-left: 40px!important;
		margin-right: 40px!important;
	}
	.calelement ul.quickselect li {
		margin: 10px auto;
	}
	.calelement .filter-wrap{text-align: center}
	.calelement #confirm-wrap{bottom: 0}
	
	.billingbtn .genbtn{
		width: 100%;
	}
	
	.billingmonth, .quartal {
	  flex-direction: column;
	  align-items: flex-start;
	}
	
	
	.module_onepage .calelement tr.asktablehead {
	  display: flex;
	  flex-direction: column;
	}
	.onepagetheader .alleterminediv {
	  position: static!important;
	}
	.onepagetheader.nosmall {
	  display: none!important;
	}
	.onepagetheader.upper {
	  padding: 20px 20px 10px !important;
	}
	.onepagetheader:not(.nosmall):not(.upper) {
	  padding: 10px 20px 20px !important;
	}
	.alleterminea {
	  float: none!important;
	}
	
	
	.quartal div.flex {
		justify-content: space-between;
		width: 100%;
	}
	.quartal div.flex .downarrowicon:after {
		top: -15px;
	}
	
	.module_bookcal .submitbtn {
		width: 100%;
	}
	
}
@media screen and (min-width: 590px){
	.calelement ul.quickselect {
		display: flex;
	}
	.calelement #confirm-wrap{ bottom: 10vh; width: 230px}
	.billingbtn .genbtn{
		width: 200px;
	}
	
	.billingmonth, .quartal {
	  flex-direction: row;
	  align-items: center;
	}
	
	.quartal div.flex .downarrowicon:after {
		top: -3px;
	}
	
	.calelement.asksmodule .onepagetheader {
		padding: 10px 20px!important;
	}
}

/*749/750*****************************/

@media screen and (max-width: 749px) {
	#cal-wrap{text-align: center;}
	#cal-wrap .calday *{text-align: left;}
	
	@media screen and (min-width: 365px) {
		.calelement .month{
			left: 225px;
		}
	}
}

@media screen and (min-width: 750px) {
	.calelement .month{
		left: 235px;
	}
}


/*959/960*****************************/

@media screen and (min-width: 960px) {
	
	.logolist img, .logolist-mid img {margin: 20px;}
	
	@media screen and (max-width: 1269px) {
		.module_appointments #edit-popup:before{
			right: 30px;
		}
		.module_appointments .info-popup:before, .module_asks #edit-popup:before{
			right: 80px;
		}
		.module_asks .info-popup:before{
			right: 120px;
		}
	}
	
	.calelement #edit-popup, .calelement .info-popup{
		right: 10px;
		top: 50px;
	}
	
	.calelement #denypopup, .calelement #editconfirmpopup{
		left: 20%;
		width: 60%;
	}
	/*table td:not(.asktabledatum):not(.oa-confirm-wrap){ */
	table:not(.billingtable) td:not(.oa-confirm-wrap){ 
		padding-left: 5px;
		padding-right: 5px;
	}
	
	.meta-above{display: inline-block;}
	.mobileel{display: none;}
	
	.module_asks .csvlink{
		margin-top: 30px;
	}
	
	.csvlink{
		float: right;
		position: relative;
		top: -20px;
	}
	
	
	#statusmessage{
		flex-direction: row;
		gap: 10px;
		padding: 15px;
	}
	.statusinner{text-align: left;}
	
	
	.module_cal.calelement .flip-btn{
		display: none;
	}
	
	.calelement.module_cal .monthheadinner{
		justify-content: center;
	}
	
	.tdhide {
		display: table-cell;
		visibility: hidden;
	}
	/*.calelement td.nothide {display: table-cell;}*/
	.calelement tr.asktablehead {display: table-row;}
	
	/*.asktable td.oa-confirm-wrap {position: static;}*/
	.calelement .oa-conordeny {position: static;}
	
	.calelement #asktable .oa-conordeny {
		position: relative;
		left: 0px;
		top: -8px;
	}
	
	.calelement #asktable .askeditlink, .calelement #asktable .askinfolink {
		position: relative;
		left: 0px;
		top: -5px;
	}
	
	.calelement.asksmodule table.asktable {
	  margin: 0px;
	}
	

	
	#logo {
	  position: absolute;
	  top: -5px;
	  left: 45px;
	}
	
	#section2 {margin-top: 0px;}
	
	.logolist, .logolist-mid{display: flex;justify-content: center;flex-wrap: wrap; align-items: center;}
	.module_login a{float: right;}
	.forgotpsw{display: inline;}
	.logintoptext {display: inline; margin: 0 0 0 280px;}
	.module_login #header .inner{justify-content: space-between;}
	#nav li {display: block;}
	#navasideanchor {display: none;}
	
	
	#section2{width: min(calc(100% - 300px),950px);}
	.nav-content-wrap{display: flex;}
	.navaside {display: block; /*min-width: 300px; max-width: 300px;*/ width: 300px}
	.angemeldet {display: block;}
	.logoutbtn {display: block;}
	.userbanner {padding: 7px 100px;}
	.meta-above-logout {display: none;}
	
	.calelement.module_bookcal .booking-wrap{display: flex; column-gap: 20px;}
	.calelement .oa-conordeny {
	  position: relative;
	  left: 250px;
	  top: -55px;
	}
	.module_onepage #asktable{
		margin: 30px 10px;
  		/*width: 949px;*/
		width: calc(100% - 20px)
	}
	
	.calelement .calmonth {
		margin: 10px;
	}
	
	.module_login .inner-sm {
		margin: 10vh auto 0;
	}
	
	.calelement.asksmodule .onepagetheader {
		padding: 10px 30px !important;
	}
	
	
}

@media screen and (max-width: 959px){
	
	.logolist img, .logolist-mid img {margin: 20px 0px;}
	
	.calelement:not(.module_billing) tr.asktablehead:not(.onepagehead) {display: none;}
	
	.calelement .calmonth{ margin: 10px auto;}
	
	.askedit-wrap, .askinfo-wrap {
		position: absolute;
	}
	.askeditlink {
		position: relative;
		top: -40px;
		/*right: -150px;*/
		right: -175px;
	}
	.askinfolink {
		position: relative;
		top: -40px;
		/*right: -150px;*/
		right: -135px;
	}
	.oa-conordeny{
		position: relative;
  		/*top: 10px;*/
	}
	
	#statusmessage{
		flex-direction: column;
		align-items: center;
		margin: 10px 0px;
	}
	#statusmessage{
		text-align: center;
	}
	
	table:not(.billingtable) td:not(.calday):not(.tdhide){ 
		display: block;
		/*padding: 0px 20px!important; padding: 0 15px; */
	}
	table.onepagetable td:not(.calday):not(.tdhide){ 
		padding: 0px 20px!important;
	}

	.calelement .onepagetable .asktabledatum{
		padding-left: 15px !important;
		margin: 15px 0;
	}
	.module_onepage .module_viewasks.calelement table.asktable td{ 
		padding: 0 30px; /*padding: 0 15px;*/
		white-space: nowrap;
	}
	.module_asks.calelement table.asktable td, .module_appointments table.asktable td {
		padding: 0px; 
	}
	.module_viewasks.calelement table.asktable td.asktabledatum{ 
		padding-top: 15px;
	}
	.module_viewasks.calelement table.asktable td.confirmation{
		padding-bottom: 15px!important;
	}
	.calelement table.asktable td.date, .calelement table.asktable td:last-child:not(.oa-confirm-wrap), .calelement table.asktable td.asktableslot{ margin-bottom: 15px}
	.calelement table.asktable td.confirmation{white-space: nowrap}
	.asktable td.asktableklasse{margin-top: 15px}
	td.oa-confirm-wrap{
		position: absolute;
		right: 0;
		bottom: 15px;
	}
	
	@media screen and (min-width: 365px) {
		.calelement #edit-popup:before{
			right: 115px;
		}
		.calelement .info-popup:before{
			right: 155px;
		}
		.calelement #edit-popup, .calelement .info-popup{
			right: -300px;
			top: -4px;
		}
	}
	
	
	#navwrap {
		background: #ffffff!important;
		padding: 0px!important;
	}
	#navwrap .nav__element {border-bottom: 1px solid #D3D3D3!important;}
	
	.csvlink{
		margin-top: 20px;
	}
	
	.calelement #denypopup, .calelement #editconfirmpopup{
		left: 10%;
		width: 80%;
	}
	
	.billingtable .noshow {display: none;}
	
	.calelement table td.asktabledatum {
		margin-top: 15px;
	}
	
	.module_bookcal .legende {
		margin: 30px 0;
	}
	
	.module_bookcal .bookform label{
		padding-top: 15px;
	}

}

/*1269/1270*****************************/

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

	.inner-sm:not(.module_login) {margin: 20px 20px 0;}
	
	.billingtable .firstnoshow {display: none;}
	
	.legende-wrap {
	  align-items: flex-start;
	}
  
}
@media screen and (min-width: 1270px) {
	.formsection{display: flex; gap: 20px;}
	.formsection .growsection {flex-grow: 1;}
	.firstsection {width: 190px;}
	.timesection {width: 220px;}
	
	.module_cal .legende {
		flex-direction: row;
		gap: 30px;
	}
	.legende-wrap {
	  align-items: center;
	}
	.module_appointments #edit-popup:before{
		right: 50px;
	}
	.module_appointments .info-popup:before, .module_asks #edit-popup:before{
		right: 100px;
	}
	.module_asks .info-popup:before{
		right: 148px;
	}
}
