/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

div, ul, li{
	/*position:relative;*/
}
/* 
   end reset
*/

#map, html, body {
	width: 100%;
	height: 100%;
	height: 100vh;
	font-family: 'Open Sans', sans-serif;
	margin: 0;
	overflow: hidden;
	position: relative;
}
body{
	position: fixed;
}
.clearfix::after {
  content: "";
  clear: both;
  display: table;
}

#color-palette {
	clear: both;
}

.color-button {
	width: 14px;
	height: 14px;
	font-size: 0;
	margin: 2px;
	float: left;
	cursor: pointer;
}

.span-button:hover{
	cursor: pointer;
}

/* floating menu */
#floating-menu-button{
  width: 55px;
  height: 55px;
  border-radius: 50%;
  background: #db4437;
  top: 0;
  left: 0;
  cursor: pointer;
  box-shadow: 0px 2px 5px #666;
  display:inline-block;
  float:left;
  position:relative;
}

.plus{
  color: white;
  position: absolute;
  top: 0;
  display: block;
  bottom: 0;
  left: 0;
  right: 0;
  text-align: center;
  padding: 0;
  margin: 0;
  line-height: 55px;
  font-size: 24px;
  animation: plus-out 0.3s;
  transition: all 0.3s;
}
#floating-menu-search{
  display:inline-block;
  float:left;
  margin-left:10px;
}
#floating-menu-search .search-box {
	color:black;
	background: #fff;
	box-shadow: 0 0 0 3px #db4437;
}
#floating-menu-search .search-box:hover,
#floating-menu-search .search-box:focus {
    background: #fffcd6;
}

.wrapper-panel{
	display: none;
}
.wrapper-panel.active{
	display:block;
}

#wrapper-search .container-search-form {
    padding: 10px 70px 10px 20px;
}

#wrapper-search .container-close-button {
    color: white;
    margin: 20px 30px;
    font-size: 24px;
    animation: rotate-out 0.3s;
    transition: all 0.3s;
    position: absolute;
    right: 0;
    top: 0;
}
#wrapper-search .search-msg p{
	color: white;
    font-size: .9em;
    padding: 20px;
    text-align: left;
}




#wrapper-info .container-close-button{
	float: right;
    color: white;
    margin: 10px 20px;
    font-size: 24px;
    animation: rotate-out 0.3s;
    transition: all 0.3s;
    background: #3b3d4d;
    padding: 5px;
    border-radius: 50%;
}
#wrapper-info .container-close-button:hover,
#wrapper-search .container-close-button:hover
{
  animation: rotate-in 0.15s linear;
  color:#428bca;
}



#container-bottom{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 110%;
    z-index: 55;
    box-shadow: 0 0px 10px #000;
    background: #ffffff;
    border-radius: 2px 2px 0 0;
	transition: all 0.5s;
}
#container-bottom.active{
	top: 80%;
}
#container-bottom.active.full{
	top: 0;
	overflow: scroll;
}
.container-info-header{
	z-index: 1;
    position: absolute;
    width: 100%;
}
.info-content{
	max-height: calc(100vh - 120px);
    overflow-y: auto;
	color: #dee2e6;
}

.info-location_element p{
	padding: 5px 40px;
}
.info-location_element p i.fas {
    position: absolute;
    left: 10px;
}
.info-location_element p i.fas:nth-child(2) {
    position: absolute;
    left: 20px;
}

.info-location_element p span{
    font-weight: bold;
}
.info-location > blockquote{
	padding: 10px;
}
.info-location_details{
    line-height: 1.4em;
    font-size: 0.85em;
}
.info-location_details p {
    padding: 5px 10px;
}
.info-location_details ul {
	list-style-type: square;
    padding: 10px 10px 10px 30px;
}
.info-location_details strong{
	font-weight: bold;
}

.container-info-gallery{
	overflow-y: hidden;
}
.btn-info-gallery{
	background: white;
    color: black;
    font-weight: bold;
    border-radius: 2em;
    padding: 5px 10px;
    display: block;
    border: 2px solid black;
    opacity: .7;
	margin:10px;
}
.btn-info-gallery:hover{
	opacity: 1;
	text-decoration: none;
}

.container-info-gallery .info-gallery{
    display: flex;
    align-items: center;
	width: 700px;
}
.container-info-gallery .info-gallery figure{
    width: 30%;
}
.container-info-gallery .info-gallery img{
	width: 100%;
	
}
.container-info-gallery .info-gallery figcaption {
  display: none;
}


.container-info-teaser .container-info-title{
    color: white;
    padding: 20px 60px 10px 20px;
    position: absolute;
    top: 0;
	text-shadow: -1px -1px 1px rgba(255,255,255,.1), 1px 1px 1px rgba(0,0,0,.5);
}
.container-info-teaser .container-info-footer{
    position: absolute;
    bottom: 0;
}
.container-info-details{
	padding:10px;
}
#container-bottom .container-close-button{
	float: right;
    color: white;
    margin: 10px 20px;
    font-size: 24px;
    animation: rotate-out 0.3s;
    transition: all 0.3s;
    background: #3b3d4d;
    padding: 5px;
    border-radius: 50%;
}
#container-bottom .container-close-button:hover{
  animation: rotate-in 0.15s linear;
  color:#428bca;
}
#container-bottom #container-info-expand-button{
	position: absolute;
    width: 100%;
	opacity: 1;
	color: white;
    top: 0;
    text-align: center;
    padding: 0;
    margin: 0;
    line-height: 24px;
    font-size: 24px;
    transition: all 0.3s;
}
#container-bottom.full #container-info-expand-button{
	opacity: 0;
}

#container-floating{
  position: absolute;
  width: 300px;
  height: 70px;
  top: 30px;
  left: 30px;
  z-index: 50;
  display:none;
}

#container-floating:hover{
}

#container-floating:hover .plus{
  animation: plus-in 0.15s linear;
  animation-fill-mode: forwards;
}

.edit{
  color: white;
  position: absolute;
  top: 0;
  display: block;
  bottom: 0;
  left: 0;
  right: 0;
  text-align: center;
  padding: 0;
  margin: 0;
  opacity: 0;
  margin: auto;
  line-height: 55px;
  font-size: 24px;
  transform: rotateZ(-70deg);
  transition: all 0.3s;
  animation: edit-out 0.3s;
}

#container-floating:hover .edit{
  animation: edit-in 0.2s;
   animation-delay: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes edit-in{
    from {opacity: 0; transform: rotateZ(-70deg);}
    to {opacity: 1; transform: rotateZ(0deg);}
}

@keyframes edit-out{
    from {opacity: 1; transform: rotateZ(0deg);}
    to {opacity: 0; transform: rotateZ(-70deg);}
}

@keyframes plus-in{
    from {opacity: 1; transform: rotateZ(0deg);}
    to {opacity: 0; transform: rotateZ(180deg);}
}

@keyframes plus-out{
    from {opacity: 0; transform: rotateZ(180deg);}
    to {opacity: 1; transform: rotateZ(0deg);}
}

@keyframes rotate-in{
    from {transform: rotateZ(0deg);}
    to {transform: rotateZ(180deg);}
}
@keyframes rotate-out{
    from {transform: rotateZ(180deg);}
    to {transform: rotateZ(0deg);}
}

#floating-panel {
	width: 400px;
    background: #3b3d4d;
    z-index: 99;
    color: #868fa0;
    position: absolute;
    left: 10px;
    top: 10px;
    -webkit-box-shadow: 0 2px 5px #000;
    box-shadow: 0 2px 5px #000;
	transition: all 0.5s;
}
body.menu-collapsed #floating-panel{
	left: -100%;
}
body.menu-collapsed #container-floating{
	display: flex;
    align-items: center;
}

.logoHeader {
    padding: 15px 10px 12px 15px;
	background: #191a25;
    /* background: url(../../static/media/bg.c639b2e0.jpg) 0 0 no-repeat; */
    position: relative;
}
.navHeader{
	font-size: 10px;
    padding: 10px;
}
.navHeader .nav-button{
	background: #868fa0;
	color: #ffffff;
    border-radius: 50%;
	transition: all 0.3s;
	margin-right: 5px;
}
.navHeader .nav-button:hover{
	background: #428bca;
	box-shadow: 0px 0px 4px 2px #fff;
}




.toggleMenu i {
    margin: 5px;
    width: 24px;
    height: 24px;
    font-size: 14px;
    line-height: 24px;
}

.logoHeader .userPanel {
    position: absolute;
    right: 9px;
    top: 12px;
    font-size: 12px;
}
.userPanel .btn {
    border-radius: 2px;
    border: none;
    background: #428bca;
    color: #fff;
    padding: 6px 10px;
    display: inline-block;
    vertical-align: middle;
    text-decoration: none;
    cursor: pointer;
	margin-top: 8px;
}


.logoHeader .appTitle {
    font-size: 16px;
    color: #fff;
    text-decoration: none;
    font-weight: bold;
}
.logoHeader a img {
    margin-right: 10px;
    vertical-align: middle;
	height: 32px;
	margin-top: -8px;
}

#panel-default, #panel-search-results {
	max-height: calc(100vh - 250px);
    overflow-y: auto;
}

.search-list {
    position: absolute;
    right: 30px;
    line-height: 2em;
	cursor: pointer;
}

#goCenterUI, #setCenterUI {
background-color: #fff;
border: 2px solid #fff;
border-radius: 3px;
box-shadow: 0 2px 6px rgba(0,0,0,.3);
cursor: pointer;
margin-bottom: 10px;
text-align: center;
}
#goCenterText, #setCenterText {
color: rgb(25,25,25);
font-family: Roboto,Arial,sans-serif;
font-size: 15px;
line-height: 25px;
padding-left: 5px;
padding-right: 5px;
}
#setCenterUI {
margin-left: 12px;
}

#navFloorUI > div {
direction: ltr;
overflow: hidden;
text-align: center;
position: relative;
color: rgb(86, 86, 86);
font-family: Roboto, Arial, sans-serif;
user-select: none;
font-size: 11px;
background-color: rgb(255, 255, 255);
padding: 8px;
border-bottom-right-radius: 2px;
border-top-right-radius: 2px;
background-clip: padding-box;
box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
min-width: 40px;
border-left: 0px;
cursor: pointer;
}
#navFloorUI > div:hover {
background-color: rgb(235, 235, 235);
}
#navFloorUI > .selected{
background-color: rgb(235, 235, 235);
}
	  
	  
#navOpacityUI > div {
    direction: ltr;
    overflow: hidden;
    text-align: center;
    position: relative;
    color: rgb(86, 86, 86);
    font-family: Roboto, Arial, sans-serif;
    user-select: none;
    font-size: 11px;
    background-color: rgb(255, 255, 255);
    padding: 8px;
    border-bottom-right-radius: 2px;
    border-top-right-radius: 2px;
    background-clip: padding-box;
    box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
    min-width: 40px;
    border-left: 0px;
}
#panel-status .status-list {
    font-size: 11px;
    font-weight: bold;
    color: white;
    padding: 5px 10px;
}

#panel-info-path{
	padding: 5px;
}
#panel-info-path span{
    background: black;
    border-radius: 10px;
    font-size: .8em;
    padding: 5px 10px;
    margin: 1px;
    cursor: pointer;
    font-weight: bold;
    display: inline-block;
}

.collection-list {
    padding-left: 0;
    background-color: #494156;
	color: #FFF;
	margin-top: 0;
    margin-bottom: 0;
}
.collection-list .element-li{
	background-color: transparent;
	padding: 8px 10px;
	border: 1px solid #616161;
	font-size: 12px;
}
.collection-list .element-li:hover{
	background: #6c6971;
	border: 1px solid #fff;
}
.collection-list .element-li.active{
 	background: #428bca;
	border: 1px solid #616161;
}
.collection-list .element-li .layer-next{
    float: right;
    padding: 0 5px;
    border-radius: 2em;
}
.collection-list .element-li .layer-next:hover{
    border: 1px solid #428bca;
    background: #428bca;
}

.collection-list .element-li .tools-front{
    float: left;
    color: #FFF;
}
.collection-list .element-li .tools-front i {
    cursor: pointer;
    padding-right: 0.5em;
}

.collection-list .element-li .tools{
    display: none;
    float: right;
    color: #FFF;
}
.collection-list .element-li .tools i{
    cursor:pointer;
	padding-right: 1em;
}
.collection-list .element-li > i{
    cursor:pointer;
}
.collection-list .element-li.active .tools{
    display: block;
	background: #428bca;
}
.collection-list .element-li.active a{
	color: #FFF;
}

.place-card-large {
    padding: 9px 0 9px 0;
}
.place-card, .default-card, .directions-card {
    cursor: default;
}
.place-desc {
    font-size: 12px;
    -moz-user-select: text;
    -webkit-user-select: text;
    -ms-user-select: text;
    user-select: text;
	width: 200px;
    display: inline-block;
}
.place-card .icon{
	text-align: center;
    font-size: 32px;
}
.place-card .navigate-text{
    text-align: center;
    padding: 5px 0 0 5px;
}
.navigate-enter {
    display: inline-block;
    vertical-align: top;
    height: 43px;
    padding: 0 7px;
	float: right;
}
.navigate {
    display: inline-block;
    vertical-align: top;
    height: 43px;
    padding: 0 7px;
	float: right;
}
.navigate-separator {
    display: inline-block;
    width: 1px;
    height: 43px;
    vertical-align: top;
    background: -webkit-linear-gradient(top,#fbfbfb,#e2e2e2,#fbfbfb);
    background: -moz-linear-gradient(top,#fbfbfb,#e2e2e2,#fbfbfb);
    background: -ms-linear-gradient(top,#fbfbfb,#e2e2e2,#fbfbfb);
    background: -linear-gradient(top,#fbfbfb,#e2e2e2,#fbfbfb);
}
.star-entity {
    display: inline-block;
    vertical-align: top;
    height: 43px;
    padding: 0 7px;
	float: right;
}

.place-name {
/*  
	overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
*/
    font-weight: bold;
    font-size: 14px;
	padding: 0 0 5px 0;
}


#panel-footer {
    background: #191a25;
    font-size: 11px;
    color: #fff;
}

#panel-footer .copyright-line{
	text-align: right;
}

#panel-tools {
    background: #191a25;
    font-size: 11px;
    padding: 10px;
    color: #fff;
}

#panel-tools .toolButton{
    position: relative;
    padding: 0;
    margin: 0;
    border: none;
    overflow: visible;
    font-size: 12px;
    background: #3b3d4d;
    color: #fff;
    -webkit-box-shadow: 0 2px 5px #000;
    box-shadow: 0 2px 5px #000;
    text-align: center;
	width:30px;
	height:30px;
}
#panel-tools .toolButton:hover{
    -webkit-box-shadow: 0 0 10px #99d0ff;
    box-shadow: 0 0 10px #99d0ff;
	color:#99d0ff;
}
#panel-tools .toolButton.active{
    -webkit-box-shadow: 0 0 10px #99d0ff;
    box-shadow: 0 0 10px #99d0ff;
	color:#99d0ff;
}


@media only screen and (max-width: 768px) {
  #floating-panel {
    width: 100%;
    background: #3b3d4d;
    left: 0;
    top: 0;
  }
}


/* search box */
.search-container{
	position: relative;
    width: 100%;
}
.search-container label{
	width: 0;
    position: absolute;
    right: 0;
    top: 0;
}

.search-box {
  -webkit-transition: width 0.6s, border-radius 0.6s, background 0.6s, box-shadow 0.6s;
  transition: width 0.6s, border-radius 0.6s, background 0.6s, box-shadow 0.6s;
  width: 100%;
  height: 40px;
  border-radius: 20px;
  border: none;
  cursor: pointer;
  background: #ebebeb;
  padding: 0 40px 0 10px;
}
.search-box + label .search-icon {
  color: black;
}
.search-box:hover {
  color: white;
  background: #c8c8c8;
  box-shadow: 0 0 0 3px #000000;
}
.search-box:hover + label .search-icon {
  color: black;
}
.search-box:focus {
  -webkit-transition: width 0.6s cubic-bezier(0, 1, 0.66, 1), border-radius 0.6s, background 0.6s;
  transition: width 0.6s cubic-bezier(0, 1, 0.66, 1), border-radius 0.6s, background 0.6s;
  border: none;
  outline: none;
  box-shadow: none;
  padding-left: 15px;
  cursor: text;
  border-radius: auto;
  background: #ebebeb;
  color: black;
}
.search-icon {
  position: relative;
  left: -30px;
  color: white;
  cursor: pointer;
	line-height: 2em;
    font-size: 1.2em;
}
/**/


/** nanoScrollerJS - initial setup **/
/** initial setup **/
.nano {
  position : relative;
  width    : 100%;
  height   : 100%;
  overflow : hidden;
}
.nano > .nano-content {
  position      : absolute;
  overflow      : scroll;
  overflow-x    : hidden;
  top           : 0;
  right         : 0;
  bottom        : 0;
  left          : 0;
}
.nano > .nano-content:focus {
  outline: thin dotted;
}
.nano > .nano-content::-webkit-scrollbar {
  display: none;
}
.has-scrollbar > .nano-content::-webkit-scrollbar {
  display: block;
}
.nano > .nano-pane {
  background : rgba(0,0,0,.25);
  position   : absolute;
  width      : 10px;
  right      : 0;
  top        : 0;
  bottom     : 0;
  visibility : hidden\9; /* Target only IE7 and IE8 with this hack */
  opacity    : .01;
  -webkit-transition    : .2s;
  -moz-transition       : .2s;
  -o-transition         : .2s;
  transition            : .2s;
  -moz-border-radius    : 5px;
  -webkit-border-radius : 5px;
  border-radius         : 5px;
}
.nano > .nano-pane > .nano-slider {
  background: #444;
  background: rgba(0,0,0,.5);
  position              : relative;
  margin                : 0 1px;
  -moz-border-radius    : 3px;
  -webkit-border-radius : 3px;
  border-radius         : 3px;
}
.nano:hover > .nano-pane, .nano-pane.active, .nano-pane.flashed {
  visibility : visible\9; /* Target only IE7 and IE8 with this hack */
  opacity    : 0.99;
}

.nano .nano-pane   { background: #888; }
.nano .nano-slider { background: #111; }
/** nanoScrollerJS - end **/


.transition-all{
	transition: all 0.3s linear;
}

/* fix height for ps*/
.pswp__ui{
	height:100%;
}

/*bootstrap popover*/
.popover  {
background: tomato!important;
color: #fff;
}
.popover.bottom .arrow:after {
  border-bottom-color:tomato;
}