@font-face {
	font-family: "Material Symbols Outlined";
	font-style: normal;
	font-weight: 100 700;
	src: url("https://fonts.gstatic.com/s/materialsymbolsoutlined/v335/kJEhBvYX7BgnkSrUwT8OhrdQw4oELdPIeeII9v6oFsI.woff2") format("woff2");
}

.xc-shop-page {
	--xc-shop-charcoal: #1b1c1c;
	--xc-shop-gold: #c19a6b;
	--xc-shop-gold-hover: #af8b5d;
	--xc-shop-muted: #666;
	--xc-shop-border: #e5e7eb;
	--xc-shop-border-light: #f3f4f6;
	--xc-shop-surface: #f9fafb;
	font-family: "Inter", sans-serif;
	color: var(--xc-shop-charcoal);
	background: #fff;
}

.xc-shop-container {
	width: min(100%, 1280px);
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: 24px;
}

.xc-shop-hero {
	padding-block: 32px 24px;
	background: #fff;
}

.xc-shop-breadcrumb,
.xc-shop-breadcrumb a,
.xc-shop-breadcrumb .woocommerce-breadcrumb,
.xc-shop-breadcrumb .rank-math-breadcrumb {
	font-size: 13px;
	font-weight: 500;
	line-height: 20px;
	color: var(--xc-shop-muted);
}

.xc-shop-breadcrumb {
	margin-bottom: 40px;
}

.xc-shop-breadcrumb a:hover,
.xc-shop-breadcrumb a:focus {
	color: var(--xc-shop-gold);
}

.xc-shop-hero-header {
	max-width: 760px;
}

.xc-shop-eyebrow {
	margin: 0 0 12px;
	font-size: 11px;
	font-weight: 700;
	line-height: 16px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--xc-shop-gold);
}

.xc-shop-title {
	margin: 0 0 16px;
	font-size: clamp(42px, 5vw, 64px);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.03em;
	color: var(--xc-shop-charcoal);
}

.xc-shop-description,
.xc-shop-description p {
	margin: 0;
	font-size: 17px;
	font-weight: 400;
	line-height: 1.7;
	color: var(--xc-shop-muted);
}

.xc-shop-content-section {
	padding-block: 48px 88px;
}

.xc-shop-mobile-filter-toggle,
.xc-shop-mobile-filter-button,
.xc-shop-mobile-filter-overlay,
.xc-shop-mobile-filter-close {
	display: none;
}

.xc-shop-layout {
	display: flex;
	align-items: flex-start;
	gap: 48px;
}

.xc-shop-sidebar {
	flex: 0 0 256px;
	width: 256px;
}

.xc-shop-sidebar-inner {
	position: sticky;
	top: 32px;
	padding: 32px;
	border-radius: 8px;
	background: var(--xc-shop-surface);
}

.xc-shop-sidebar-heading {
	margin-bottom: 28px;
}

.xc-shop-sidebar-heading h2 {
	margin: 0 0 4px;
	font-size: 24px;
	font-weight: 600;
	line-height: 32px;
	color: var(--xc-shop-charcoal);
}

.xc-shop-sidebar-heading p {
	margin: 0;
	font-size: 14px;
	line-height: 20px;
	color: var(--xc-shop-muted);
}

.xc-shop-filter-form,
.xc-shop-sidebar .widget-area {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.xc-shop-widget {
	margin: 0;
}

.xc-shop-widget-title {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0 0 10px;
	padding: 12px;
	border-radius: 4px;
	background: #e5e7eb;
	font-size: 14px;
	font-weight: 700;
	line-height: 20px;
	color: var(--xc-shop-charcoal);
}

.xc-shop-widget-icon,
.material-symbols-outlined {
	font-family: "Material Symbols Outlined";
	font-size: 20px;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	letter-spacing: normal;
	text-transform: none;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	font-feature-settings: "liga";
	-webkit-font-feature-settings: "liga";
	-webkit-font-smoothing: antialiased;
	font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;
}

.xc-shop-filter-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
	max-height: 260px;
	margin: 0;
	padding: 0;
	list-style: none;
	overflow-y: auto;
}

.xc-shop-price-list {
	max-height: none;
}

.xc-shop-filter-list li {
	margin: 0;
	padding: 0;
}

.xc-shop-filter-list a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	min-height: 38px;
	padding: 9px 12px;
	border-radius: 4px;
	font-size: 14px;
	font-weight: 600;
	line-height: 20px;
	color: var(--xc-shop-muted) !important;
	text-decoration: none !important;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.xc-shop-filter-list a:hover,
.xc-shop-filter-list a:focus,
.xc-shop-filter-list a.is-active {
	background: #fff;
	color: var(--xc-shop-charcoal) !important;
}

.xc-shop-filter-list a.is-active {
	box-shadow: inset 3px 0 0 var(--xc-shop-gold);
}

.xc-shop-filter-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 24px;
	padding: 2px 7px;
	border-radius: 999px;
	background: #e5e7eb;
	font-size: 11px;
	font-weight: 700;
	line-height: 16px;
	color: var(--xc-shop-muted);
}

.xc-shop-filter-list a:hover .xc-shop-filter-count,
.xc-shop-filter-list a:focus .xc-shop-filter-count,
.xc-shop-filter-list a.is-active .xc-shop-filter-count {
	background: rgb(193 154 107 / 15%);
	color: var(--xc-shop-gold);
}

.xc-shop-filter-field select,
.xc-shop-sidebar .widget select,
.xc-shop-sidebar .widget input[type="number"],
.xc-shop-sidebar .widget input[type="text"],
.xc-shop-sidebar .widget input[type="search"] {
	width: 100%;
	min-height: 42px;
	padding: 9px 12px;
	border: 1px solid var(--xc-shop-border);
	border-radius: 4px;
	background-color: #fff;
	font-size: 14px;
	font-weight: 500;
	line-height: 20px;
	color: var(--xc-shop-charcoal);
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.xc-shop-filter-field select:focus,
.xc-shop-sidebar .widget select:focus,
.xc-shop-sidebar .widget input:focus {
	border-color: var(--xc-shop-gold);
	box-shadow: 0 0 0 1px var(--xc-shop-gold);
}

.xc-shop-clear-filters {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 12px;
	padding-top: 24px;
	border-top: 1px solid var(--xc-shop-border);
	font-size: 14px;
	font-weight: 700;
	line-height: 20px;
	color: var(--xc-shop-gold) !important;
	text-decoration: none !important;
}

.xc-shop-clear-filters:hover,
.xc-shop-clear-filters:focus {
	text-decoration: underline !important;
}

.xc-shop-products {
	flex: 1 1 0;
	min-width: 0;
}

.xc-shop-grid-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 32px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--xc-shop-border-light);
}

.xc-shop-grid-header h1,
.xc-shop-grid-header h2 {
	margin: 0 0 8px;
	font-size: 40px;
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--xc-shop-charcoal);
}

.xc-shop-result-count,
.xc-shop-result-count .woocommerce-result-count,
.xc-shop-grid-header p {
	float: none;
	margin: 0 !important;
	font-size: 15px;
	font-weight: 400;
	line-height: 22px;
	color: var(--xc-shop-muted);
}

.xc-shop-sort {
	display: flex;
	align-items: center;
	gap: 12px;
	white-space: nowrap;
}

.xc-shop-sort > span {
	font-size: 12px;
	font-weight: 700;
	line-height: 16px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--xc-shop-muted);
}

.xc-shop-sort .woocommerce-ordering {
	float: none;
	margin: 0;
}

.xc-shop-sort select.orderby {
	min-width: 160px;
	min-height: 38px;
	padding: 8px 40px 8px 14px;
	border: 1px solid var(--xc-shop-border);
	border-radius: 4px;
	background-color: #fff;
	font-size: 14px;
	font-weight: 500;
	line-height: 20px;
	color: var(--xc-shop-charcoal);
	outline: none;
}

.xc-shop-page ul.products,
.woocommerce .xc-shop-page ul.products,
.woocommerce-page .xc-shop-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 32px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none;
}

.xc-shop-page ul.products::before,
.xc-shop-page ul.products::after {
	display: none !important;
	content: none !important;
}

.xc-shop-page ul.products li.product,
.woocommerce .xc-shop-page ul.products li.product,
.woocommerce-page .xc-shop-page ul.products li.product {
	display: flex !important;
	flex-direction: column;
	float: none !important;
	clear: none !important;
	width: auto !important;
	min-width: 0;
	margin: 0 !important;
	padding: 24px !important;
	border: 1px solid #cbd5e1;
	border-radius: 4px;
	background: #fff;
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.xc-shop-page ul.products li.product:hover {
	border-color: #94a3b8;
	box-shadow: 0 10px 30px -10px rgb(0 0 0 / 10%);
}

.xc-shop-page ul.products li.product a.woocommerce-loop-product__link {
	display: flex;
	position: relative;
	flex: 1 1 auto;
	flex-direction: column;
	color: inherit;
	text-decoration: none !important;
}

.xc-shop-page ul.products li.product a img {
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 1 / 1;
	margin: 0 0 24px !important;
	padding: 0;
	border-radius: 8px;
	background: var(--xc-shop-surface);
	object-fit: cover;
	transition: transform 500ms ease;
}

.xc-shop-page ul.products li.product:hover a img {
	transform: scale(1.06);
}

.xc-shop-page .xc-loop-product-category {
	margin: 0 0 4px !important;
	font-size: 10px;
	font-weight: 700;
	line-height: 16px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--xc-shop-muted);
}

.xc-shop-page .woocommerce-loop-product__title {
	margin: 0 0 8px !important;
	padding: 0 !important;
	font-size: 20px !important;
	font-weight: 700;
	line-height: 28px !important;
	color: var(--xc-shop-charcoal) !important;
	transition: color 0.2s ease;
}

.xc-shop-page ul.products li.product:hover .woocommerce-loop-product__title {
	color: var(--xc-shop-gold) !important;
}

.xc-shop-page .xc-loop-rating-row {
	display: flex;
	align-items: center;
	gap: 8px;
	height: 16px;
	margin: 0 0 16px;
}

.xc-shop-page ul.products li.product .star-rating {
	display: inline-block;
	float: none !important;
	flex: 0 0 auto;
	width: 5.4em;
	height: 1em;
	margin: 0 !important;
	font-size: 13px;
	line-height: 1;
	color: var(--xc-shop-gold) !important;
	vertical-align: middle;
}

.xc-shop-page ul.products li.product .star-rating::before {
	color: #d1d5db !important;
}

.xc-shop-page ul.products li.product .star-rating span,
.xc-shop-page ul.products li.product .star-rating span::before {
	color: var(--xc-shop-gold) !important;
}

.xc-shop-page .xc-loop-review-count {
	display: inline-flex;
	align-items: center;
	height: 16px;
	margin: 0;
	font-size: 12px;
	font-weight: 500;
	line-height: 16px;
	color: var(--xc-shop-muted);
	vertical-align: middle;
	transform: translateY(1px);
}

.xc-shop-page ul.products li.product .price {
	display: block;
	margin: auto 0 24px !important;
	font-size: 24px !important;
	font-weight: 500 !important;
	line-height: 32px !important;
	color: var(--xc-shop-charcoal) !important;
}

.xc-shop-page .xc-loop-price-currency {
	font-size: 12px;
	font-weight: 500;
	line-height: 16px;
	color: var(--xc-shop-muted);
}

.xc-shop-page ul.products li.product .price ins,
.xc-shop-page ul.products li.product .price bdi,
.xc-shop-page ul.products li.product .price .amount,
.xc-shop-page ul.products li.product .price .woocommerce-Price-currencySymbol {
	font: inherit;
	color: inherit !important;
	text-decoration: none;
}

.xc-shop-page ul.products li.product .price del {
	margin-right: 8px;
	font-size: 0.7em;
	color: #9ca3af !important;
}

.xc-shop-page ul.products li.product .button,
.xc-shop-page ul.products li.product a.button,
.xc-shop-page ul.products li.product .add_to_cart_button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 52px;
	margin: 0 !important;
	padding: 16px 18px !important;
	border: 0 !important;
	border-radius: 2px !important;
	background: var(--xc-shop-gold) !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	line-height: 18px !important;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #fff !important;
	text-align: center;
	text-decoration: none !important;
	transition: background-color 0.2s ease;
}

.xc-shop-page ul.products li.product .button:hover,
.xc-shop-page ul.products li.product .button:focus {
	background: var(--xc-shop-gold-hover) !important;
	color: #fff !important;
}

.xc-shop-page ul.products li.product .added_to_cart {
	display: inline-flex;
	justify-content: center;
	margin-top: 10px;
	font-size: 13px;
	font-weight: 700;
	color: var(--xc-shop-gold) !important;
}

.xc-shop-pagination {
	margin-top: 80px;
}

.xc-shop-pagination .woocommerce-pagination ul.page-numbers,
.xc-shop-pagination nav.woocommerce-pagination ul {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin: 0;
	padding: 0;
	border: 0;
	list-style: none;
}

.xc-shop-pagination .woocommerce-pagination ul.page-numbers li,
.xc-shop-pagination nav.woocommerce-pagination ul li {
	border: 0;
}

.xc-shop-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border: 1px solid var(--xc-shop-border);
	border-radius: 4px;
	background: #fff;
	font-size: 15px;
	font-weight: 700;
	line-height: 20px;
	color: var(--xc-shop-charcoal) !important;
	text-decoration: none !important;
	transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.xc-shop-pagination .page-numbers.current,
.xc-shop-pagination .page-numbers:hover,
.xc-shop-pagination .page-numbers:focus {
	border-color: var(--xc-shop-charcoal);
	background: var(--xc-shop-charcoal);
	color: #fff !important;
}

.xc-shop-page .woocommerce-info {
	border-top-color: var(--xc-shop-gold);
	background: var(--xc-shop-surface);
	color: var(--xc-shop-charcoal);
}

@media (max-width: 1024px) {
	.xc-shop-layout {
		gap: 32px;
	}

	.xc-shop-page ul.products,
	.woocommerce .xc-shop-page ul.products,
	.woocommerce-page .xc-shop-page ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.xc-shop-container {
		padding-inline: 20px;
	}

	.xc-shop-hero {
		padding-block: 24px 8px;
	}

	.xc-shop-content-section {
		padding-block: 28px 64px;
	}

	.xc-shop-mobile-filter-button {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		gap: 8px;
		min-height: 44px;
		margin: 0 0 20px;
		padding: 10px 18px;
		border: 1px solid var(--xc-shop-border);
		border-radius: 4px;
		background: var(--xc-shop-charcoal);
		box-shadow: 0 10px 24px rgb(0 0 0 / 10%);
		font-size: 14px;
		font-weight: 800;
		line-height: 20px;
		letter-spacing: 0.04em;
		text-transform: uppercase;
		color: #fff;
		cursor: pointer;
	}

	.xc-shop-mobile-filter-button .material-symbols-outlined {
		font-size: 20px;
		color: #fff;
	}

	.xc-shop-mobile-filter-overlay {
		display: block;
		position: fixed;
		inset: 0;
		z-index: 9998;
		background: rgb(0 0 0 / 48%);
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.25s ease, visibility 0.25s ease;
	}

	.xc-shop-layout,
	.xc-shop-grid-header {
		flex-direction: column;
		align-items: stretch;
	}

	.xc-shop-sidebar {
		position: fixed;
		top: 0;
		left: 0;
		z-index: 9999;
		width: min(86vw, 360px);
		height: 100dvh;
		flex-basis: auto;
		background: var(--xc-shop-surface);
		box-shadow: 20px 0 40px rgb(0 0 0 / 18%);
		transform: translateX(-105%);
		transition: transform 0.28s ease;
	}

	.xc-shop-sidebar-inner {
		position: relative;
		top: auto;
		height: 100%;
		padding: 24px 20px 32px;
		border-radius: 0;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}

	.xc-shop-mobile-filter-close {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		position: absolute;
		top: 18px;
		right: 16px;
		width: 38px;
		height: 38px;
		border-radius: 999px;
		background: #fff;
		box-shadow: 0 6px 16px rgb(0 0 0 / 10%);
		color: var(--xc-shop-charcoal);
		cursor: pointer;
	}

	.xc-shop-mobile-filter-close .material-symbols-outlined {
		font-size: 20px;
	}

	.xc-shop-mobile-filter-toggle:checked ~ .xc-shop-mobile-filter-overlay {
		opacity: 1;
		visibility: visible;
	}

	.xc-shop-mobile-filter-toggle:checked ~ .xc-shop-layout .xc-shop-sidebar {
		transform: translateX(0);
	}

	.xc-shop-sidebar-heading {
		padding-right: 48px;
	}

	.xc-shop-grid-header h1,
	.xc-shop-grid-header h2 {
		font-size: 32px;
	}

	.xc-shop-sort {
		justify-content: space-between;
	}

	.xc-shop-sort select.orderby {
		width: 100%;
	}

	.xc-shop-page ul.products,
	.woocommerce .xc-shop-page ul.products,
	.woocommerce-page .xc-shop-page ul.products {
		grid-template-columns: 1fr;
		gap: 24px !important;
	}

	.xc-shop-pagination {
		margin-top: 56px;
	}
}

@media (max-width: 480px) {
	.xc-shop-mobile-filter-button {
		width: 100%;
	}

	.xc-shop-sidebar {
		width: min(90vw, 340px);
	}

	.xc-shop-pagination .woocommerce-pagination ul.page-numbers,
	.xc-shop-pagination nav.woocommerce-pagination ul {
		gap: 8px;
	}

	.xc-shop-pagination .page-numbers {
		width: 42px;
		height: 42px;
	}
}
