
html {
	font-family: sans-serif;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%
}
body {
	margin: 0
}
ul, .slick-dots, .menu-top-list, .menu-main-list ul, .footer-top-list, .footer-bottom-list, .anchor-menu .anchor-menu-list, .markers-list, .contact-list, .phone-list, .product-list, .product-menu {
	margin: 0;
	padding: 0;
	list-style: none
}
.has--2-boxes {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column
}
.slide-wrapper .has--2-boxes {
	height: 100%
}
.slide-wrapper .has--2-boxes .box.box-event {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex
}
.slide-wrapper .has--2-boxes .box.box-event .box-inner {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex
}
.has--2-boxes .box a {
	color: #3d3d3c
}
.has--2-boxes .box.box-event {
	height: auto;
	border-bottom: 1px solid #d8d8d8
}
.has--2-boxes .box.box-event .box-inner .box_text-wrapper {
	width: 100%
}
.has--2-boxes .box.box-event .box-inner .box_content {
	padding: 20px 20px 10px
}
.has--2-boxes .box.box-event h1, .has--2-boxes .box.box-event h2, .has--2-boxes .box.box-event h3, .has--2-boxes .box.box-event h4, .has--2-boxes .box.box-event .section-subtitle {
	font-size: 1rem;
	font-weight: bold;
	padding: 10px 0 15px 0;
	white-space: nowrap;
	overflow: hidden;
	position: relative
}
.has--2-boxes .box.box-event h1:after, .has--2-boxes .box.box-event h2:after, .has--2-boxes .box.box-event h3:after, .has--2-boxes .box.box-event h4:after, .has--2-boxes .box.box-event .section-subtitle:after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	background: #fff;
	background: -webkit-linear-gradient(left, transparent 0%, #fff 100%);
	background: linear-gradient(to right, transparent 0%, #fff 100%);
	width: 30px
}
.has--2-boxes .box.box-event .address {
	margin-bottom: 0;
	border: none
}
.box {
	box-shadow: 0 5px 11px 0 rgba(0,0,0,0.18), 0 4px 15px 0 rgba(0,0,0,0.15);
	background: #fff;
	min-height: 400px;
	overflow: hidden;
	position: relative
}
.ie .box {
	box-shadow: 0 4px 16px 0 rgba(0,0,0,0.18), 0 2px 20px 0 rgba(0,0,0,0.15)
}
.box:hover a:hover {
	text-decoration: none
}
.box:hover:not(.has--overlay) .hover-block {
	opacity: 1
}
.box.has--read-more {
	padding-bottom: 55px
}
.box.box-event {
	background: #F5F5F5
}
.box.box-event h1, .box.box-event h2, .box.box-event h3, .box.box-event h4, .box.box-event .section-subtitle {
	padding: 20px 30px 20px;
	box-sizing: border-box;
	margin: 0
}
.box.box-event .box_img-wrapper {
	position: relative
}
.box.box-event .box-img {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%)
}
.box.box-event .box_content {
	padding: 20px 20px 10px
}
.box.box-event .address, .box.box-event .date {
	margin-bottom: 15px
}
.box.box-event .address .ic, .box.box-event .date .ic {
	display: inline-block;
	width: 40px;
	height: 40px;
	text-align: center;
	background-color: #fff;
	box-shadow: 0px 0px 9px 0px rgba(0,0,0,0.4);
	margin-bottom: 15px;
	padding-top: 8px;
	margin-left: 0;
	margin-right: 10px
}
.box.box-event .date {
	font-weight: normal;
	margin-bottom: 0;
	font-size: 1.5rem;
}
.has--2-boxes .box {
	min-height: auto
}
.box .address {
	border-bottom: 1px solid #D8D8D8
}
.box.box-image img {
	width: 100%;
	height: auto
}
.box.box-camera {
	background-color: #F5F5F5
}
.box.box-camera .compare-btn-remove, .box.box-camera .compare-btn-add {
	position: absolute;
	top: 15px;
	right: 15px;
	background: transparent;
	border: none;
	padding: 0
}
.box.box-camera .compare-btn-remove svg, .box.box-camera .compare-btn-add svg {
	margin-left: 10px;
	fill: #3c3c3b
}
.box.box-camera .compare-btn-remove:hover {
	cursor: pointer
}
.box.box-camera .compare-btn-remove svg {
	fill: #ed1c29
}
.box.box-camera .compare-btn-add:hover {
	cursor: pointer
}
.box.box-camera .box_description .row {
	border-bottom: 1px solid #D8D8D8;
	padding-bottom: 8px;
	margin-bottom: 8px
}
.box.box-camera .box_description .row:last-child {
	border-bottom: none
}
.box.box-camera .box_description .label {
	font-weight: bold;
	width: 120px
}
.box.box-camera .box_description .value {
	width: calc(100% - 120px)
}
.box.box-camera .box_description .value p {
	margin: 0
}
.box.box-compare {
	box-shadow: none;
	background: transparent
}
.box.box-compare:hover .hover-block {
	opacity: 0
}
.box.box-compare .box-inner {
	padding: 30px 10px 10px
}
.box.box-compare .box_img-wrapper {
	box-shadow: 0 5px 11px 0 rgba(0,0,0,0.18), 0 4px 15px 0 rgba(0,0,0,0.15);
	background: #fff
}
.box.box-compare .box_img-wrapper:hover .hover-block {
	opacity: 1
}
.box.box-compare .compare-btn-remove {
	position: absolute;
	top: 0;
	right: 15px;
	background: transparent;
	border: none;
	padding: 0
}
.box.box-compare .compare-btn-remove:hover {
	cursor: pointer
}
.box.box-compare .compare-btn-remove svg {
	margin-left: 10px;
	fill: #ed1c29
}
.box.box-camera .flag.is--new, .box.box-compare .flag.is--new {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background: #ED1C29;
	color: #fff;
	text-transform: uppercase;
	padding: 3px 8px
}
.box_img-wrapper {
	display: block;
	overflow: hidden;
	position: relative;
	text-align: center;
	background: #fff
}
.box_img-wrapper .box-img {
	width: auto;
	max-width: 100%;
	height: auto;
	max-height: 100%;
	margin: auto
}
.box_img-wrapper .box-img img {
	width: 100%;
	height: auto;
	padding:40px;
}
.box_img-wrapper .hover-block {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	opacity: 0;
	font-size: 0;
	text-align: center;
	background: rgba(240, 29, 29, 0.5);
	-webkit-transition: opacity .25s ease-in-out;
	transition: opacity .25s ease-in-out
}
.box_img-wrapper .hover-block:before {
	content: "";
	display: inline-block;
	height: 100%;
	vertical-align: middle
}
.box_img-wrapper .hover-block_text {
	font-size: 16px;
	color: #fff
}
.box_img-wrapper .hover-block_text svg {
	fill: #fff
}
.box_text-wrapper {
	display: block;
	overflow: hidden;
	position: relative;
	background: #fff
}
.box_text-wrapper .hover-block {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	opacity: 0;
	font-size: 0;
	text-align: center;
	background-color: rgba(239,51,61,0.9);
	-webkit-transition: opacity .25s ease-in-out;
	transition: opacity .25s ease-in-out
}
.box_text-wrapper .hover-block:before {
	content: "";
	display: inline-block;
	height: 100%;
	vertical-align: middle
}
.box_text-wrapper .hover-block_text {
	font-size: 1rem;
	color: #fff
}
.box_text-wrapper .hover-block_text svg {
	fill: #fff
}
.box_content {
	padding: 20px 20px;
	box-sizing: border-box
}
.box_content .txt-rte p:last-child {
	margin-bottom: 0
}
.box_read-more {
	background-color: #fff;
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	text-align: center;
	padding: 0 30px;
	border-top: 1px solid #EEE
}
.box_read-more:before {
	content: "";
	background: -webkit-linear-gradient(bottom, #fff 0, rgba(255,255,255,0) 100%);
	background: linear-gradient(to top, #fff 0, rgba(255,255,255,0) 100%);
	position: absolute;
	bottom: 100%;
	bottom: calc(100% + 1px);
	left: 0;
	right: 0;
	height: 50px
}
.box_read-more a {
	padding: 15px 0;
	display: block;
}
.box_overlay {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	text-align: center;
	background: rgba(0,0,0,0.8)
}
.box_overlay svg {
	fill: #fff
}
.no-touchevents .box_overlay:hover {
	background: rgba(0,0,0,0.5)
}
.box_overlay-inner {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%)
}
.box_overlay-txt {
	color: #fff;
	font-weight: bold;
	font-size: 1rem;
	display: block;
	padding: 20px
}
.grid {
	font-size: 0;
	vertical-align: top;
	margin: 0px
}
.flexbox .grid {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch
}
.grid_item {
	display: inline-block;
	vertical-align: top;
	padding: 10px;
	box-sizing: border-box;
	font-size: 1.5rem;
	width: 100%
}
.flexbox .grid_item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch
}
.flexbox .grid_item .box {
	width: 100%
}
.has--2-col .grid_item {
	width: 40%
}
.has--5-col .grid_item {
	width: 19.8%
}

@media (max-width: 679px) {
.has--2-col .grid_item {
	width: 100%
}
.has--5-col .grid_item {
	width: 100%
}
}
.has--3-col .grid_item {
	width: 33.3333%
}
.has--4-col .grid_item {
	width: 24.8%
}
.has--1-col .grid_item {
	width: 28%
}

@media (max-width: 1150px) {
.has--4-col .grid_item {
	width: 33.3333%
}
}

@media (max-width: 1023px) {
.has--3-col .grid_item, .has--4-col .grid_item {
	width: 50%
}
}

@media (max-width: 679px) {
.has--3-col .grid_item, .has--4-col .grid_item {
	width: 100%
}
}
.img-col img, .large-img-col img {
	width: 100%;
	height: auto
}

.section {
	background-color: #fff
}
.section.has--cap-top {
	padding-top: 80px
}

@media (max-width: 768px) {
.section.has--cap-top {
	padding-top: 30px
}
}
.section.has--cap-bottom {
	padding-bottom: 20px
}

@media (max-width: 768px) {
.section.has--cap-bottom {
	padding-bottom: 30px
}
}
.section:first-child.section-text-with-bg-img {
	margin: 0
}
.section.has--cols {
	font-size: 0;
	letter-spacing: 0
}
.section.has--cols .section-col-60, .section.has--cols .section-col-40 {
	display: inline-block;
	vertical-align: top;
	font-size: 1rem
}
.section.has--cols .section-col-60 {
	width: 60%
}
.main-wrapper .section.has--cols .section-col-60 {
	padding-top: 80px
}
.section.has--cols .section-col-40 {
	width: 40%
}
.section.has--cols .container {
	margin-left: auto;
	margin-right: 100px;
	max-width: 690px;
	font-size: 1rem
}

@media (max-width: 1024px) {
.section.has--cols .section-col-60, .section.has--cols .section-col-40 {
	width: 100%
}
.section.has--cols .container {
	margin-right: auto
}
}
.section .container .img-col {
	position: relative
}
.section .container .img-col.has--cap-top {
	margin-top: 30px
}
.section .container .img-col.has--cap-bottom {
	margin-bottom: 30px
}
.section.is--grey, .section.gray-background {
	background-color: #f5f5f5
}
.section.camera .result {
	padding-top: 80px
}
.large-img-col {
	position: relative
}
.gray-background {
	background-color: #f5f5f5
}
.black-gradient {
	background: #3c3c3c;
	background: -webkit-linear-gradient(346deg, #3c3c3c 30%, #131313 100%);
	background: linear-gradient(104deg, #3c3c3c 30%, #131313 100%)
}
.red-gradient {
	background: #ed1c29;
	background: -webkit-linear-gradient(346deg, #ed1c29 30%, #9d2603 100%);
	background: linear-gradient(104deg, #ed1c29 30%, #9d2603 100%)
}