/* css zu normen *//* Baurecht_NormenCSS  */#baurechtLinks, #baurechtRechts {font-size: 18px;}

#baurechtLinks {width: 420px !important;}

#baurechtRechts {width: calc(100% - 420px) !important;}

#baurechtTreeHeadline, #baurechtAusgabeHeadline {
	border-top: none !important;
	padding-top: 0 !important;
}

@media (max-width: 1024px) {
	#baurechtLinks, #baurechtRechts {width: 100% !important;}
	#baurechtLinks {margin-bottom: 0;}
}

#baurechtAusgabeHeadline b {
	font-size: 24px;
	color: var(--green);
}

.baurechtWrapper #baurechtAusgabeHeadline b {
	font-size: 260%;
	line-height: normal;
	text-transform: uppercase;
	font-family: var(--hgbRegular);
}/* --- --- *//* BaurechtNormenV2CSS  *//* ----------------------------------- */
/* --------------- Tree -------------- */
/* ----------------------------------- */
#baurechtLinks {
	width: 33.33%;
	display: inline-block;
	vertical-align: top;
}
#baurechtTreeHeadline {
	border-top: 3px solid #CCE7D9;
	padding-top: 30px;
	margin-bottom: 20px;
}
#baurechtTree_mobile_chk, #chkBaurechtTree, #lblBaurechtTreeHideBereich, #lblBaurechtTreeShow {display: none;}
#baurechtTree {
	margin: 0;
	padding-left: 0;
	line-height: 150%;
}
#baurechtTree ul {
	display: none;
	padding-left: 20px;
	margin: 5px 0;
}
#baurechtTree li.openleaf > ul {display: block;}
#baurechtTree li {
	list-style: none;
	position: relative;
	margin-bottom: 5px;
}
#baurechtTree li > div {
	display: inline-block;
	width: 10px;
	height: 10px;
	margin-right: 5px;
	margin-bottom: 1px;
	background-image: url('/bilder/document_dunkelgrau.svg');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	cursor: pointer;
}
#baurechtTree li.isnode > div {
	background: none;
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	border-left: 10px solid #008542;
}
#baurechtTree li.isnode.openleaf > div {
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 10px solid #008542;
	border-bottom: none;
}
#baurechtTree a, #baustoffeTreeHeadline {
	font-weight: normal;
	color: inherit;
}
#baurechtTree li.openleaf > a {font-weight: bold;}




#baurechtTree a:hover {color: #008542;}

@media screen and (max-width: 1024px) {
	#baurechtLinks {width: 0;}
	#baurechtTreeSeitenreiter {
		height: 100%;
		width: 300px;
		position: fixed;
		top: 0;
		left: -300px;
		padding: 14px;
		z-index: 999;
		transition: 500ms;
		overflow-y: auto;
		background-color: white;
		font-size: 1rem;
	}
	#baurechtTreeHeadline {
		width: calc(100% - 30px - 14px);
		border-top: none;
		padding-top: 0;
	}
	#chkBaurechtTree:checked ~ #baurechtTreeSeitenreiter {
		left: 0;
		box-shadow: 5px 10px 18px rgba(0, 0, 0, 0.8);
	}
	
	#lblBaurechtTreeShow {
		display: block;
		width: 56px;
		height: 56px;
		background-color: #008542;
		background-image: url('/bilder/baustoffeTreeOpen.svg');
		background-repeat: no-repeat;
		background-position: center;
		background-size: 68%;
		position: fixed;
		right: 0;
		top: calc(50% - 56px/2);
		cursor: pointer;
		z-index: 2;
		border-color: white;
		border-style: solid;
		border-width: 1px 0 1px 1px;
	}
	#chkBaurechtTree:checked ~ #lblBaurechtTreeShow {
		background-image: url('/bilder/baustoffeTreeClose.svg');
		background-size: 100%;
	}
	
	#lblBaurechtTreeHide {
		display: block;
		width: 30px;
		height: 29px;
		cursor: pointer;
		position: absolute;
		top: 14px;
		right: 14px;
	}
	#lblBaurechtTreeHide::before, #lblBaurechtTreeHide::after {
		display: block;
		width: 100%;
		height: 4px;
		background-color: #008542;
		border-radius: 2px;
		content: '';
		position: absolute;
		left: 0px;
	}
	#lblBaurechtTreeHide::before {
		top: 13px;
		transform: rotate(-45deg);
	}
	#lblBaurechtTreeHide::after {
		bottom: 12px;
		transform: rotate(45deg);
	}
	
	#lblBaurechtTreeHideBereich {
		display: block;
		position: fixed;
		top: 0;
		right: 0;
		height: 100%;
		cursor: unset;
		z-index: 999;
		background-color: rgba(0, 0, 0, 0.2);
	}
	#chkBaurechtTree:checked ~ #lblBaurechtTreeHideBereich {width: 100%;}
}

/* ----------------------------------- */
/* -------------- Ausgabe ------------ */
/* ----------------------------------- */
#baurechtRechts {
	width: 66.66%;
	display: inline-block;
	vertical-align: top;
	float: right;
	padding-left: 40px;
}
#baurechtAusgabeHeadline {
	border-top: 3px solid #CCE7D9;
	padding-top: 30px;
	margin-bottom: 20px;
}
.baurechtGruen {color: #008542;}
.baurechtCol_L, .baurechtCol_R {
	display: inline-block;
	vertical-align: top;
	margin-bottom: 20px;
}
.baurechtCol_L {
	width: 200px;
}
.baurechtCol_R {
	width: calc(100% - 200px);
hyphens: auto;
overflow-wrap: break-word
}

@media screen and (max-width: 1024px) {
	#baurechtRechts {
		width: 100%;
		float: none;
		padding-left: 0;
	}
}

@media screen and (max-width: 768px) {
	.baurechtCol_L, .baurechtCol_R {width: 100% !important;}
	.baurechtCol_L {margin-bottom: 0;}
}

#baurechtTree li.isnode.openleaf > a {display:inline-block !important;}/* --- --- *//* MenueCSS  *//*Balken ueber menu*/

.GreenMenuBalken{
  height:18px;
  max-width: 1140px;
  margin:0 auto;
  padding:0.5vw 20px;
  line-height: 18px;
  box-sizing: content-box;
  display:flex;
  flex-direction: row;
}
.GreenMenuBalken img {width: 13px; margin-right:7px}
.GreenMenuBalken > div{
  display:flex;
}
.GreenMenuBalken > .leftSide{
  flex-grow: 1;
}
.GreenMenuBalken a{
  color: #61ce70;
  font-size:13px;
  display:flex;
  flex-direction: row;
  align-items: center;
  
}
.GreenMenuBalken > .leftSide a{margin-right: 20px;}
.GreenMenuBalken > .rightSiede a{margin-left:20px;}
@media (max-width: 1024px){.GreenMenuBalken{display: none;}}

/*Allgemein*/
#MainMenue{
  padding: 0 20px;
  display:flex;
  max-width: 1180px;
  width: 100%;
  margin:0 auto;
}
#MainMenue a{color:#000}
#MainMenue > input{appearance: none;}
#MainMenue > .HomeButton{
  background:url('/juba/pic/adminCompanyLogo.svg') no-repeat;
  min-width: 228px;
  background-position: center;
}
#MainMenue ul{list-style: none; padding-left:0;}
#MainMenue > ul > li > a {display:none;}
#MainMenue > ul{padding: 10px 0}

#MainMenue > ul > li > ul div{display:none}

/*Ebene 1*/
#MainMenue > ul > li > ul {
  display:flex;
  justify-content:right;
}
#MainMenue > ul > li > ul > li {
  position: relative;
  z-index: 2;
}
#MainMenue > ul > li > ul > li.isnode > a:after{
  content:'';
  margin-left:15px;
  width: 8px;
  height: 8px;
  transform: rotateZ(-45deg) scale(80%) translateY(-3px);
  border-left: 3px solid black;
  border-bottom: 3px solid black;
  display:inline-block;
  transition: ease-in-out 300ms;
}
#MainMenue > ul > li > ul > li.isnode:hover > a:after{
  border-color: var(--green);
}
#MainMenue > ul > li > ul > li > a{
  font-weight: 400;
  font-family: var(--sourceSansSemibold);
  font-size:18px;
  padding:18px;
  display: inline-block;
  line-height: 18px;
}
#MainMenue > ul > li > ul > li:hover > a{color: var(--green)}

@media (max-width: 1140px){
	#MainMenue > ul > li > ul > li > a{padding: 13px;}
	#MainMenue > ul > li > ul > li.isnode > a::after{margin-left:9px;}
}
/*Ebene 2*/
#MainMenue > ul > li > ul > li > ul{
  position: absolute;
  width: fit-content;
  min-width: 100%;
  white-space: nowrap;
  background-color:#fff;
  transition: ease-in-out 300ms;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
}
#MainMenue > ul > li > ul > li:not(:hover) > ul{
  opacity: 0;
  pointer-events: none;
}
#MainMenue > ul > li > ul > li > ul > li{
  padding: 15px 10px 15px 15px;
  border-bottom: 1px solid #E2ECF7;
  height:48px;
  transition: ease-in-out 300ms;
}
#MainMenue > ul > li > ul > li > ul > li:hover{
  background-color: #3f444b;
}
#MainMenue > ul > li > ul > li > ul > li:hover > a{color: #fff}
#MainMenue > ul > li > ul > li > ul > li > a{
  font-family: sans-serif;
  font-size:13px;
  font-weight: 600;
  line-height: 20px;
  display: inline-block;
  vertical-align: top;
}/* --- --- *//* MobileMenueCSS  *//* --------------------- MobileMenueButton --------------------- */

@media (max-width: 1024px) {  
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu_kb_show_menu {
    width: 30px;
    height: 20px;
    position: absolute;
    border-top: 4px solid black;
    border-bottom: 4px solid black;
    right: 50px;
    top: calc(50% - 10px);
  }
  
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu_kb_show_menu::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: calc(50% - 2px);
    height: 4px;
    width: 100%;
    background-color: black;
  }
  
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu_kb_show_menu:hover {border-color: #e10019}
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu_kb_show_menu:hover::after
  {background-color: #e10019;}
  
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu_kb_show_menu {display: block;}
  
  #HeaderMainMenu_kb_show_menu,
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu_kb_hide_menu  {display: none;}
  
  #HeaderMainMenu_kb_hide_menu {
    width: 30px;
    height: 20px;
    position: absolute;
    right: 47px;
    top: calc(50% - 8px);
    transform: rotate(45deg);
  }
  
  #HeaderMainMenu_kb_hide_menu::after, #HeaderMainMenu_kb_hide_menu::before {
    content: '';
    display: inline-block;
    position: absolute;
    background-color: black;
  }
  
  #HeaderMainMenu_kb_hide_menu::after {
    height: 4px;
    width: 25px;
    top: calc(12px - 2px);
  }
  
  #HeaderMainMenu_kb_hide_menu::before {
    width: 4px;
    height: 25px;
    left: calc(12px - 2px);
  }
  
  #HeaderMainMenu_kb_hide_menu:hover::after,
  #HeaderMainMenu_kb_hide_menu:hover::before
  {background-color: #e10019;}
}

/* --------------------- MobileMenue --------------------- */

@media (max-width: 1024px) {
  #MainMenue {
    height: 84px;
    padding: 15px;
    position: relative;
  }
  
  #HeaderMainMenu_mobile_chk:checked ~ #HeaderMainMenu {display: none;}
  #HeaderMainMenu{
    position: absolute;
    left: 0;
    top:55px;
    background-color: #fff;
    z-index: 2;
    padding: 0 !important;;
    box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  }
  #HeaderMainMenu > li > ul{
    flex-direction: column;
    width: 100%;
  }
  #HeaderMainMenu > li > ul > li > a{
    padding: 17px !important;
    width: 100%;
  }
  #HeaderMainMenu > li > ul > li:hover,
  #HeaderMainMenu > li > ul > li.openleaf
  {background-color: #3f444b;}
  #HeaderMainMenu > li > ul > li:hover > a,
  #HeaderMainMenu > li > ul > li.openleaf > a
  {color: #fff !important;}
  #HeaderMainMenu > li > ul > li:hover > a::after,
   #HeaderMainMenu > li > ul > li.openleaf > a::after
  {border-color: #fff !important;} 
  #HeaderMainMenu > li > ul > li{
    border-bottom: 1px solid #E2ECF7;
    transition: ease-in-out 300ms;
  }
  
  
  @keyframes doubleClick{
	  0% {height:0;}
	  100% {height: 0;}
  }
  #HeaderMainMenu > li > ul > li.isnode > div{
    position: absolute;
    width: 100%;
    height: 100%;
    display: inline-block;
	cursor: pointer;
  }
  #HeaderMainMenu > li > ul > li.isnode.openleaf > div{
	  animation: doubleClick 300ms 1;
	  height: 52px;
  }
  
  #HeaderMainMenu > li > ul > li.isnode:not(.openleaf) > ul{
    display: none;
  }
  #HeaderMainMenu > li > ul > li.isnode > ul{
    position: relative;
    pointer-events: all !important;
    opacity: 1 !important;;
  }
  #HeaderMainMenu > li > ul > li.isnode > ul > li{padding-left: 27px;}
}/* --- --- */.per_du{display:none;}/* --- --- */@keyframes footerTransition {
  0% {opacity: 0;}
  99% {opacity: 0;}
  100% {opacity: 1;}
}
@media (min-width: 769px) {
  #main {
    position: relative;
    min-height: 100vh;
    padding-bottom: 419px;
  }
  footer {
    position: absolute;
    bottom: 0;
	/*padding-bottom: 45px;*/
  }
  footer > div img {padding-right: 20px}
}
footer,footer b{font-family: Inter, sans-serif;}
footer b{font-weight: bolder;}
footer {
  background-color: #F8F8F8;
  padding-top: 30px;
  box-shadow: 10px 10px 10px 10px;
}
.footerSerUeb ul {
  display: none;
  background-color: #F0F0F0;
  list-style: none;
  box-shadow: 0px 0px 5px 0px;
  padding: 0;
  margin: 0;
  position: absolute;
  left: 100px;
  width: max-content;
  top: 10px;
  z-index: 5;
}
.footerSerUeb:hover ul {
  display: inline-block;
  animation: footerTransition 500ms;
}
.footerSerUeb ul > li > a {
  width: 100%;
  display: inline-block;
  padding: 10px 20px;
}
.footerSerUeb ul > li:hover > a {color: white;}
.footerSerUeb ul > li:hover {background-color: black;}
footer a {color: #676867;}
footer a:hover {color: #E23125;}
footer a > span {
  transform: scaleX(185%);
  display: inline-block;
  margin-left: 10px;
}

footer > div {
  display: flex;
  flex-direction: row;
  justify-content: center;
  font-size: 15.6px;
  color: #676867;
  padding: 0 25px;
  letter-spacing: 0;
  line-height:1.5em;
}
footer > div.bg_gruen {
  color: #C8D5DC;
  padding: 10px 0px;
  font-size: 20px;
  margin-top: 50px;
}
footer > div > div {
  width: 100%;
  display: inline-block;
}
footer h3 {
  color: var(--green);
  font-size: 24px;
  font-family: var(--hgbRegular);
  line-height:42px;	
}
footer > div > div.footerColWide {max-width: 342px; padding-right:70px}
footer > div > div.footerColSmall {max-width: 228px;}

@media (max-width: 1172px) {
  #main {padding-bottom: 527.2px;}
}

@media (max-width: 914px) {
  #main {padding-bottom: 557.2px;}
}

@media (max-width: 894px) {
  #main {padding-bottom: 617.2px;}
}

@media (max-width: 828px) {
  #main {padding-bottom: 647.2px;}
}

@media (max-width: 788px) {
  #main {padding-bottom: 742px;}
}

@media (max-width: 768px) {
  #main {padding-bottom: 0px;}
  footer > div {display: inline-block;}
  .bg_gruen {width: 100%; text-align: center;}
  footer > div > div {
    max-width: 100% !important;
  }
  footer > div > div {
    padding: 20px !important;
  }
  footer > div > div:first-of-type {
    padding: 20px 50px !important;
    text-align: center;
  }
  .footerColMobile {width: 50%;}
}
@media (max-width: 468px) {
  br.hide768 {display: inline-block !important;}
  .footerColMobile {width: 100%;}
}/* --- --- */@media (max-width:360px){
	.HomeButton {min-width: 45vw !important;}
}/* --- --- */