/* 8. Pages */
/* ----------------------------------------
	Element Category Page
------------------------------------------*/
.category-default img {
	min-height: 20rem;
}
.category-default .category-content {
	left: 3rem;
}
.category-default .category-title {
	margin-bottom: 0;
	font-size: 2.2em;
}
.category-default .category-count {
	opacity: 0.6;
	line-height: 1.2;
}
.category-ellipse-section {
	margin-bottom: 5.2rem;
}
.category-classic-section {
	background-color: #f8f8f8;
}
.category-masonry-section {
	padding-bottom: 3.7rem;
}
.category-masonry-section .category-grid {
	display: -ms-grid;
	display: grid;
	grid-template-columns: repeat(auto-fill, calc(100% / 4));
	margin: -1rem;
}
.category-masonry-section .category-grid>* {
	padding: 1rem;
}
.category-masonry-section .grid-item1 {
	-ms-grid-column-span: 2;
	grid-column-end: span 2;
	-ms-grid-row-span: 2;
	grid-row-end: span 2;
}
.category-masonry-section .grid-item2 {
	-ms-grid-column-span: 1;
	grid-column-end: span 1;
	-ms-grid-row-span: 1;
	grid-row-end: span 1;
}
.category-masonry-section .grid-item3 {
	-ms-grid-column-span: 1;
	grid-column-end: span 1;
	-ms-grid-row-span: 2;
	grid-row-end: span 2;
}
.category-masonry-section .grid-item3 .category-banner,
.category-masonry-section .grid-item3 figure,
.category-masonry-section .grid-item3 img {
	height: 100%;
}
@media (max-width: 991px) and (min-width: 768px) {
	.category-masonry-section .category-grid {
		grid-template-columns: repeat(auto-fill, calc(100% / 3));
	}
	.category-masonry-section .grid-item3 {
		-ms-grid-row: 1;
		grid-row-start: 1;
		-ms-grid-column: 3;
		grid-column-start: 3;
		-ms-grid-row-span: 3;
		grid-row-end: span 3;
	}
}
@media (max-width: 767px) {
	.category-masonry-section .category-grid {
		grid-template-columns: repeat(auto-fill, calc(100% / 2));
	}
}
@media (max-width: 575px) {
	.page-title {
		font-size: 3rem;
	}
	.page-subtitle {
		font-size: 1.2rem;
	}
}
@media (max-width: 479px) {

	.category-masonry-section .grid-item2,
	.category-masonry-section .grid-item3 {
		-ms-grid-row-span: 1;
		grid-row-end: span 1;
		-ms-grid-column-span: 2;
		grid-column-end: span 2;
	}
}
/*--------------------------
	Error 404
--------------------------*/
.error-404 {
	padding-top: 14.5rem;
	padding-bottom: 10rem;
	background-color: #f7f7f7;
}
.error-404 figure {
	margin: 0 auto;
	max-width: 82rem;
}
.error-404 .banner-content {
	margin-top: 5.5rem;
}
.error-404 .banner-title {
	margin-bottom: 0.8rem;
}
.error-404 p {
	margin-bottom: 3.3rem;
}
/*--------------------------------------------
	Single Product Page
----------------------------------------------*/
.product-gallery {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	position: sticky;
}
.product-gallery.row>* {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.product-gallery.product-gallery-sticky {
	top: 2rem;
}
.product-gallery-btn {
	position: absolute;
	padding: 1rem;
	width: 4rem;
	height: 4rem;
	right: 1.5rem;
	bottom: 1.5rem;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 0;
	border-radius: 50%;
	color: #999;
	background: #fff;
	font-size: 2rem;
	line-height: 1;
	opacity: 0.7;
	-webkit-transition: opacity 0.3s, color 0.3s;
	transition: opacity 0.3s, color 0.3s;
	z-index: 1;
	-webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
	cursor: pointer;
}
.product-gallery-btn.product-degree-viewer {
	bottom: 6.5rem;
}
.product-gallery-btn.product-video-viewer {
	bottom: 11.5rem;
}
.product-gallery-btn:hover {
	opacity: 1;
	color: #333;
}
.product-sticky-content.fixed {
	background-color: #fff;
}
.bought-together-products>* {
	width: auto;
}
.bought-together-products .product-wrap {
	position: relative;
	-webkit-box-flex: 0;
	-ms-flex: 0 0 15.8rem;
	flex: 0 0 15.8rem;
	max-width: 15.8rem;
}
.bought-together-products .product-wrap:not(:first-child) {
	margin-left: 3rem;
}
.bought-together-products .product-wrap:not(:first-child) .product-media::before,
.bought-together-products .product-wrap:not(:first-child) .product-media::after {
	content: "";
	position: absolute;
	left: -2.5rem;
	top: 50%;
	background-color: #999;
}
.bought-together-products .product-wrap:not(:first-child) .product-media::before {
	width: 17px;
	height: 1px;
	-webkit-transform: translateX(-8px);
	transform: translateX(-8px);
}
.bought-together-products .product-wrap:not(:first-child) .product-media::after {
	width: 1px;
	height: 17px;
	-webkit-transform: translateY(-8px);
	transform: translateY(-8px);
}
.bought-together-products .product-details {
	padding: 1.5rem 0.2rem 0;
}
.bought-together-products .product-button {
	position: relative;
	margin: 1.3rem 0 2.5rem 10rem;
}
.bought-together-products .product-button::before,
.bought-together-products .product-button::after {
	content: "";
	position: absolute;
	left: -5rem;
	top: 70px;
	width: 17px;
	height: 1px;
	-webkit-transform: translateX(-8px);
	transform: translateX(-8px);
	background-color: #999;
}
.bought-together-products .product-button::before {
	margin-top: -12px;
}
.bought-together-products .bought-price {
	font-size: 2.4rem;
}
.bought-together-products .bought-count {
	margin-bottom: 2.7rem;
	line-height: 1.3;
}
.bought-together-products .product-media:hover img {
	opacity: 1;
}
.bought-together-products .product-checkbox {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.bought-together-products .product-checkbox label {
	position: static;
	padding-left: 0;
}
.bought-together-products .custom-checkbox {
	cursor: pointer;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}
.bought-together-products .custom-checkbox+label::before {
	top: 1.5rem;
	left: 1.5rem;
	-webkit-transform: none;
	transform: none;
}
.product-tabs .nav-item:not(:last-child) {
	margin-right: 4rem;
}
.product-tabs .nav-link {
	padding: 1.5rem 0 1.3rem;
	font-size: 2rem;
	font-weight: 700;
	color: #999;
	text-transform: capitalize;
}
.product-tabs .nav-link::after {
	border-top: 2px solid transparent;
}
.product-tabs .nav-tabs .nav-link:hover,
.product-tabs .nav-tabs .nav-link.active {
	color: #333;
}
.product-tabs .tab-pane {
	padding: 3.5rem 0 2.7rem;
}
.product-tabs ul {
	font-size: 1.4rem;
	color: #666;
}
.product-tabs .product-video img {
	min-height: 20rem;
}
#product-tab-description .sub-title {
	margin: 0.4rem 0 0.4rem;
	font-size: 1.4rem;
}
#product-tab-description .sub-title span {
	margin-right: 1.2rem;
}
#product-tab-description .detail {
	line-height: 1.6;
}
#product-tab-description ul {
	font-size: 1.3rem;
}
#product-tab-description.card-body .col-md-6 {
	margin-bottom: 1.7rem;
}
#product-tab-specification ul li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	position: relative;
	padding: 0rem 0 1rem;
}
#product-tab-specification ul label {
	-webkit-box-flex: 0;
	-ms-flex: 0 0 20rem;
	flex: 0 0 20rem;
	max-width: 20rem;
	-ms-flex-item-align: center;
	-ms-grid-row-align: center;
	align-self: center;
	z-index: 1;
	color: #333;
}
#product-tab-specification ul p {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	margin-bottom: 0;
}
#product-tab-vendor .vendor-banner img {
	min-height: 29.5rem;
	width: 100%;
}
#product-tab-vendor .vendor-user {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 1.7rem;
}
#product-tab-vendor .vendor-logo img {
	border: 1px solid #eee;
	border-radius: 5px;
}
#product-tab-vendor .vendor-name {
	margin: 0.3rem 0;
	font-size: 1.8rem;
	font-weight: 600;
	color: #333;
}
#product-tab-vendor .vendor-name a {
	color: inherit;
}
#product-tab-vendor .ratings-full {
	margin-right: 0.8rem;
}
#product-tab-vendor .rating-reviews {
	font-size: 1.4rem;
	color: #666;
}
#product-tab-vendor .vendor-info {
	margin-bottom: 3.1rem;
	font-size: 1.4rem;
}
#product-tab-vendor .vendor-info li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	padding: 0.75rem 0;
}
#product-tab-vendor .vendor-info label {
	display: inline-block;
	-webkit-box-flex: 0;
	-ms-flex: 0 0 12rem;
	flex: 0 0 12rem;
	max-width: 12rem;
	padding-right: 1rem;
	color: #333;
}
#product-tab-vendor .store-address {
	font-size: 1.4rem;
	color: #666;
	opacity: 1;
}
#product-tab-vendor .store-phone a {
	color: #333;
}
#product-tab-vendor .store-phone a:hover {
	color: #336699;
}
#product-tab-vendor p {
	font-size: 1.4rem;
	line-height: 1.75;
}
#product-tab-description.card-body,
#product-tab-vendor.card-body,
#product-tab-specification.card-body,
#product-tab-reviews.card-body {
	padding-top: 2.2rem;
	padding-bottom: 2rem;
}
.accordion-simple:not(.accordion-icon) .card-header a::after {
	font-size: 1.6rem;
}
@media (min-width: 768px) {
	#product-tab-vendor .pl-md-6 {
		padding-left: 3rem !important;
	}
}
#product-tab-reviews {
	border-bottom-width: 0;
}
#product-tab-reviews p {
	font-size: 1.4rem;
}
#product-tab-reviews .avg-rating-container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 1rem;
	margin-bottom: 0.2rem;
}
#product-tab-reviews .avg-mark {
	font-size: 6em;
	font-weight: 600;
	color: #336699;
	letter-spacing: -0.025em;
	line-height: 1;
	margin-bottom: 0;
}
#product-tab-reviews .avg-rating {
	margin-left: 1.8rem;
}
#product-tab-reviews .avg-rating p {
	font-size: 1.4rem;
	line-height: 1.4;
}
#product-tab-reviews .avg-rating .ratings-container {
	margin-bottom: 0.3rem;
}
#product-tab-reviews .avg-rating .ratings-full {
	margin-right: 0.8rem;
}
#product-tab-reviews .ratings-value {
	margin-bottom: 1.6rem;
	font-size: 1.4rem;
}
#product-tab-reviews .ratings-value span:first-child {
	margin-right: 2.1rem;
	font-size: 2.5rem;
}
#product-tab-reviews .ratings-value .count {
	margin-left: 0.6rem;
	font-size: 1.2rem;
	color: #aaa;
}
#product-tab-reviews .ratings-list .ratings-container {
	margin-bottom: 1.5rem;
}
#product-tab-reviews .ratings-list .progress-bar {
	max-width: 20rem;
	margin-left: 1.3rem;
	margin-bottom: 0;
	border-radius: 0.4rem;
}
#product-tab-reviews .ratings-list .progress-bar span {
	border-radius: 0.4rem;
}
#product-tab-reviews .ratings-list .progress-value {
	margin-left: 2rem;
	min-width: 4rem;
}
#product-tab-reviews .ratings-list .progress-value mark {
	font-size: 1.2rem;
	color: #666;
}
#product-tab-reviews .title-link {
	font-size: 1.4rem;
}
#product-tab-reviews .review-form {
	padding-top: 0.3rem;
}
#product-tab-reviews .review-form .form-control {
	min-height: 4rem;
	margin-bottom: 2rem;
	font-family: Poppins, sans-serif;
	font-size: 1.3rem;
	border-color: #eee;
	color: #777;
}
#product-tab-reviews .review-form .form-control::-webkit-input-placeholder {
	color: inherit;
}
#product-tab-reviews .review-form .form-control::-moz-placeholder {
	color: inherit;
}
#product-tab-reviews .review-form .form-control:-ms-input-placeholder {
	color: inherit;
}
#product-tab-reviews .review-form .form-control::-ms-input-placeholder {
	color: inherit;
}
#product-tab-reviews .review-form .form-control::placeholder {
	color: inherit;
}
#product-tab-reviews .review-form textarea {
	height: 13.3rem;
}
#product-tab-reviews .review-form .btn {
	background-color: #454545;
	border-color: #454545;
}
#product-tab-reviews .form-group {
	margin: 0.4rem 0 4.1rem;
	font-size: 1.4rem;
}
#product-tab-reviews .form-group label {
	padding-left: 2.7rem;
}
#product-tab-reviews .form-group .custom-checkbox+label::before {
	top: 0;
	-webkit-transform: none;
	transform: none;
	margin-top: 0.2rem;
}
#product-tab-reviews .tab-nav-boxed .nav-item {
	margin: 0 1rem 0.5rem 1rem;
}
#product-tab-reviews .tab-nav-boxed .nav-link {
	font-size: 1.3rem;
	font-weight: 600;
	color: #333;
	border-width: 1px;
	padding: 0.9em 1.5em;
	border-radius: 2rem;
}
#product-tab-reviews .tab-nav-boxed .nav-link::after {
	content: none;
}
#product-tab-reviews .tab-nav-boxed .nav-link:hover,
#product-tab-reviews .tab-nav-boxed .nav-link.active {
	color: #336699;
}
#product-tab-reviews .tab-nav-boxed .tab-pane {
	padding: 1.5rem 0 0;
}
.vendor-product-section {
	margin-bottom: 4.2rem;
}
.vendor-product-section .ratings-container,
.related-product-section .ratings-container {
	margin-bottom: 0.3rem;
}
.product-single .product-countdown-container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin: -0.7rem 0 1.3rem;
	font-size: 1.5rem;
}
.product-single .product-countdown-container .countdown-amount {
	font-weight: 700;
	color: #336699;
}
.description-section .title.title-link::before,
.review-section .title.title-link::before {
	height: 0.2rem;
}
aside .service-list {
	padding: 0 2rem;
	border: 1px solid #eee;
}
aside .service-list>* {
	padding: 1.6rem 0;
}
aside .service-list>*:not(:last-child) {
	border-bottom: 1px solid #eee;
}
aside .service-list .icon-box svg {
	width: 3rem;
	height: 3rem;
}
aside .service-list .icon-box-title {
	font-size: 1.3rem;
	line-height: 1.3;
	letter-spacing: 0;
}
aside .service-list p {
	font-size: 1.2rem;
	line-height: 1.2;
}
aside .sp-sidebar-banner .banner-content {
	top: 9%;
	left: 6.5%;
}
aside .sp-sidebar-banner .banner-title,
aside .sp-sidebar-banner .banner-subtitle {
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	margin-bottom: 0.5rem;
}
aside .sp-sidebar-banner span {
	font-size: 2.4rem;
	margin-right: 0.5rem;
}
@media (min-width: 992px) {
	.sticky-both-content .product-details-1 {
		-webkit-box-ordinal-group: 0;
		-ms-flex-order: -1;
		order: -1;
	}
}
.hotspot-banner {
	overflow: visible;
}
.hotspot-product {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	position: absolute;
	width: 3em;
	height: 3em;
	border-radius: 50%;
	background-color: #fff;
	-webkit-transition: background-color 0.3s;
	transition: background-color 0.3s;
}
.hotspot-product .product {
	position: absolute;
	opacity: 0;
	width: 20em;
	padding: 1rem;
	visibility: hidden;
	background: #fff;
	-webkit-box-shadow: 0 0 30px rgba(0, 0, 0, 0.06);
	box-shadow: 0 0 30px rgba(0, 0, 0, 0.06);
	border-radius: 0.5rem;
	overflow: hidden;
	-webkit-transition: opacity 0.3s, visibility 0.3s, z-index 0.3s, -webkit-transform 0.3s;
	transition: opacity 0.3s, visibility 0.3s, z-index 0.3s, -webkit-transform 0.3s;
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, z-index 0.3s;
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, z-index 0.3s, -webkit-transform 0.3s;
	z-index: -1;
}
.hotspot-product .product .product-action-vertical {
	opacity: 1;
	visibility: visible;
}
.hotspot-product:hover {
	background-color: #333;
}
.hotspot-product:hover .btn-hotspot {
	color: #fff;
}
.hotspot-product:hover .product {
	opacity: 1;
	visibility: visible;
	z-index: 1;
}
.hotspot-product.hotspot-product-1 {
	left: 22.6%;
	top: 10.9%;
}
.hotspot-product.hotspot-product-2 {
	left: 23.8%;
	top: 82%;
}
.hotspot-product.hotspot-product-3 {
	left: 71.1%;
	top: 36.1%;
}
.hotspot-right .product {
	left: 100%;
	top: -6rem;
}
.hotspot-right:hover .product {
	-webkit-transform: translateX(1rem);
	transform: translateX(1rem);
}
.hotspot-top .product {
	bottom: 100%;
	left: -40px;
}
.hotspot-top:hover .product {
	-webkit-transform: translateY(-1rem);
	transform: translateY(-1rem);
}
.hotspot-left .product {
	right: 100%;
	top: -60px;
}
.hotspot-left:hover .product {
	-webkit-transform: translateX(-1rem);
	transform: translateX(-1rem);
}
.btn-hotspot {
	font-size: 1.2em;
	line-height: 1;
	color: #333;
	-webkit-transition: color 0.3s;
	transition: color 0.3s;
}
.pswp img {
	border-radius: 0.3rem;
}
@media (min-width: 768px) {
	body.addtocart-fixed .footer {
		padding-bottom: 12.5rem;
	}
}
@media (max-width: 767px) {
	.hotspot-banner {
		font-size: 0.8rem;
	}
}
@media (max-width: 575px) {
	.bought-together-products .product-wrap {
		-webkit-box-flex: 0;
		-ms-flex: 0 0 12rem;
		flex: 0 0 12rem;
		max-width: 12rem;
	}
	.bought-together-products .product-button {
		margin: -1rem 0 3rem 3rem;
	}
	.bought-together-products .product-button::before,
	.bought-together-products .product-button::after {
		left: -1.5rem;
	}
}
@media (max-width: 479px) {
	.hotspot-banner {
		font-size: 0.6rem;
	}
}
@media (max-width: 375px) {
	#product-tab-specification ul li::before {
		width: calc(44% - 1rem);
	}
	#product-tab-specification ul label {
		-webkit-box-flex: 0;
		-ms-flex: 0 0 44%;
		flex: 0 0 44%;
		max-width: 44%;
	}
}