* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-user-drag: none;
	-webkit-touch-callout: none;
	-ms-content-zooming: none;
}

@font-face {
	font-family: "nunito";
	src: url("../fonts/Nunito-Regular.ttf");
}

@font-face {
	font-family: "nunito-semibold";
	src: url("../fonts/Nunito-SemiBold.ttf");
}

@font-face {
	font-family: "nunito-bold";
	src: url("../fonts/Nunito-SemiBold.ttf");
}

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;
}
  
button {
	padding: 0;
	border: none;
	font: inherit;
	color: inherit;
	background-color: transparent;
}

html, body {
	font-family: "Nunito", sans-serif;
	font-size: 1em;
	font-weight: 400;
	font-style: normal;
	display: flex;
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	overflow: hidden;
	justify-content: center;
	align-items: center;
	scroll-behavior: smooth;
}

/* Typography */

h1 {
	font-size: 3.1573345183em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	line-height: 1.1;
	color: #343030;
}

h2 {
	font-size: 2.368593037em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	line-height: 1.1;
	color: #343030;
}

h3 {
	font-size: 1.776889em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	line-height: 1.1;
	color: #343030;
}

h4 {
	font-size: 1.333em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	line-height: 1.1;
	color: #343030;
}

h5 {
	font-size: 1em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	line-height: 1.1;
	color: #343030;
}

h6 {
	font-size: 0.7501875469em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	color: #343030;
}

.body_large {
	font-size: 1.333em;
	font-family: "Nunito", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.5;
	color: #343030;
}

p, ol, ul, li {
	font-size: 1em;
	font-family: "Nunito", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.5;
	color: #343030;
}

.body_small {
	font-size: 0.7501875469em;
	font-family: "Nunito", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.5;
	color: #343030;
}

.body_xsmall {
	font-size: 0.5627813555em;
	font-family: "Nunito", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.5;
	color: #343030;
}

a {
	font-size: 1em;
	font-family: "Nunito", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.5;
	color: #343030;
	text-decoration: underline;
}

button {
	font-size: 1em;
	font-family: nunito-bold;
	font-weight: 700;
	font-style: normal;
	line-height: 1.1;
	color: #343030;
}

/* Style */

/* Modal */

.modal {
	width: 0;
	height: 0;
	position: fixed;
	z-index: 100000;
	top: 0px;
	background: rgba(52, 48, 48, 0.7);
	transition: height 0s 0.4s ease, width 0s 0.4s ease, opacity 0.4s ease;
	opacity: 0;
	pointer-events: none;
	overflow: scroll;
}
  
.modal_flex {
	display: flex;
	justify-content: center;
	align-items: center;
}
  
.modal.active {
	width: 100%;
	height: 100%;
	opacity: 1;
	transition: opacity 0.4s ease;
	pointer-events: all;
}

.visits__modal_leave_tour_content {
	width: 328px;
	background: #fff;
	border-radius: 12px;
	padding: 24px 16px 16px 16px;
	box-shadow: 0 2px 30px 0 rgba(0, 0, 0, 0.5);
	transition: all 0.4s ease;
	text-align: center;
}

.visits__modal_leave_tour_content h4 {
	max-width: 232px;
	margin: 0 auto;
}

.visits__modal_leave_tour_buttons_container {
	display: flex;
	justify-content: space-between;
	margin-top: 24px;
}

.visits__modal_leave_tour_buttons_container button {
	width: calc(50% - 8px);
	height: 48px;
	border-radius: 8px;
	cursor: pointer;
}

.visits__modal_leave_tour_yes {
	background-color: #E5E3E3;
	display: block;
	width: 100%;
    height: 100%;
	line-height: 48px;
}

.visits__modal_leave_tour_yes a {
	text-decoration: none;
	font-weight: 700;
}

.visits__modal_leave_tour_no {
	background-color: #22BFB3;
	font-weight: 700;
	color: #FFF;
}


/* Rest */ 

#hint {
	text-align: center;
	padding: 20px;
}

#pano {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	cursor: url(../img/custom-cursor.svg) 20 20, auto !important;
}

#loading-overlay {
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	background-color: #FFF;
	display: flex;
	flex-direction: column;
	justify-content: center;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

#loading-overlay-cover {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: #0007;
}

#loading-text {
	position: relative;
	text-align: center;
	margin: 0px auto;
	font-family: nunito-semibold;
	font-size: 2em;
	color: #FFF;
}

/* progress bar */

#progress-container {
	width: 50%;
	background-color: #ddd;
	position: relative;
	margin: 0px auto;
	top: 20px;
	border-radius: 2px;
}

#progress-bar {
	width: 1%;
	height: 6px;
	background-color: #22BFB3;
	border-radius: 2px;
}

#playback-progress-wrapper {
	position: fixed;
	bottom: 106px;
	left: 20px;
	right: 20px;
	display: flex;
	height: fit-content;
	max-width: 400px;
	margin: auto;
}

#playback-progress-container {
	background-color: #ffffff7e;
	position: relative;
	margin: auto 10px;
	height: 4px;
	border-radius: 2px;
	width: 100%;
	bottom: 1px;
}

#playback-progress-bar {
	width: 0%;
	height: 100%;
	background-color: #ffffff;
	border-radius: 2px;
}

.progress-label {
	font-family: nunito-semibold;
	font-size: 12px;
	color: #FFF;
}

.vr-tour-playback-tools {
	left: 342px;
}

#compass {
	background-color: #FFFFFF;
	box-shadow: 0px 4px 8px rgba(0, 0, 0, .3);
	width: 42px;
	height: 42px;
	border-radius: 50%;
	position: fixed;
	top: 10px;
	right: 10px;
	scale: 1.0;
}

.top-left-controls {
	position: absolute;
	top: 30px;
	left: 30px;
	display: flex;
}

#fullscreen {
	background-color: #FFFFFF;
	width: 42px;
	height: 42px;
	border-radius: 8px;
	position: relative;
	margin-right: 16px;
	box-shadow: 0px 4px 8px rgba(0, 0, 0, .3);
}

#fullscreen-icon {
	position: absolute;
	width: 26px;
	height: 26px;
	top: 8px;
	left: 8px;
}

#leave-tour {
	z-index: 1;
    background-color: white;
    height: 42px;
    padding: 0px 16px;
	border-radius: 8px;
	box-shadow: 0px 4px 8px rgba(0, 0, 0, .3);
}

#leave-tour a {
	text-decoration: none;
	font-weight: 700;
	color: #F26668;
}

#Arrow {
	top: 50%;
	left: 11px;
	stroke: rgb(31, 191, 179);
	transform-origin: 50% 50%;
}

#hotspot-details {
	display: none;
	background-color: #000000c0;
	width: 100%;
	height: 100%;
	position: absolute;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

@media screen and (orientation: portrait) {
	#hotspot-details {
		flex-direction: column;
	}

	#hotspot-image-container {
		display: contents;
	}
}

@media screen and (min-width: 700px) and (min-height: 700px) {
	#hotspot-details {
		padding: 50px;
	}
}

#hotspot-details-container {
	max-width: 500px;
	min-width: 200px;
	/*flex: 1 1 100%;*/
}

#hotspot-image-container {
	flex: 1 1 100%;
	min-width: 30%;
	width: auto;
	height: intrinsic;
}

#hotspot-details h1 {
	font-size: 24px;
	padding: .3em;
	text-align: center;
	color: #fff;
}

#hotspot-details p {
	font-size: 16px;
	padding-left: .5em;
	padding-right: .5em;
	text-align: center;
	color: #fff;
}

.stop p {
	width: 68px;
	height: 68px;
	font-size: 12px;
	text-align: center;
	color: #fff;
	white-space: normal;
	text-overflow: ellipsis;
	margin: auto;
	display: table-cell;
	vertical-align: middle;
	background-color: #00000088;
	border-radius: 10px;
	line-height: 1.1;
	font-family: nunito-semibold;
}

#hotspot-details-close-button {
	margin: auto;
	background-color: transparent;
	border: none;
	display: block;
}

#hotspot-full-image {
	width: 100%;
	height: 100%;
	margin: auto;
	object-fit: contain;
}

.interest {
	background-image: url(http://placeimg.com/640/360/any);
	height: 360px;
	position: relative;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.video-footer {
	text-align: center;
	background: rgba(255, 255, 255, 0.5);
	backdrop-filter: blur(5px);
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 12px 0px 12px 0px;
	min-width: 274px;
	min-height: 96px;
}

.video-footer-panel-open {
	left: 342px;
	right: 0px;
}

.control-container {
	display: flex;
	align-items: center;
	justify-content: space-evenly;
	position: fixed;
	bottom: 112px;
}

#powered-by-yt {
	position: fixed;
	bottom: 40px;
	margin: auto;
}

@media screen and (max-height: 450px) {
	#powered-by-yt {
		display: none;
	}
}

@media screen and (min-width: 700px) and (min-height: 700px) {
	.video-footer {
		text-align: center;
		position: fixed;
		bottom: 30px;
		left: 30px;
		right: 30px;
		border-radius: 20px;
		max-width: max-content;
		margin: auto;
		min-height: 96px;
	}

	#compass {
		top: 30px;
		right: 30px;
		transform: scale(1.2);
	}

	.control-container {
		bottom: 138px;
	}

	#playback-progress-wrapper {
		left: 0px;
		right: 0px;
	}
}

.start-btn {
	color: #fff;
	background-color: #22bfb3;
	padding: 15px 60px 15px 60px;
	border-width: 0;
	border-radius: 40px;
	margin: 10px auto;
	font-family: nunito-semibold;
	font-size: 1.2em;
	display: flex;
	align-items: center;
	white-space: nowrap;
	position: relative;
}

.play-icon {
	border: 0;
	background: transparent;
	box-sizing: border-box;
	width: 0;
	height: 16px;
	border-color: transparent transparent transparent #fff;
	margin: 0 15px 0 0;
	cursor: pointer;
	border-style: solid;
	border-width: 10px 0 10px 18px;
}

#panel-tour-begin {
	padding: 0px 15px 0px 15px;
}

#panel-tour-continue {
	display: none;
	padding: 0px 15px 0px 15px;
}

#panel-tour-replay {
	display: none;
	padding: 0px 15px 0px 15px;
}

#panel-tour-during {
	display: none;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}

.tour-during-control {
	display: none;
}

.play-icon, .rewind-btn, .play-btn, .skip-btn, .stop {
	display: inline-block;
	background-position: center;
	background-repeat: no-repeat;
}

.rewind-btn, .skip-btn, .play-btn {
	background-color: #FFF;
	z-index: 100;
}

.rewind-btn, .skip-btn {
	width: 40px;
	height: 40px;
	border-radius: 20px;
}

.play-btn {
	width: 48px;
	height: 48px;
	border-radius: 24px;
	cursor: pointer;
	margin: 24px;
	background-repeat: no-repeat;
	background-position: center;
	background-image: url(/vr/img/play-btn.svg);
}

.rewind-btn {
	background-image: url(/vr/img/skip-back-15.svg);
}

.skip-btn {
	background-image: url(/vr/img/skip-forward.svg);
}

.play-btn.paused {
	background-image: url(/vr/img/pause-btn.svg);
}

@media(hover: hover) and (pointer: fine) {
    .rewind-btn:hover, .skip-btn:hover, .play-btn:hover {
		opacity: 75%;
	}
}

.stops-container-wrap {
	font-size: 0;
	overflow-x: scroll;
	overflow-y: hidden;
	padding-left: 10px;
}

@media screen and (max-width: 450px) {
	.top-left-controls {
		top: 10px;
		left: 10px;
	}
}

/*Firefox*/

/*From version 64 - https://drafts.csswg.org/css-scrollbars-1/*/

.stops-container-wrap {
	scrollbar-width: none;
	scrollbar-color: #666666 #efefef;
}

/* Chrome */

.stops-container-wrap::-webkit-scrollbar-track {
	background-color: transparent;
	height: 0px;
}

.stops-container-wrap::-webkit-scrollbar-thumb {
	background-color: #333;
	border: 1px solid transparent;
	background-clip: content-box;
	height: 0px;
}

.stops-container-wrap::-webkit-scrollbar {
	width: 4px;
	height: 0px;
}

.stops-container {
	width: 100%;
	overflow: visible;
	white-space: nowrap;
}

.stop, .walk-wrap, .walk {
	display: inline-block;
}

.stop {
	border-radius: 10px;
	margin: 2px;
	background-size: cover;
}

.stop-spacer {
	width: 10px;
	display: inline-block;
}

.stop.active {
	border: 2px solid #22bfb3;
	border-radius: 12px;
	margin: 0px;
}

.walk-wrap {
	height: 64px;
	width: 44px;
	position: relative;
}

.walk {
	width: 48px;
	margin: 30px -2px;
	/*half .stop height - half .walk.active border height */
	border: 4px solid #666;
	position: relative;
}

.walk.active {
	border: 4px solid #22bfb3;
}

.walk-btn {
	display: block;
	background-color: #FFF;
	background-image: url(/vr/img/select-walk-btn.svg);
	background-repeat: no-repeat;
	background-position: center;
	width: 28px;
	height: 28px;
	border-radius: 14px;
	position: absolute;
	top: 20px;
	left: 8px;
}

/* Panel */

.vr-tour-global-container {
    width: 100vw;
    height: 100vh;
    display: flex;
    flex-direction: row;
}

.vr-tour-panel-container {
    width: 342px;
	height: 100vh;
	position: absolute;
    top: 0;
    left: 0;
	background-color: #FFF;
    -moz-box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.32);
    -webkit-box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.32);
    box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.32);
	z-index: 3;
	transition: all 0.2s ease;
    overflow: scroll;
}

.vr-tour-show-details {
	display: none;
}

#vrtour {
    width: 100%;
}

.vr-tour-panel-tour-info-container {
	border-top: 1px solid #E5E3E3;
	border-bottom: 1px solid #E5E3E3;
    padding: 24px 0px;
    margin: 0px 24px 24px 24px;
}

.vr-tour-panel-tour-key-info-container {
    display: flex;
    flex-direction: row;
	margin-top: 16px;
	position: relative;
}

.vr-tour-panel-tour-info-item {
	display: flex;
	flex-direction: row;
	align-items: center;
	margin-right: 16px;
	position: relative;
}

.vr-tour-panel-tour-info-item:last-child {
	margin-right: 0px;
}

.vr-tour-panel-tour-info-item img {
	width: 16px;
	height: 16px;
	margin-right: 8px;
}

.vr-tour-panel-tour-author-container {
	display: flex;
	flex-direction: row;
	align-items: center;
	margin-top: 16px;
	margin-bottom: 16px;
	position: relative;
}

.vr-tour-panel-tour-author-container img {
	width: 40px;
	height: 40px;
	border-radius: 100%;
	border: 2px solid #fff;
	margin-right: 16px;
	box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.32);
}

.vr-tour-panel-tour-author-container p {
	margin-right: 4px;
}

.vr-tour-panel-map-container {
	margin-top: 24px;
	overflow: hidden;
	height: 385px;
	width: 100%;
	position: relative;
}
  
.vr-tour-panel-map-visual {
	background-position: center top;
	background-size: cover;
	background-repeat: no-repeat;
	width: 100%;
	height: 385px;
}

.tour-map-white-gradient-overlay {
	width: 100%;
	height: 40%;
	position: absolute;
	bottom: 0;
	background: linear-gradient(rgba(255, 255, 255, 0), white 75%);
	z-index: 1;
}

.tour-map-slider-arrows-container {
	height: 40px;
	position: absolute;
	width: 100%;
	bottom: 120px;
}

@media (max-width: 960px) {
	.tour-map-slider-arrows-container {
		width: 100%;
	}
}

.panel-open {
	left: 342px;
	right: 0px;
}

@media (max-width: 600px) {

	.vr-panel {
		position: relative;
    	width: 100%;
    	height: 100%;
	}

	.vr-tour-panel-container {
		width: 100%;
		height: 100%;
		-moz-box-shadow: -8px 0px 16px rgba(0, 0, 0, 0.32);
		-webkit-box-shadow: -8px 0px 16px rgba(0, 0, 0, 0.32);
		box-shadow: -8px 0px 16px rgba(0, 0, 0, 0.32);
	}

	.vr-tour-show-details {
		display: block;
		width: 100%;
		height: 72px;
		outline: none;
		border: none;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.vr-tour-show-details::before {
		width: 16px;
		height: 16px;
		content: " ";
		background-image: url(../img/chevron-up.svg);
		background-repeat: no-repeat;
		background-position: center;
		margin-right: 8px;
		transform: rotate(180deg);
		transition: all 0.2s ease;
	}

	.mob-panel-closed .vr-tour-show-details::before {
		transform: rotate(0deg);
	}

	.mob-panel-closed {
		transform: translateY(calc(100% - 72px));
		overflow: hidden;
	}

	.panel-open-mob {
		bottom: 72px;
	}

	.tour-map-slider-arrows-container {
		display: none;
	}

	#loading-text {
		position: relative;
	}

	.panel-open {
		left: 0px;
		right: 0px;
	}
}

/* iFrame Specific */

.vr-tour-iframe-tour-details {
	z-index: 1;
	padding: 0px 16px;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
	align-items: center;
	text-align: center;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.z-index-10 {
	z-index: 10;
}

.vr-tour-iframe-tour-details h3,
.vr-tour-iframe-tour-details h5,
.vr-tour-iframe-tour-details p {
	color: #FFF;
	position: relative;
}
