html {
	margin: 0;
}

body {
	padding: 0;
	margin: 0;
	height: 100%;
	overscroll-behavior-y: none;
	font-family: -apple-system, BlinkMacSystemFont, Arial, Helvetica, sans-serif;
	background: #EFEEED;
}

.building_scroll {
	position: absolute;
	display: none;
	width: 100%;
	height: 100%;
	bottom: 0;
	overflow-x: scroll;
	white-space: nowrap;
	margin: 0;
	padding: 0;
	font-size: 0;
}

.building_detail {
	margin: 0;
	padding: 0;
	position: relative;
	display: inline-block;
	height: 100%;
	width: 100%;
	box-sizing: border-box;
	position: fixed;	
}

.building_detail_content {
	font-size: 16px;
	white-space: normal;
	text-align: center;
	position: absolute;
	width: 100%;
	bottom: 12px;
	box-sizing: border-box;
}

.building_detail_content_wrapper {
	max-width: 786px;
    margin-left: auto;
    margin-right: auto;    
}

.building_detail_content_wrapper p {
	margin: 12px;
	padding: 18px;
    display: inline-block;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 12px;			
}

.building_detail_content_wrapper p br {
    line-height: 50%;
}

.building_header_content {
	font-size: 16px;
	white-space: normal;
	text-align: center;
	position: absolute;
	width: 100%;
	bottom: 72px;
	box-sizing: border-box;
}

.building_header_content_wrapper {
	max-width: 786px;
    margin-left: auto;
    margin-right: auto;
}

.building_header_content_wrapper h1, .building_header_content_wrapper h2 {
	margin-top: 0px;
	margin-bottom: 0px;
}

#map_container {
	position: fixed;
	display: block;
	z-index: -1;
	position: fixed;
	width: 100%;
	height: 100%;
	overflow-x: hidden;
	overflow-y: hidden;
}

#map_container canvas {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
}

#map_buildings {
	position: absolute;
	left: 0;
	top: 0;
	transform-origin: top left;
	display: none;
}

.details_pane {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: none;
    text-align: left;
}

.details_background {
	z-index: -2;
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: none; 
    background: rgba(255, 255, 255, 0.5);
}

.details_content {
	max-width: 768px;
    margin-left: auto;
    margin-right: auto;
	padding: 0;
}

.text_light {
	/* margin-top: 6px;	*/
	color: #666666;
}

.text_header {
	margin-top: 24px;
	padding-bottom: 0;
	margin-bottom: 0;
}

.details_img_block {
	width: 100%;
	margin-top: 24px;
	margin-bottom: 24px;	
	font-size: 0;
	padding: 0;
}

.details_img_row {
	width: 100%;
	padding: 0;
	margin: 0;
	border: 0;
	border-spacing: 0;
}

.details_img_padding {
	height: 6px;
	width: 6px;
}

.details_img_large_container {
	padding: 0;
	margin: 0;
	border: 0;
}
.details_img_horizontal_container {
	padding: 0;
	margin: 0;
	border: 0;
}
.details_img_vertical_container {
	padding: 0;
	margin: 0;
	border: 0;
}

.details_img {
	width: 100%;
}

.details_full_width {
	padding: 18px;
}

.details_half_width {
	padding: 18px;
	display: inline-block;
	float: left;
	width: 336px;
}

h1 {
	margin-top: 12px;
	margin-bottom: 12px;
}

.navigation {
	position: absolute;
	width: 100%;
}

.menu_container {
	padding: 0;
	margin: 0;
	position: absolute;
	left: 0;
	top: 0;
}

.close_container {
	padding: 12px;
	margin: 0;
	float: right;
	display: none;
	position: absolute;
	top: 0;
	right: 0;
}

.close_button {
	font-size: 12px;
	margin: 0;

}

.menu_closed {
	padding: 24px 12px 24px 12px;
	margin: 0;
	opacity: 0;
}

.menu_open {
	padding: 24px 12px 24px 12px;
	margin: 0;
	display: none;
	background: white;
}

.menu_button_container {
	padding-bottom: 12px;
}

.menu_button_menu {
	font-size: 12px;
	padding: 12px;
	background: white;
	border-radius: 6px;
}

.menu_entry {
	padding-bottom: 6px;
	padding-left: 12px;

}

.menu_button:link {
	color: black;
	text-decoration: none;
}
.menu_button:hover {
	color: black;
	text-decoration: none;
}
.menu_button:active {
	color: black;
	text-decoration: none;
}
.menu_button:visited {
	color: black;
	text-decoration: none;
}

.menu_button_menu:link {
	color: blue;
	text-decoration: none;
}
.menu_button_menu:hover {
	color: blue;
	text-decoration: none;
}
.menu_button_menu:active {
	color: blue;
	text-decoration: none;
}
.menu_button_menu:visited {
	color: blue;
	text-decoration: none;
}

.details_login {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	background: rgba(0,0,0,0.4);
}

.details_login_wrapper {
    margin-left: auto;
    margin-right: auto;
    margin-top: 72px;
	max-width: 480px;

}

.details_login_content {
	padding: 24px;
	text-align: left;
	background: white;
	border-radius: 12px;
	margin: 24px;
}

.login_close_container {
	margin: -12px;
	float: right;
	position: relative;
	top: 0;
	right: 0;
}

#login_form {
	margin: 0;
}

#login_form label {
	margin-top: 12px;
	display: inline-block;
}

#login_form input {
	width: 100%;
	height: 36px;
	margin-top: 12px;
	border-radius: 3px;
	font-size: 16px;
}

.update_banner {
	margin-top: 0;
	margin-left: 0;
	margin-right: 0;
	padding-top: 12px;
	padding-bottom: 12px;
	padding-left: 12px;
	padding-right: 12px;
	background-color: #3C51B0;
}

.update_text {
	font-size:  16px;
	color: white;
	display: inline;
}


.update_text a:link {
	color: white;
	text-decoration: underline;
}
.update_text a:hover {
	color: white;
	text-decoration: underline;
}
.update_text a:active {
	color: white;
	text-decoration: underline;
}
.update_text a:visited {
	color: white;
	text-decoration: underline;
}

.overlay {
	padding: 0;
	margin: 0;
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	text-align: center;
}

.overlay_contents {
	position: relative;
}

