html {
	padding: 0;
	margin: 0;
}
body {
	-webkit-font-smoothing: antialiased;
	overflow-y: hidden;
	overflow-x: hidden;
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	font: 18px 'Rubik', sans-serif;
	color: #000;
}

*, ::after,::before {
	box-sizing: border-box;
}

button,
.btn {
	padding: 6px;
	border: none;
	border-radius: 3px;
	background-color: #2f498e;
	color: #fff;
	cursor: pointer;
}
.btn.--with-close-icon {
	position: relative;
	padding-left: 19px;
}
.btn.--with-close-icon::after,
.btn.--with-close-icon::before {
	content: '';
	position: absolute;
	top: calc(50% - 0.5em);
	left: 10px;
	width: 2px;
	height: 1em;
	background-color: #fff;
}
.btn.--with-close-icon::before {
	transform: rotate(45deg);
}
.btn.--with-close-icon::after {
	transform: rotate(-45deg);
}
.ui-icon {
	display: inline-block;
	width: 1em;
	height: 1em;
	vertical-align: middle;
	color: inherit;
}
.back-link {
	position: fixed;
	top: 15px;
	left: 15px;
	color: inherit;
	text-decoration: none;
	z-index: 10;
}

.viewer-banner {
	position: fixed;
	top: 0;
	left: 0;
	display: flex;
	width: 100vw;
	padding-left: 75px;
	z-index: 1;
}
.viewer-banner__content {
	display: none;
	padding: 4px;
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
	margin: auto;
	background-color: rgba(0,0,0, .5);
	color: #fff;
	line-height: 0.9em;
}
.viewer-banner__content.--active {
	display: block;
}
@media (min-width: 992px) {
	.viewer-banner {
		top: auto;
		bottom: 0;
		padding-left: 0;
	}
}

.viewer {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.viewer-canvas {
	width: 100%;
	height: 100%;
	user-select: none;
}

.viewer-nav-cube {
	position: absolute;
	bottom: 60px;
	right: 0;
	visibility: hidden;
	z-index: 100;
}

@media (max-width: 768px) {
	.viewer-nav-cube {
		display: none;
	}
}

.viewer-nav-cube.enabled {
	visibility: visible;
}

.viewer-nav-cube canvas {
	width: 180px;
	visibility: inherit !important;
}

.viewer .model-loader {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.model-loader .model-loader-text {
	font-size: 2em;
	text-align: center;
}

.model-loader .model-loader-img {
	border-radius: 50%;
	background-color: #fff;
	opacity: .5;
	padding: 10px;
	box-shadow: 1px 1px 2px #000;
	margin-bottom: 15px;
}

.model-loader .model-loader-img img {
	display: block;
	margin: auto;
	opacity: 0.9;
	width: 50px;
	height: 50px;
}

.viewer-controls {
	position: absolute;
	top: 0;
	right: 0;
	max-height: 100vh;
	color: #fff;
	transition: transform 0.2s;
	z-index: 100;
	border-bottom-left-radius: 2px;
	transform: translateX(calc(100% - 34px));
}
.viewer-controls.--opened {
	transform: translateX(0);
}
.viewer-controls__content {
	max-height: calc(100vh - 31px);
	padding: 2px 5px 0;
	border: 1px solid rgba(0,0,0, .4);
	border-bottom-color: transparent;
	background-color: rgba(0,0,0, .5);
	overflow: auto;
	scrollbar-width: thin;
	scrollbar-color: #363636 #c2c2c2;
}
.viewer-controls::-webkit-scrollbar {
	width: 8px;
	border-radius: 3px;
	background-color: #c2c2c2;
}
.viewer-controls::-webkit-scrollbar-thumb {
	border-radius: 3px;
	border-left: 2px solid transparent;
	border-right: 2px solid transparent;
	background-clip: padding-box;
	background-color: #363636;
}

.viewer-controls label {
	cursor: pointer;
}
.viewer-controls > :last-child label {
	margin-bottom: 0;
}
.viewer-controls .property-list {
	height: 0;
	max-height: 40vh;
	overflow: auto;
	scrollbar-width: thin;
	scrollbar-color: #363636 #c2c2c2;
}
.viewer-controls .property-list::-webkit-scrollbar {
	border-radius: 3px;
	width: 7px;
	background-color: #c2c2c2;
}
.viewer-controls .property-list::-webkit-scrollbar-thumb {
	border-radius: 3px;
	background-color: #363636;
}
.viewer-controls .property-list.--active {
	height: 100%;
	margin-bottom: 8px;
}
.viewer-controls .property-list.--active:empty {
	margin-bottom: 0;
}
.viewer-controls .property-list__item {
	margin-bottom: 5px;
}
.viewer-controls .property-list__item.--active {
	color: #e4ef11;
}
.viewer-controls .model-info {
	display: none;
	padding: 5px;
	margin-top: 4px;
	background: rgba(255,255,255,.6);
	direction: ltr;
}
.viewer-controls .model-info:empty {
	padding: 0;
}
.viewer-controls .model-info.--active {
	display: block;
}
.viewer-controls .model-info p {
	margin: 0 0 5px 0;
	color: #117187;
}
.viewer-controls .model-info p:last-child {
	margin-bottom: 0;
}
.viewer-controls .point-cloud-list {
	direction: ltr;
}
.viewer-controls .btn-control {
	display: flex;
	width: 100%;
	align-items: center;
	gap: 4px;
	padding: 0;
	border: none;
	margin: 0;
	margin-bottom: 3px;
	background-color: transparent;
	cursor: pointer;
	color: #000;
}
html[dir=rtl] .viewer-controls .btn-control {
	flex-direction: row-reverse;
	justify-content: space-between;
}
.viewer-controls .btn-control__text {
	color: #fff;
}
.viewer-controls .btn-control input[type=checkbox] {
	display: none;
}
.viewer-controls .btn-control__icon {
	height: 24px;
	width: 24px;
	padding: 0.15em;
	border-radius: 2px;
	fill: #000;
	background-color: #fff;
	text-align: center;
	line-height: 1em;
}
.viewer-controls svg.icon-hand {
	fill: none;
	stroke: #000;
}
.viewer-controls svg.icon-measurement {
	transform: rotate(90deg);
}
.viewer-controls svg.icon-scissors {
	transform: rotate(-90deg);
}
.viewer-controls .btn-control.active .btn-control__icon {
	color: #fff;
	background-color: #2f498e;
	fill: #fff;
}
.viewer-controls .btn-control.active svg.icon-hand {
	fill: none;
	stroke: #fff;
}
.viewer-controls .btn-group__title {
	padding-left: 29px;
	margin-bottom: 1px;
	color: #292929;
	font-size: .85em;
	line-height: 1em;
}
.viewer-controls .btn-controls-toggle {
	position: relative;
	left: -24px;
	width: calc(100% + 24px);
	padding-top: 3px;
	padding-bottom: 3px;
	margin-bottom: 0;
	border: 1px solid rgba(0,0,0, .4);
	border-right: none;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	background-color: rgba(0,0,0, .6);
	outline: none;
}
html[dir=rtl] .viewer-controls .btn-controls-toggle {
	left: 0;
	padding-right: 5px;
}
html[dir=rtl] .viewer-controls .btn-controls-toggle .btn-control__icon {
	margin-right: auto;
}
.viewer-controls .btn-controls-toggle::before {
	content: '';
	position: relative;
	display: inline-block;
	height: 0;
	width: 0px;
	border: 10px solid transparent;
	border-right: 15px solid #fff;
	border-left-width: 0;
	padding-left: 5px;
	margin-right: 5px;
	will-change: transform;
}
.viewer-controls.--opened .btn-controls-toggle .btn-control__icon {
	transform: scaleX(-1);
}
.viewer-controls.--opened .btn-controls-toggle::before {
	transform: scaleX(-1);
	left: 4px;
}

.viewer-panels {
	position: fixed;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
	border: 1px solid #000;
	background-color: rgba(0,0,0, .8);
}
.viewer-panels > * + * {
	border-top: 1px solid #000;
}
.viewer-panels__messages {
	position: absolute;
	bottom: calc(100% + 2px);
	left: 50%;
	transform: translateX(-50%);
	max-width: 100vw;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.viewer-panels__messages .viewer__message {
	width: max-content;
	max-width: 100%;
	padding: 5px 10px;
	border-radius: 8px;
	margin-bottom: 2px;
	background-color: rgba(0,0,0, .75);
	color: #fff;
}
@media (max-width: 768px) {
	.viewer-panels__messages .viewer__message.--type--screen-record-message {
		display: none !important;
	}
}
.viewer-panels .viewer-panel .viewer-panel__close {
	display: flex;
	align-self: stretch;
	padding-left: 6px;
	border-left: 2px solid #ddd;
	margin-left: auto;
}
.viewer-panels .viewer-panel .viewer-panel__close button {
	display: flex;
	align-items: center;
	align-self: center;
	padding: 0;
	border: none;
	background-color: transparent;
	color: red;
}
.viewer-panels .viewer-panel .viewer-panel__close button svg {
	height: 1.3em;
	width: 1.3em;
}
@media (min-width: 992px) {
	.viewer-panels {
		top: 0;
		bottom: auto;
		border-radius: 0;
		border-bottom-left-radius: 5px;
		border-bottom-right-radius: 5px;
	}
	.viewer-panels__messages {
		top: calc(100% + 2px);
		bottom: auto;
	}
}

.modal {
	display: none;
	flex-direction: column;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 95vw;
	max-height: calc(100vh - 90px);
	border: 1px solid #000;
	border-radius: 5px;
	z-index: 1000;
	background-color: rgba(0,0,0, .9);
}
.modal.--opened {
	display: flex;
}
.modal__header {
	position: relative;
	min-height: 25px;
	padding: 5px;
}
.modal__header .modal__close {
	position: absolute;
	top: 5px;
	right: 5px;
	height: 15px;
	width: 15px;
	padding: 0;
	border: none;
	background-color: transparent;
}
.modal__close::after,
.modal__close::before {
	content: '';
	position: absolute;
	top: 0;
	left: auto;
	right: auto;
	width: 2px;
	height: 100%;
	background-color: #fff;
}
.modal__close::before {
	transform: rotate(45deg);
}
.modal__close::after {
	transform: rotate(-45deg);
}
.modal__footer {
	padding: 5px;
}
.modal__body {
	padding-left: 5px;
	padding-right: 5px;
	overflow: auto;
}

@media (max-width: 768px) {
	.viewer-controls .assembly {
		max-height: 30vh;
	}
}

.distance-plugin-pointer {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 21px;
	height: 21px;
	transform: translate(-50%, -50%);
}
.distance-plugin-pointer.--active {
	display: block;
}
.distance-plugin-pointer::before,
.distance-plugin-pointer::after {
	content: '';
	position: absolute;
	width: 1px;
	height: 100%;
	background-color: blue;
	box-shadow: 0 0 2px #fff;
}
.distance-plugin-pointer::before {
	top: 0;
	left: 10px;
}
.distance-plugin-pointer::after {
	top: 0;
	left: 10px;
	transform: rotate(90deg);
}
.distance-plugin-pointer.--surface {
	background-color: pink;
	border: 2px solid red;
}
.distance-plugin-pointer.--edge {
	background-color: greenyellow;
	border: 2px solid green;
	height: 6px;
	width: 6px;
}
.distance-plugin-pointer.--vertex {
	height: 11px;
	width: 11px;
	background-color: rgba(236, 236, 236, .3);
	border: 2px solid rgb(50, 50, 50);
}
.distance-plugin-pointer.--vertex::before,
.distance-plugin-pointer.--vertex::after,
.distance-plugin-pointer.--edge::before,
.distance-plugin-pointer.--edge::after,
.distance-plugin-pointer.--surface::before,
.distance-plugin-pointer.--surface::after {
	content: none;
}

.distance-plugin-controls {
	display: none;
	position: fixed;
	bottom: 0;
	left: 50%;
	padding-bottom: 5px;
	transform: translateX(-50%);
}
.distance-plugin-controls.--active {
	display: block;
}
.distance-plugin-controls button {
	border: none;
	border-radius: 3px;
	background-color: #353535;
	color: #fff;
	font-size: 17px;
	padding: 5px 10px;
}
.distance-plugin-controls button.add {
	background-color: #971616;
}

@media (min-width: 768px) {
	.distance-plugin-controls {
		display: none !important;
	}
}

.xeokit-context-menu {
	font-family: inherit;
	font-size: 15px;
	display: none;
}
.xeokit-context-menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.xeokit-context-menu ul li {
	list-style-type: none;
	padding-left: 10px;
	padding-right: 20px;
	padding-top: 4px;
	padding-bottom: 4px;
	color: black;
	border-bottom: 1px solid gray;
	background: rgba(255, 255, 255, 0.46);
	cursor: pointer;
}
.xeokit-context-menu ul li:hover {
	background: black;
	color: white;
	font-weight: normal;
}
.xeokit-context-menu .disabled {
	color: gray;
	cursor: default;
	font-weight: normal;
}
.xeokit-context-menu .disabled:hover {
	color: gray;
	background: #eee;
}

.drawing-canvas {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	user-select: none;
}
.drawing-canvas::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	background-color: #fff;
}
.drawing-panel {
	display: none;
	align-items: center;
	gap: 5px 10px;
	padding: 5px 4px 5px 10px;
	color: #fff;
	font-size: 16px;
	direction: ltr;
}
.drawing-panel.--active {
	display: flex;
}
.drawing-panel button {
	line-height: 0.5;
}
.drawing-panel button:disabled {
	background-color: #828aa1;
	cursor: default;
}
.drawing-panel button svg {
	display: inline-block;
	width: 1.4em;
	height: 1.4em;
	color: inherit;
}
.drawing-panel input[type=color] {
	padding: 0;
	border: none;
	block-size: 19px;
	width: 30px;
	height: 30px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: transparent;
	cursor: pointer;
}
.drawing-panel input[type=color]::-webkit-color-swatch {
	border: none;
	padding: 0;
}
.drawing-panel__input-range {
	white-space: nowrap;
}
.drawing-panel__input-range input {
	display: inline-block;
	width: 31px;
	padding: 1px;
	border: none;
	border-radius: 2px;
	background-color: #fff;
	text-align: center;
}
.drawing-panel__tools {
	display: flex;
	gap: 5px;
	line-height: 0.4em;
}
.drawing-panel__tools label {
	cursor: pointer;
}
.drawing-panel__tools span {
	display: inline-block;
}
.drawing-panel__tools svg {
	display: inline-block;
	height: 1.4em;
	width: 1.4em;
	aspect-ratio: 1;
}
.drawing-panel__tool-text-icon {
	width: 1em;
	display: inline-block;
	text-align: center;
	line-height: 1em;
	font-size: 1.4em;
	font-family: "Times New Roman";
}
.drawing-panel__tools input[type=radio] {
	display: none;
}
.drawing-panel__tools input[type=radio]:checked + span {
	color: #2f498e;
}
.drawing-panel__options {
	display: flex;
	align-items: center;
	gap: inherit;
}
.drawing-panel__options-toggle {
	display: none;
}
.drawing-panel__actions {
	white-space: nowrap;
}
.drawing-panel .viewer-panel__close button svg {
	height: 1.8em !important;
	width: 1.8em !important;
}

@media (max-width: 768px) {
	.drawing-panel {
		grid-template-columns: auto auto;
		gap: 5px;
	}
	.drawing-panel.--active {
		display: grid;
	}
	.drawing-panel__options {
		display: none;
		grid-column-start: 1;
		grid-column-end: 3;
		grid-row-start: 2;
		column-gap: 8px
	}
	.drawing-panel__options-toggle {
		display: inline-block;
		padding-right: 5px;
		border-right: 1px solid #888;
	}
}

@media (min-width: 769px) {
	.drawing-panel__action-share {
		display: none;
	}
}

.video-record-panel {
	display: none;
	align-items: center;
	gap: 8px;
	padding: 5px 10px;
	color: #fff;
	font-size: 16px;
	direction: ltr;
	white-space: nowrap;
}
.video-record-panel.--active {
	display: flex;
}
.video-record-panel__time {
	width: 60px;
}
.video-record-panel__time::before {
	content: '';
	display: inline-block;
	height: 10px;
	width: 10px;
	border-radius: 50%;
	background-color: gray;
	box-shadow: 0 0 2px gray;
	margin-right: 5px;
}
.video-record-panel.--recording .video-record-panel__time::before {
	background-color: #c71111;
	box-shadow: 0 0 2px #c71111;
}
.video-record-panel__btn-stop,
.video-record-panel__btn-start {
	position: relative;
	height: 18px;
	width: 18px;
	padding: 0;
	border: none;
	background-color: transparent;
}
.video-record-panel__btn-start::before {
	content: '';
	position: absolute;
	top: 3px;
	left: 3px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: #fff;
}
.video-record-panel.--recording .video-record-panel__btn-start::before {
	left: 5px;
	width: 2px;
	height: 12px;
	background-color: #fff;
	border: none;
}
.video-record-panel.--recording .video-record-panel__btn-start::after {
	content: '';
	position: absolute;
	top: 3px;
	right: 5.5px;
	width: 2px;
	height: 12px;
	background-color: #fff;
}
.video-record-panel__btn-stop::after {
	content: '';
	position: absolute;
	top: 3px;
	left: 3px;
	height: 12px;
	width: 12px;
	background-color: #fff;
}
.video-record-output {
	width: max-content;
}
.video-record-output video {
	max-width: 100%;
	max-height: calc(100vh - 90px - 34px - 25px - 10px);
}
.video-record-output .modal__footer {
	text-align: right
}
@media (min-width: 769px) {
	.video-record-output__btn-share {
		display: none;
	}
}
@media (max-width: 768px) {
	.video-record-output video {
		max-height: 80vh;
	}
	.video-record-output__btn-save {
		display: none;
	}
	.point-cloud-advert {
		display: none;
	}
}
.video-record-share {
	width: 45%;
	height: 45%;
	min-width: 400px;
}
@media (max-width: 768px) {
	.video-record-share {
		width: 100%;
		height: 100%;
	}
}
.video-record-share .modal__body {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	text-align: center;
	line-height: 2em;
}
.video-record-share__progress,
.video-record-share__confirm {
	display: none;
}
.video-record-share__progress.--active,
.video-record-share__confirm.--active {
	display: block;
}

.video-record-share__progress::before {
	content: '';
	display: inline-block;
	width: 30px;
	height: 30px;
	border: 2px solid #fff;
	border-left-color: transparent;
	border-right-color: transparent;
	border-radius: 50%;
	animation: rotate .7s infinite linear;
}

@keyframes rotate {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}