:root {
  --mobile-padding-lr: 0.7rem;
  --desktop-padding-lr: 2rem;
  --main-font-color: rgb(60, 60, 60);
  --link-color: #0E468D;
  --bold-font-weight: 500;
  --main-color-dark: #0E468D;
  --neutral-grey-light: #EEE;
  --neutral-grey-medium: #DDD;
  --brighter-background-transparent: rgba(255,255,255,0.5);
  --darker-background-transparent: rgba(0,0,0,0.075);
  --darker-background: rgb(236,236,236);
}


#cookie_info_box {
	background-color: #F4F4F4;
	box-shadow: 0 0 0.4em rgba(0,0,0,0.5);
}

@media print {
  #cookie_info_box {
    display: none;
  }
}

body.mobile_device #cookie_info_box {
	width: 100%;
	background-color: rgba(0, 0, 0, 0.9);
	color: #AAA;
}

body.mobile_device #cookie_info_box.cookie_info_box_additional_info_open {
	position: relative;
	bottom: auto;
	top: 0;
}

#cookie_info_box > p {
	padding: 0.1em 0.3em;
	text-align: center;
	margin: 0;
}

body.mobile_device #cookie_info_box > p {
	font-size: 0.8em;
}

#cookie_info_box > p a {
	margin-left: 1em;
}

#cookie_info_box > p a:not(.button) {
	color: inherit;
	text-decoration: underline;
}

#cookie_info_box > p a.button {
	margin-bottom: 0;
}

#cookie_info_box_additional_info {
	font-size: 0.9em;
	padding: 0.4em;
	background-color: rgba(255,255,255,0.02);
}

#cookie_info_box_additional_info ul li {
	list-style: inside disc;
}

html ,
body {
	height: 100%;
}

body {
  display: flex;
  flex-direction: column;
}


#main_container {
	width: 100%;
  flex: 1;
  display: flex;
  flex-direction: column;
}

#main {
	width: 100%;
	margin: 0 auto;
	max-width: 65rem;
	min-height: 80%;
  padding-bottom: 1em;
	position: relative;
  flex: 1;
}

#footer_container {
	color: #444;
	background-color: var(--darker-background);
}

#header {
}

#menu_container {
	background-color: #0E468D;
}


.loginTeaser {
	display: none;
	background-color: rgb(100, 100, 100);
	color: #FFF;
}

.menu_toggled .loginTeaser {
	display: block;
}

.language_select_container {
	display: none;
	text-align: right;
	background-color: #0E468D;
	line-height: 2.2em;
}

.menu_toggled .language_select_container ,
body.process_mode_quick .language_select_container {
	display: block;
}

body.process_mode_quick .language_select_container .language_select_links a {
	font-size: 0.8em;
}

#header_top {
	display: none;
}

.language_select_container a {
	color: rgba(255,255,255, 0.8);
	padding: 0 0.5em;
	line-height: inherit;
	display: inline-block;
}

.language_select_container a.selected {
	color: #FFFFFF;
}

.language_select_container a:hover {
	background-color: rgba(255,255,255, 0.1);
}

#menu_toggle {
	text-align: right;
	line-height: 2em;
	font-size: 1.4em;
	min-height: 2em;
	color: #FFF;
	position: relative;
}


@media (min-height: 31em) {
  #menu_toggle {
    line-height: 2em;
    font-size: 1.9em;
    min-height: 2em;
    color: #FFF;
    position: relative;
  }
}

#menu_service {
	color: inherit;
	display: inline-block;
	padding: 0 0.5em;
}

#menu {
	display: none;
	color: #FFF;
}

.menu_toggled #menu {
	display: block;
}

#headline_container {
	line-height: inherit;
	color: inherit;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-shadow: inherit;
	background-image: url('/ticket/tcult/pics/customer_screen/logo.png');
	background-repeat: no-repeat;
	background-size: auto 90%;
	background-position: 0.3% center;
	z-index: 1;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 85%;
	width: calc(100% - 2em);
}

#headline {
	padding-left: 2.5em;
	height: 100%;
	text-align: left;
}

#headline img {
	max-height: 50%;
	margin: 0.5em 0;
}

.content {
	padding: 0.2em var(--mobile-padding-lr);
}









div.interne_debug_info {
	text-align:center;
}
div.interne_debug_info > span{
	font-size: 100%;
	text-align:center;
	border-color: #aa0000;
	border-width: 1px;
	border-style: solid;
}







@media (min-width: 36em) {
	#cookie_info_box > p {
		padding: 0.3em;
	}

	body.mobile_device #cookie_info_box > p {
		font-size: 0.9em;
	}

}


@media (min-width: 49em) {

	#main {
		max-width: 100%;
	}


	body:not(.mobile_device) #header_top_container {
		background-color: #0E468D;
		min-height: 3em;
	}

	body:not(.mobile_device) #menu_toggle ,
	body:not(.mobile_device) #menu_container .language_select_container ,
	body:not(.mobile_device) #menu_container .loginTeaser {
		display: none;
	}

	body:not(.mobile_device) #menu ,
	body:not(.mobile_device) #header_top {
		display: block;
	}

	body:not(.mobile_device) #header_top {
		position: relative;
		height: 4em;
		padding: 0.5em 0;
		vertical-align: middle;
		color: #FFFFFF;
	}

	body:not(.mobile_device) #header_top_logo {
		height: inherit;
		background-image: url('/ticket/tcult/pics/customer_screen/logo.png');
		background-repeat: no-repeat;
		background-size: auto 100%;
		background-position: 0 0;
		display: inline-block;
		width: 15em;
		vertical-align: middle;
		margin-left: 0.4em;
	}

	body:not(.mobile_device) #header_top_text {
		color: #0E468D;
		display: inline-block;
		width: 83.5%;
		vertical-align: middle;
		height: 100%;
	}

	body:not(.mobile_device) #header_top_text img {
		max-height: 75%;
		margin: 0.5em 0;
	}

	body:not(.mobile_device) #header_top .language_select_container {
		display: block;
		background-color: transparent;
		position: absolute;
		top: 0;
		right: 0;
		z-index: 2;
		color: inherit;
	}

	body:not(.mobile_device) #header_top .loginTeaser {
		position: absolute;
		bottom: 0;
		right: 0;
		z-index: 2;
		color: inherit;
	}

	body:not(.mobile_device) .language_select_container a {
		color: rgba(255,255,255, 0.8);
		text-shadow: none;
	}

	body:not(.mobile_device) .language_select_container a.selected {
		color: #FFF;
	}

	body:not(.mobile_device) .language_select_container a:hover {
		background-color: rgba(255,255,255, 0.6);
	}

	body:not(.mobile_device) .loginTeaser {
		display: block;
		padding: 0.5em 0 0 0;
		background-color: transparent;
	}

	body:not(.mobile_device) #menu {
    margin-top: 1em;
  }

	body:not(.mobile_device) #header_top ,
	body:not(.mobile_device) #menu_container ,
	#content_container {
		width: 100%;
		margin: 0 auto;
		font-size: 1em;
		max-width: 65rem;
	}
}


@media (min-width: 65rem) {
	body:not(.mobile_device) #header_top_logo {
		margin-left: 0;
	}

  body.mobile_device #menu_container {
    max-width: 65rem;
    margin: 0 auto;
  }

	.content {
		padding: 0.5em 0;
	}
}







@media print {
	#header_container {
		display: none;
	}

	#main {
		width: auto;
		max-width: none;
		margin: 0 2%;
		padding: 0;
		color: #000;
		background: transparent;
	}

	#footer_container {
		box-shadow: none;
	}

	h1 ,
	h2 ,
	h3 ,
	h4 ,
	h5 ,
	h6 {
		page-break-after:avoid;
		page-break-inside:avoid
	}
	img {
		page-break-inside:avoid;
		page-break-after:avoid;
	}

	blockquote ,
	table ,
	pre {
		page-break-inside:avoid;
	}

	ul ,
	ol ,
	dl {
		page-break-before:avoid;
	}
}



