/*site*/
html, body {
	height: 100%;
	margin: 0;
	font-family: 'Montserrat', Sans-serif !important;
	color: #333;
	overflow: visible !important;
}
h1, h2, h3, h4, h5 p, span {
	font-family: 'Montserrat', Sans-serif !important;
}
button {
	outline: none;
	border: none;
}
div {
	box-sizing: border-box;
}


.product-placeholder {
	position: relative;
}
.product-placeholder #loading-gif {
	top: 50%;
	left: 50%;
	position: absolute;
	width: 100%;
	height: 100%;
    text-align: center;
    transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);
	background: rgba(255,255,255,0.5);
}
.product-placeholder #loading-gif img {
	max-width: 300px;
	top: 50%;
	left: 50%;
	position: absolute;
    text-align: center;
    transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);	
}
.co-summary-line div.titles {
	height: auto !important;
}
co-summary-line div.titles span {
	line-height: 1;
}
co-summary-line div.price > span.price {
	font-size: 13px !important;
	font-weight: normal !important;
}
.controls-bottom {
	position: absolute;
    left: 0;	
}
.summary-line {
    position: relative;
	padding-right: 30px;
	min-height: 80px;
}

.summary-line:after {
    content: '\f055';
    position: absolute;
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: 20px;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    right: 10px;
    top: 15px;
}
.header-wrapper {
	width: 100%;
    float: left;
    background: #FFF;
	position: fixed;
	z-index: 10;
	border-bottom: 1px solid #eee;
}
.expand-animated .image-wrapper {
    min-height: 800px;
}
.threed-viewer {
	position: absolute;
	z-index: 4;
	height: 100%;
	left: 0;
	width: 100%;
	top: 0px;
    transition: all .5s;
    -webkit-transition: all .5s;	
	padding: 40px 40px 0 40px;
	box-sizing: border-box;
}
.threed-viewer.expand-animated {
    left: 0;
    padding: 40px;
    box-sizing: border-box;
    transition: all .5s;
    -webkit-transition: all .5s;
}
.fotorama__active {
    position: relative;
    display: block;
    height: 100%;
    width: 100%;
    text-align: center;
}
.configurator-data {
    float: left;
	width: 100%;
}	
.configurator-data span {
    font-size: 16px;
    padding-top: 10px;
    padding-bottom: 10px;
    display: block;
}

.configurator-data p.expand-desc {
	height: auto;
	max-height: 200px;
	background: rgba(255,255,255,0.6);
	-webkit-transition: height 0.4s, background 0.4s; /* Safari prior 6.1 */
	transition: height 0.4s, background 0.4s;
	padding-left: 15px;
	margin-left: -15px;
}
.configurator-data p {
	font-size: 13px;
    line-height: 1.5;
    font-weight: normal;

	-webkit-transition: height 0.4s, background 0.4s; /* Safari prior 6.1 */
	transition: height 0.4s, background 0.4s;
	background: rgba(255,255,255,0);
}
.configurator-data p p {
	height: auto;
}
.configurator-data h1 {
	font-size: 24px;
    font-weight: normal;
	white-space: nowrap;
    text-align: left;
	padding: 25px 0 0 0;
	margin: 0;
}

		
.product-added-information h2 {
	font-size: 22px;
    font-weight: normal;
	white-space: nowrap;
    text-align: left;
	padding-bottom: 20px;
}
.product-added-information .table-wrapper {
	padding-right: 40px;
}
.product-added-information table {
	width: 100%;
}
.product-added-information tr td, .product-added-information tr th {
	text-align: left;
	font-size: 14px;
	font-weight: normal;
	border: none;
}
.header-station {
	padding: 0 100px;
	margin: 0 auto;
	box-sizing: border-box;
	max-width: 1440px;
	padding: 10px 0;
}
.image-wrapper {
	position: relative;
	min-height: 600px;
}
.image-wrapper .animated-wrapper {
	position: absolute;
	right: 60px;
	top: 60px;	
}
.product-info .addtocart {
	width: 100%;
	float: left;
	padding: 30px 0 0 0;
}
.product-info .addtocart i {
	color: #FFF;
	margin-right: 10px;
}
.product-info .addto {
	background-color: #222;
    border-radius: 5px 5px 5px 5px;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 15%);	
	color: #FFF;
    padding: 10px 30px;
    font-size: 18px;
	cursor: pointer;
}
.product-info .addto i.fa:before {
	content:'\f1c1';
}
.image-wrapper .animated-wrapper .animated_3d {   
	background-color: #D22F2F;
    border-radius: 100%;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 15%);
    color: #FFF;
    height: 40px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    width: 40px;
}
.image-wrapper .animated-wrapper .getrender {
	background-color: #D22F2F;
    border-radius: 100%;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 15%);
    color: #FFF;
    height: 40px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    width: 40px;
}
.image-wrapper .animated-wrapper .getrender i:before {
	content:'\f021';
}

.threed-viewer .close_3d {
    background-color: #D22F2F;
    border-radius: 100%;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 15%);
    position: absolute;
    top: 20px;
    right: 20px;
    border: none !important;
    color: #fff;
    padding: 0;
    font-size: 0px;
    cursor: pointer;
	height: 45px;
	width: 45px;
}
.threed-viewer .close_3d i {
	font-size: 22px;
}
.image-wrapper .animated-wrapper img {
	max-width: 240px;
}
.header-station ul {
	margin: 0;
	padding: 0;
}
.header-station ul li {
	display: inline-block;
	list-style: none;
	padding: 20px 20px 0 20px;
}
.header-station .header-logo {
	width: 50%;
	margin: 0 auto;
	text-align: center;
	display: inline-block;
}
.header-station .header-left {
	float: left;
	width: 25%;
}
.header-station .header-right {
	float: right;
	width: 25%;
}
.header-station .header-right ul {
	float: right;
}
.header-station .header-right ul li {
	font-size: 18px;
	padding-right: 10px;
}
.header-station .header-switch {
	width: 50%;
	float: right;
	display: none;
}
.header-station .header-switch ul {
	
}
.header-station .header-switch ul li {
	float: right;
	margin: 0px 10px 0 0;
}
.header-station .header-switch ul li, .header-station .header-switch ul {
	list-style: none;
}
.header-station .header-logo img {
    margin: 0 auto;
}
.header-station .header-switch img {
	height: 60px;
}
.header-station .header-switch li:last-child img {
	border: 4px solid #000000;
	opacity: 1;
}
.header-station .header-switch li img {
	border: 4px solid #222;
	opacity: 0.6;
}

.product-essential-wrapper, .main-essential-wrapper {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 20px;
    box-sizing: border-box;	
}
.product-essential, .main-essential {
	position: relative;
}
.breadcrumbs-wrapper {
    padding: 0;
}
.product-main-information, .main-information-wrapper {
	float: left;
	width: 100%;
	padding-bottom: 40px;
	top: 30px;
	box-sizing: border-box;	
	position: relative;	
}
.product-essential-wrapper .breadcrumbs ul li, .main-essential-wrapper .breadcrumbs ul li {
	display: inline-block;
	list-style: none;
	font-size: 13px;
	padding-right: 10px;
}
.product-essential-wrapper .breadcrumbs ul, .main-essential-wrapper .breadcrumbs ul {
	margin: 0px;
	padding: 15px 0;
}
.product-essential .product-info {
	position: relative;
	width: 30%;
	float: left;
	padding-right: 0px;
}
.product-essential .product-media {
	position: relative;
	width: 70%;
	float: left;
	overflow: hidden;
}
.product-essential .product-media .product-placeholder {
	padding: 0 40px 40px 40px;
}
.product-essential .product-media .product-placeholder img {
	margin-top: 0px;
}
.product-added-information {
	width: 100%;
	float: left;
	padding: 40px 0;	
}
.product-added-information .product-info {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 40px;
}
.product-added-information .product-info p {
    font-size: 14px;
    line-height: 1.5;
    font-weight: normal;
}	
.product-added-information .product-info .product-description {
	width: 40%;
	float: left;
}
.product-added-information .product-info .product-tags {
	width: 30%;
	float: left;
}
.product-added-information .product-info .product-links {
	width: 30%;
	float: left;
	padding-left: 10px;
}
.product-added-information .product-info .product-links .links-wrapper span {
    display: block;
    margin-bottom: 5px;
}
/*bb*/
co-slideout {
	min-width: 600px;
	z-index: 15 !important;
	top: 0px !important;
	max-width: calc(30vw + 60px) !important;
	height: 100% !important;
}
.selections-header {
	text-align: left;
}
.selections-header p {
	font-size: 20px;
    font-weight: normal;
    padding: 15px 0;
	position: relative;
	margin-bottom: 0px;
}

.configurator-data h1 {
	position: relative;
}
.configurator-data h1:after {
	content: "";
    border-top: 2px solid #000000;
    position: absolute;
    left: 0px;
    bottom: 0;
    width: 50px;
    height: 3px;
    top: 60px;
}	
.selections {
	width: 100%;
	float: left;
	top: 0px;
	z-index: 10;
	right: 0px;
	background: #FFF;
	box-sizing: border-box;
}

rp-selections-summary {
	background: transparent !important;
	overflow: visible !important;
}
co-summary-line {
	background: transparent !important;
	cursor: pointer;
	box-shadow: none !important;
    border-top: 1px solid #F5F5F5;
}
co-summary-line div.icon.collapse {
	position: absolute;
    right: 0;
    bottom: 0;
    height: 100%;
	grid-area: none;
}
co-summary-line:hover div.icon.collapse {
    border-color: #FFF;
}
co-summary-line div.icon.collapse co-icon {
	position: absolute !important;
    width: 30px !important;
    height: 30px !important;
    bottom: 2px !important;
    margin: 0;
	right: 4px !important;
}
co-summary-line div.icon.collapse co-icon:after {
    content: '\f078';
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: 14px;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;

}
co-summary-line:hover div.icon.collapse co-icon:after {
	color: #FFF;
}
co-summary-line:hover div.icon.collapse co-icon:hover:after {
	color: #000;
}
co-summary-line div.icon.collapse co-icon svg {
	display: none !important;
}
div.sum {
	box-shadow: none !important;
	border-top: 1px solid #F5F5F5;
}
co-card .co-card-wrapper {
	transition: .3s ease-out !important;
}
rp-answer-card {
	position: relative;
}
rp-answer-card:hover {
	min-height: 100px;
}
rp-answer-card:hover co-card .co-card-wrapper {
	transform: scale(1.15);
	background: #e4e9e8 !important;
	position: absolute;
    z-index: 999999;
	width: 100%;
}
rp-answer-card:hover co-card .co-card-wrapper span.description {
	height: auto !important;
	min-height: 30px;
	overflow: visibile !important;
}
co-summary-line:hover, co-summary-line.highlighted {
	background: rgba(0,0,0,0.7) !important;
}
co-summary-line:hover div span, co-summary-line:hover div label, co-summary-line.highlighted div label, co-summary-line.highlighted div span{
	color: #FFF !important;
}
co-summary-line.highlighted co-html-header h1 {
	color: #FFF;
}
co-summary-line:hover .summary-line:after, co-summary-line.highlighted .summary-line:after {
	color: #FFF;
}
co-summary-line.highlighted .summary-content {
	position: absolute;
    left: -100%;
    z-index: 9;
    width: 100%;
    height: 100%;
	background: rgba(0,0,0,0.7);
	top: 1px;
}	
co-summary-line co-image img {
	border-radius: 5px;
}
co-summary-line rp-answer-card {
	width: 33.33333% !important;
}
co-slideout rp-answer-card {
	cursor: pointer;
}
co-slideout div.title {
    margin: 10px 0 0 30px !important;
    padding: 120px 40px 0px 0 !important;
    width: 100% !important;
    float: left !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}
co-slideout div.title h3 {
    display: block !important;
    font-size: 34px !important;
    font-weight: normal !important;
    max-width: 330px !important;
    text-align: right !important;
    margin: 0 !important;
    padding-bottom: 0px;
    float: right !important;
	min-height: 182px;
	box-sizing: border-box;
}
co-slideout span.option-count {
    width: 100% !important;
    float: left !important;
    text-align: right !important;
    padding-right: 5px !important;
    box-sizing: border-box !important;
	margin: 0 !important;
}
.co-card-wrapper .description-wrapper {
	width: 100%;
	align-items: start !important;
	overflow: hidden;
}
rp-answer-card span.description {
	font-size: 12px !important;
    margin-top: 10px !important;
    text-align: left !important;
    overflow: hidden !important;
    padding: 0 10px 0 0 !important;
    box-sizing: border-box !important;
    height: 30px !important;
	line-height: normal;
}	
rp-answer-card span.price {
    font-weight: normal !important;
    font-size: 12px !important;
}

.sum {
  background-color: transparent !important;
}
	
.controls-bottom {

	position: absolute;
	
	
}
co-summary-line label {
	white-space: nowrap;
	cursor: pointer;
}
canvas {
	height: 100%;
	width: 100%;
}
div#Configurator {
	width: 100%;
	float: left;
}
div#Configurator .wrapper {
	
	padding: 20px;
}
div#Configurator .wrapper img {
	max-height: 40px;
}

.config-wrapper {
	box-sizing: border-box;
    width: 100vw;
    height: 100vh;
    position: relative;
    z-index: 2;
    padding: 40px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}
.highlighted {
	box-shadow: none !important;
	outline: none !important;
}
.configurator__title {
    position: absolute;
    top: 60px;
    left: 40px;
    z-index: 3;
}
.configurator__title h2 {
    font-family: 'FuturaStd-Bold';
    font-size: 32px;
    line-height: 36px;
    margin: 0;
    color: black;
}
.check {
	background-color: #000000 !important;
	width: 20px !important;
	height: 20px !important;
}

body .force-expand, body .force-info {display: none !important;}

@-webkit-keyframes scaleout {0%{-webkit-transform:scale(0);transform:scale(0)}100%{-webkit-transform:scale(1);transform:scale(1);opacity:0}}@keyframes scaleout{0%{-webkit-transform:scale(0);transform:scale(0)}100%{-webkit-transform:scale(1);transform:scale(1);opacity:0}}
#CarouselWrapper img{max-width: 100%; max-height: 800px;}
#ConfiguratorView2D{position: absolute; width: 70vw; height: calc(100% - 200px); top: 60px; left: 0;z-index:7;}

@media only screen and (max-width:992px) {
	body.expanded .product-essential .product-media {
		position: fixed;
		width: 100%;
		height: 100%;
		background: #FFF;
		top: 0;
		left: 0;
		transition: max-width .25s ease;
		margin: 0 !important;
	}	
	body.expanded .animated_expand {
		display: none;
	}
	body.expanded .selections-header {
		display: none;
	}
	body.expanded .selections {
		position: fixed;
		right: 0;
		bottom: 0px !important;
		height: 80px !important;
		top: initial !important;
		min-height: 0 !important;
		padding: 0 !important;
		box-shadow: 0px 10px 20px 0px #000;
		z-index: 999999999999;
		box-sizing: border-box;
		width: 100%;
		max-width: 100%;
		left: 0;	
		background: rgba(255, 255, 255, 1);
	}	
	body.expanded .product-essential .product-media threed-configurator {
		max-height: calc(100% - 60px);
		max-width: 100%;
	}
	body.expanded .selections-content {
		overflow-x: auto;
		overflow-y: hidden;
		display: flex;
		gap: 10px;
		height: 100%;
	}
	body.expanded rp-selections-summary {
		height: 100%;
	}
	body.expanded rp-selections-summary-line {
		max-width: 70px;
		padding: 0 5px;
	}
	body.expanded .co-summary-line {
		border-top: none !important;
	}
	body.expanded .co-summary-line .summary-line {
		display: flex;
		flex-direction: column;
		padding-right: 0;
	}
	body.expanded .co-summary-line .image {
		display: flex;
		flex-shrink: 0;
		width: 100%;
		height: 40px;
		padding: 3px;
		justify-content: center;
	}
	body.expanded .co-summary-line .image co-image {
		width: auto !important;
		height: auto !important;
		padding: 0 !important;
		margin: 0 !important;
	}
	body.expanded co-summary-line div.icon.collapse {
		display: none;
	}
	body.expanded .summary-line:after {
		display: none;
	}
	body.expanded .co-summary-line .title-wrapper:first-child {
		margin-top: 0px !important;
	}
	body.expanded .co-summary-line div.titles {
		line-height: 1.23;
		margin: 0px;
	}	
	body.expanded .co-summary-line .titles label {
		font-size: 11px !important;
		line-height: 1.23;
		margin-bottom: 0px !important;
		font-style: normal;
	}
	body.expanded co-summary-line div.titles span {
		font-size: 10px !important;
		display: -webkit-box;
		-webkit-line-clamp: 1;
		-webkit-box-orient: vertical;
		overflow: hidden;
		text-overflow: ellipsis;
	}	
	body.expanded .co-summary-line .total-price {
		display: none;
	}
	body.expanded .configurator-data {
		position: fixed;
		top: 0;
		z-index: 999999999;
		left: 50%;
		width: calc(100% - 100px);
		transform: translateX(-50%);
	}
	body.expanded .product-name {
		display: flex;
		align-items: center;
		justify-content: center;
	}
	body.expanded .configurator-data h1#title_wrapper {
		padding:8px 5px 0 5px !important;
		font-weight: 600;
		display: -webkit-box;
		-webkit-line-clamp: 1;
		-webkit-box-orient: vertical;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: normal;
	}
	body.expanded .configurator-data span {
		padding: 10px 5px 0 5px;
		display: none;
	}	
	body.expanded .configurator-data h1:after {
		display: none;
	}
	body.expanded .threed-viewer {
		padding: 0;
	}
	body.expanded .product-info .addtocart {
		position: fixed;
		bottom: 90px;
		right: 10px;
		left: initial !important;
		display: flex;
		width: auto;
	}
	body.expanded .product-added-information {
		display: none;
	}
	body.expanded .product-added-information.active {
		display: block;
		position: fixed;
		background: #FFF;
		z-index: 9999999999;
		top: 60px;
		/* padding: 0; */
		height: calc(100% - 60px);
	}	
	body.expanded header.header {
		display: none !important;
	}
	body.expanded .product-info .addto {
		padding: 5px 20px;
		font-size: 14px;
	}
	body.expanded div.sum {
		position: fixed;
		z-index: 999;
		gap: 5px;
		bottom: 90px;
		right: 177px;
		width: auto;
		height: auto;
		border-top: none !important;
	}
	body.expanded div.sum label {
		margin: 0;
	}
	body.expanded .controls-bottom {
		display: none !important;
	}
	body.expanded co-slideout {
		width: 600px !important;
		z-index: 15 !important;
		top: 0px !important;
		max-width: 100% !important;
		height: 100% !important; 
		min-width: auto !important;
	}
	body.expanded .search-button {
		display: none !important;
	}
	body.expanded co-slideout div.title {
		padding: 60px 40px 0 0 !important;
	}
	body.expanded co-slideout div.title h3 {
		min-height: 0 !important;
		padding-left: 30px !important;
		padding-right: 30px !important;
		font-size: 30px !important;
		font-weight: normal !important;
		max-width: 100% !important;	
		text-align: left !important;
		float: left !important;		
	}
	body.expanded co-slideout rp-answer-card.small-mode {
		width: 20% !important;
	}
	body.expanded .site-footer {
		display: none !important;
	}
	body.expanded .force-expand {
		height: 40px !important;
		top: 10px !important;
		width: 50px;
		right: initial;
		left: 10px;
		background: none;
		position: absolute;
		z-index: 99;
		bottom: 10px;
		display: block !important;
	}
	body.expanded div.back-btn {
		margin-top: 8px;
		width: 24px;
		height: 24px;
		margin-left: 10px;
	}	
	body.expanded .force-info {
		display: block !important;
		height: 40px !important;
		top: 10px !important;
		width: 50px;
		left: initial;
		right: 10px;
		background: none;
		position: absolute;
		z-index: 99;
		bottom: 10px;
	}
	body.expanded div.info-btn {
		margin-top: 8px;
		width: 24px;
		height: 24px;
		margin-left: 10px;
	}	
}

@media only screen and (max-width:768px){

	.product-essential .product-media {
		margin-top: 60px;
		width: 100%;
	}
	.product-essential .product-info {
		position: initial !important;
		width: 100%;
	}
	button.animated_expand {
		display: none;
	}
	.configurator-data {
		float: left;
		width: 100%;
		position: absolute;
		top: -30px;
		left: 0;
		width: 100%;
		text-align: center;	
	}
	.configurator-data h1 {
		text-align: center;
		width: auto;
		display: inline-block;
	}
	.selections {
		width: 100%;
	}
	.product-added-information .product-info .product-description {
		width: 100%;
		float: left;
		padding: 10px;
	}
	.product-added-information .product-info .product-tags {
		width: 100%;
		float: left;
		padding: 10px;
	}
	.product-added-information .product-info .product-links {
		width: 100%;
		float: left;
		padding: 10px;
	}
	

}
@media only screen and (max-width:640px){
	body.expanded co-slideout rp-answer-card.small-mode {
		width: 33.3333% !important;
	}
}
@media print {
	co-summary-line div.icon.collapse {
		display: none !important;
	}
	#render_img {
		display: none !important;
	}
	button.animated_expand, .animated-wrapper, .render-wrapper{
		display: none;
	}
	.configurator-data {
		position: absolute;
		top: -50px;
		width: 100%;
		left: 0;
		text-align: center;
	}
	.image-wrapper {
		max-height: 600px !important;
	}
	.product-essential .product-info {
		position: initial !important;
		width: 100% !important;
		float:none !important;
		page-break-before: always;
		display: block !important;
	}
	.product-essential .product-media {
		width: 100% !important;
		page-break-after: always;
		display: block !important;
		float: none !important;		
	}
	.product-name {
		position: relative;
		top: -40px;
	}
	.configurator-data h1 {
		display: inline-block;
	}
	.configurator-data h1:after {
		display: none;
	}
	.configurator-data span {
		display: inline-block;
		margin-left: 30px;
	}
	.product-info .addtocart {
		display: none !important;
	}
	.product-added-information {
		display: none;
	}
	.title-item-list {
		max-height: 100% !important;
		display: flex;
		align-items: flex-start;
		vertical-align: top;
		justify-content: space-between;
		gap: 20px;
		column-gap: 40px;
	}
	div.titles {
		display: block;
	}
	div.titles span {
		line-height: 10px !important;
		font-size: 12px !important;
	}
	.summary-line {
		min-height: 100% !important;
	}
	.title-wrapper {
		margin: 2px 0 !important;
		overflow-y: visible !important;
	}
	.selections-header {
		display: none;
	}
	.co-summary-line {
		float: left !important;
		width: 100% !important;
	}
	.co-summary-line div.titles {
		height: auto !important;
	}
	.builder-item--logo .site-logo {
		padding: 0;
		margin-bottom: -100px;
		position: relative;
		top: -20px;
		z-index: 9999999999999999;
	}
	
	.summary-line:after {
		display: none;
	}
	.builder-item--nav-icon .navbar-toggle {
		display: none !important;
	}
	.bars {
		display: none;
	}
	.selections {
		margin-top: 0px;
	}
}
