.xco-ccart,
.xco-ccart * {
	box-sizing: border-box;
}

body.xco-mcart-lock-scroll {
	overflow: hidden;
}

.xco-ccart {
	--xco-ccart-font: "Plus Jakarta Sans", "Inter", "Poppins", Arial, sans-serif;
	--xco-ccart-canvas-bg: transparent;
	--xco-ccart-card-bg: #ffffff;
	--xco-ccart-text: #000000;
	--xco-ccart-muted: #707070;
	--xco-ccart-border: #dedede;
	--xco-ccart-border-soft: #eeeeee;
	--xco-ccart-input-bg: #ffffff;
	--xco-ccart-input-text: #000000;
	--xco-ccart-input-border: #000000;
	--xco-ccart-button-bg: #000000;
	--xco-ccart-button-text: #ffffff;
	--xco-ccart-button-hover-bg: #191919;
	--xco-ccart-secondary-button-bg: #ffffff;
	--xco-ccart-secondary-button-text: #000000;
	--xco-ccart-secondary-button-border: #dedede;
	--xco-ccart-qty-bg: #ffffff;
	--xco-ccart-qty-text: #000000;
	--xco-ccart-qty-border: #000000;
	--xco-ccart-remove-icon: #000000;
	--xco-ccart-remove-icon-hover: #333333;
	--xco-ccart-hover-text: #333333;
	--xco-ccart-page-max-width: 1180px;
	--xco-ccart-layout-gap: 32px;
	--xco-ccart-summary-width: 340px;
	--xco-ccart-title-margin-bottom: 48px;
	--xco-ccart-row-padding-y: 20px;
	--xco-ccart-row-padding-x: 16px;
	--xco-ccart-panel-radius: 22px;
	--xco-ccart-thumb-radius: 12px;
	--xco-ccart-pill-radius: 999px;
	--xco-ccart-thumb-size: 92px;
	--xco-ccart-primary-button-height: 48px;
	--xco-ccart-qty-height: 34px;
	width: 100%;
	max-width: var(--xco-ccart-page-max-width);
	margin: 0 auto;
	font-family: var(--xco-ccart-font);
	color: var(--xco-ccart-text);
	background: var(--xco-ccart-canvas-bg);
}

.xco-ccart a,
.xco-ccart button,
.xco-ccart input {
	font-family: inherit;
}

.xco-ccart__section {
	width: 100%;
}

.xco-ccart__main-title {
	margin: 0 0 var(--xco-ccart-title-margin-bottom) 0;
	font-family: inherit;
	font-size: clamp(34px, 4vw, 48px);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.04em;
	color: var(--xco-ccart-text);
}

.xco-ccart__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, var(--xco-ccart-summary-width));
	gap: var(--xco-ccart-layout-gap);
	align-items: start;
}

.xco-ccart__left,
.xco-ccart__right {
	min-width: 0;
}

.xco-ccart__panel {
	background: var(--xco-ccart-card-bg);
	border: 1px solid var(--xco-ccart-border);
	border-radius: var(--xco-ccart-panel-radius);
}

.xco-ccart__products-card {
	overflow: hidden;
}

.xco-ccart__table-head,
.xco-ccart__row {
	display: grid;
	grid-template-columns: minmax(260px, 1fr) 160px 140px 72px;
	align-items: center;
}

.xco-ccart__table-head {
	min-height: 54px;
	padding: 0 var(--xco-ccart-row-padding-x);
	border-bottom: 1px solid var(--xco-ccart-border);
}

.xco-ccart__th {
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--xco-ccart-text);
}

.xco-ccart__th--product {
	text-align: left;
}

.xco-ccart__th--quantity,
.xco-ccart__th--total {
	text-align: center;
}

.xco-ccart__th--action {
	text-align: right;
}

.xco-ccart__row {
	min-height: calc(var(--xco-ccart-thumb-size) + (var(--xco-ccart-row-padding-y) * 2));
	padding: var(--xco-ccart-row-padding-y) var(--xco-ccart-row-padding-x);
	border-bottom: 1px solid var(--xco-ccart-border);
	background: var(--xco-ccart-card-bg);
}

.xco-ccart__row:last-child {
	border-bottom: none;
}

.xco-ccart__td {
	min-width: 0;
}

.xco-ccart__td--product {
	display: grid;
	grid-template-columns: var(--xco-ccart-thumb-size) minmax(0, 1fr);
	gap: 18px;
	align-items: center;
}

.xco-ccart__thumb {
	display: block;
	width: var(--xco-ccart-thumb-size);
	height: var(--xco-ccart-thumb-size);
	border-radius: var(--xco-ccart-thumb-radius);
	overflow: hidden;
	background: #f5f5f5;
	text-decoration: none;
}

.xco-ccart__thumb-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.xco-ccart__product-title {
	display: block;
	margin: 0 0 7px 0;
	font-size: 19px;
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--xco-ccart-text);
	text-decoration: none;
}

.xco-ccart__product-title:hover {
	color: var(--xco-ccart-hover-text);
	text-decoration: none;
}

.xco-ccart__product-meta,
.xco-ccart__product-meta * {
	font-size: 12px;
	font-weight: 500;
	line-height: 1.35;
	color: var(--xco-ccart-muted);
	margin: 0;
	padding: 0;
}

.xco-ccart__product-meta dl,
.xco-ccart__product-meta dt,
.xco-ccart__product-meta dd,
.xco-ccart__product-meta p {
	display: inline;
	margin: 0;
	padding: 0;
}

.xco-ccart__product-meta dt::after {
	content: ": ";
}

.xco-ccart__product-meta dd::after {
	content: " ";
}

.xco-ccart__td--quantity,
.xco-ccart__td--total,
.xco-ccart__td--action {
	display: flex;
	align-items: center;
}

.xco-ccart__td--quantity,
.xco-ccart__td--total {
	justify-content: center;
}

.xco-ccart__td--action {
	justify-content: flex-end;
}

.xco-ccart__qty-pill {
	display: inline-grid;
	grid-template-columns: calc(var(--xco-ccart-qty-height) - 2px) 42px calc(var(--xco-ccart-qty-height) - 2px);
	align-items: center;
	justify-content: center;
	height: var(--xco-ccart-qty-height);
	border: 1px solid var(--xco-ccart-qty-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-qty-bg);
	overflow: hidden;
}

.xco-ccart__qty-btn {
	width: calc(var(--xco-ccart-qty-height) - 2px);
	height: calc(var(--xco-ccart-qty-height) - 2px);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	color: var(--xco-ccart-qty-text);
	font-size: 15px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	appearance: none;
}

.xco-ccart__qty-btn:disabled {
	opacity: 0.25;
	cursor: not-allowed;
}

.xco-ccart__qty-input {
	width: 42px;
	height: calc(var(--xco-ccart-qty-height) - 2px);
	border: 0 !important;
	box-shadow: none !important;
	outline: 0 !important;
	background: transparent !important;
	text-align: center;
	font-size: 13px;
	font-weight: 700;
	color: var(--xco-ccart-qty-text);
	padding: 0;
	appearance: textfield;
}

.xco-ccart__qty-input:focus,
.xco-ccart__qty-input:focus-visible {
	border: 0 !important;
	box-shadow: none !important;
	outline: 0 !important;
}

.xco-ccart__qty-input::-webkit-outer-spin-button,
.xco-ccart__qty-input::-webkit-inner-spin-button {
	margin: 0;
	appearance: none;
}

.xco-ccart__line-total {
	font-size: 20px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.03em;
	color: var(--xco-ccart-text);
}

.xco-ccart__remove-btn {
	width: 34px;
	height: 34px;
	border: none;
	background: transparent;
	color: var(--xco-ccart-remove-icon);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	cursor: pointer;
	appearance: none;
}

.xco-ccart__remove-btn:hover {
	color: var(--xco-ccart-remove-icon-hover);
}

.xco-ccart__trash-icon {
	width: var(--xco-mcart-trigger-icon-size);
	height: var(--xco-mcart-trigger-icon-size);
	display: block;
}

.xco-ccart__update-button,
.xco-ccart__checkout-button,
.xco-ccart__empty-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: var(--xco-ccart-primary-button-height);
	border: 1px solid var(--xco-ccart-button-bg);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-button-bg);
	color: var(--xco-ccart-button-text);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
	padding: 0 32px;
	cursor: pointer;
	appearance: none;
}

.xco-ccart__update-button {
	margin-top: 22px;
	min-width: 205px;
}

.xco-ccart__update-button:hover,
.xco-ccart__checkout-button:hover,
.xco-ccart__empty-button:hover {
	background: var(--xco-mcart-checkout-button-hover-bg);
	border-color: var(--xco-mcart-checkout-button-hover-border);
	color: var(--xco-mcart-checkout-button-hover-text);
	text-decoration: none;
}

.xco-ccart__summary-card {
	padding: 22px;
}

.xco-ccart__summary-title {
	margin: 0 0 22px 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--xco-ccart-text);
}

.xco-ccart__coupon-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 74px;
	gap: 12px;
	margin: 0 0 20px 0;
}

.xco-ccart__coupon-input {
	width: 100%;
	height: 42px;
	border: 1px solid var(--xco-ccart-input-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-input-bg);
	color: var(--xco-ccart-input-text);
	font-size: 12px;
	font-weight: 500;
	padding: 0 16px;
	outline: none;
}

.xco-ccart__coupon-input::placeholder {
	color: var(--xco-ccart-muted);
	opacity: 1;
}

.xco-ccart__coupon-button {
	height: 42px;
	border: 1px solid var(--xco-ccart-secondary-button-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-secondary-button-bg);
	color: var(--xco-ccart-secondary-button-text);
	font-size: 12px;
	font-weight: 700;
	padding: 0 16px;
	cursor: pointer;
	appearance: none;
}

.xco-ccart__coupon-button:hover {
	border-color: var(--xco-ccart-hover-text);
	color: var(--xco-ccart-hover-text);
}

.xco-ccart__applied-coupons {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: -6px 0 18px 0;
}

.xco-ccart__coupon-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	height: 28px;
	border: 1px solid var(--xco-ccart-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-secondary-button-bg);
	color: var(--xco-ccart-secondary-button-text);
	font-size: 11px;
	font-weight: 700;
	padding: 0 10px;
	cursor: pointer;
	appearance: none;
}

.xco-ccart__coupon-pill-x {
	font-size: 15px;
	line-height: 1;
}

.xco-ccart__summary-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin: 0 0 10px 0;
}

.xco-ccart__summary-label {
	font-size: 13px;
	font-weight: 500;
	line-height: 1.2;
	color: var(--xco-ccart-text);
}

.xco-ccart__summary-value {
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	color: var(--xco-ccart-text);
	text-align: right;
	white-space: nowrap;
}

.xco-ccart__summary-divider {
	height: 1px;
	width: 100%;
	background: var(--xco-ccart-border-soft);
	margin: 14px 0;
}

.xco-ccart__summary-row--total .xco-ccart__summary-label {
	font-size: 14px;
	font-weight: 700;
}

.xco-ccart__summary-row--total .xco-ccart__summary-value {
	font-size: 22px;
	font-weight: 800;
	letter-spacing: -0.04em;
}

.xco-ccart__warranty {
	display: grid;
	grid-template-columns: 22px minmax(0, 1fr);
	gap: 10px;
	align-items: start;
	margin: 34px 0;
}

.xco-ccart__warranty-icon {
	width: 22px;
	height: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--xco-ccart-text);
}

.xco-ccart__check-icon {
	width: var(--xco-mcart-trigger-icon-size);
	height: var(--xco-mcart-trigger-icon-size);
	display: block;
}

.xco-ccart__warranty-text {
	font-size: 11px;
	font-weight: 600;
	line-height: 1.45;
	color: var(--xco-ccart-text);
}

.xco-ccart__warranty-link {
	border: none;
	background: transparent;
	color: var(--xco-ccart-text);
	font-size: 11px;
	font-weight: 800;
	line-height: 1;
	text-decoration: underline;
	padding: 0;
	cursor: pointer;
	appearance: none;
}

.xco-ccart__checkout-button {
	margin-top: 30px;
	width: 100%;
}

.xco-ccart__notices {
	margin: 0 0 18px 0;
}

.xco-ccart__notices:empty {
	display: none;
}

.xco-ccart__notices .woocommerce-message,
.xco-ccart__notices .woocommerce-error,
.xco-ccart__notices .woocommerce-info {
	margin: 0 0 16px 0;
	padding: 14px 18px;
	border: 1px solid var(--xco-ccart-border);
	border-radius: 14px;
	background: var(--xco-ccart-card-bg);
	color: var(--xco-ccart-text);
	font-size: 13px;
	font-weight: 600;
	list-style: none;
}

.xco-ccart__notices .woocommerce-error {
	border-color: rgba(176, 0, 32, 0.35);
	color: #b00020;
}

.xco-ccart__empty {
	width: 100%;
	padding: 60px 30px;
	border: 1px solid var(--xco-ccart-border);
	border-radius: var(--xco-ccart-panel-radius);
	background: var(--xco-ccart-card-bg);
	text-align: center;
}

.xco-ccart__empty-title {
	margin: 0 0 10px 0;
	font-size: 32px;
	font-weight: 800;
	line-height: 1.1;
	color: var(--xco-ccart-text);
}

.xco-ccart__empty-text {
	margin: 0 0 24px 0;
	font-size: 14px;
	color: var(--xco-ccart-muted);
}

.xco-ccart.is-loading {
	pointer-events: none;
	opacity: 0.58;
	transition: opacity 160ms ease;
}

@media (max-width: 1024px) {
	.xco-ccart__layout {
		grid-template-columns: 1fr;
	}

	.xco-ccart__right {
		width: 100%;
	}
}

@media (max-width: 767px) {
	.xco-ccart__table-head {
		display: none;
	}

	.xco-ccart__row {
		grid-template-columns: 1fr;
		gap: 16px;
		min-height: auto;
		padding: 20px;
	}

	.xco-ccart__td--product {
		grid-template-columns: min(82px, var(--xco-ccart-thumb-size)) minmax(0, 1fr);
		gap: 14px;
	}

	.xco-ccart__thumb {
		width: min(82px, var(--xco-ccart-thumb-size));
		height: min(82px, var(--xco-ccart-thumb-size));
	}

	.xco-ccart__product-title {
		font-size: 17px;
	}

	.xco-ccart__td--quantity,
	.xco-ccart__td--total,
	.xco-ccart__td--action {
		justify-content: space-between;
		width: 100%;
	}

	.xco-ccart__td--quantity::before {
		content: "Quantity";
		font-size: 12px;
		font-weight: 700;
		color: var(--xco-ccart-text);
	}

	.xco-ccart__td--total::before {
		content: "Total";
		font-size: 12px;
		font-weight: 700;
		color: var(--xco-ccart-text);
	}

	.xco-ccart__td--action::before {
		content: "Action";
		font-size: 12px;
		font-weight: 700;
		color: var(--xco-ccart-text);
	}

	.xco-ccart__update-button,
	.xco-ccart__coupon-button {
		width: 100%;
	}

	.xco-ccart__coupon-form {
		grid-template-columns: 1fr;
	}
}

/* Menu Cart Widget -------------------------------------------------------- */
.xco-ccart--menu {
	--xco-mcart-section-gap: 12px;
	--xco-mcart-thumb-size: 64px;
	--xco-mcart-green: #129447;
	--xco-mcart-panel-width: var(--xco-ccart-page-max-width);
	--xco-mcart-panel-padding: 22px;
	--xco-mcart-dropdown-offset: 12px;
	--xco-mcart-dropdown-bg: var(--xco-ccart-card-bg);
	--xco-mcart-dropdown-max-height: min(78vh, 760px);
	--xco-mcart-dropdown-padding: 18px;
	--xco-mcart-section-title-margin-bottom: 14px;
	--xco-mcart-product-list-gap: 12px;
	--xco-mcart-product-item-gap: 12px;
	--xco-mcart-product-padding-bottom: 12px;
	--xco-mcart-coupon-gap: 10px;
	--xco-mcart-actions-gap: 10px;
	--xco-mcart-button-min-height: 44px;
	--xco-mcart-button-radius: var(--xco-ccart-pill-radius);
	--xco-mcart-trigger-bg: #000000;
	--xco-mcart-trigger-text: #ffffff;
	--xco-mcart-trigger-border: #000000;
	--xco-mcart-trigger-hover-bg: var(--xco-ccart-button-hover-bg);
	--xco-mcart-trigger-hover-text: #ffffff;
	--xco-mcart-trigger-hover-border: var(--xco-ccart-button-hover-bg);
	--xco-mcart-trigger-gap: 8px;
	--xco-mcart-trigger-icon-size: 18px;
	--xco-mcart-bubble-bg: #ffffff;
	--xco-mcart-bubble-text: #000000;
	--xco-mcart-bubble-border: var(--xco-mcart-trigger-bg);
	--xco-mcart-cart-button-bg: var(--xco-ccart-secondary-button-bg);
	--xco-mcart-cart-button-text: var(--xco-ccart-secondary-button-text);
	--xco-mcart-cart-button-border: var(--xco-ccart-secondary-button-border);
	--xco-mcart-cart-button-hover-bg: var(--xco-ccart-secondary-button-bg);
	--xco-mcart-cart-button-hover-text: var(--xco-ccart-secondary-button-text);
	--xco-mcart-cart-button-hover-border: var(--xco-ccart-text);
	--xco-mcart-checkout-button-bg: var(--xco-ccart-button-bg);
	--xco-mcart-checkout-button-text: var(--xco-ccart-button-text);
	--xco-mcart-checkout-button-border: var(--xco-ccart-button-bg);
	--xco-mcart-checkout-button-hover-bg: var(--xco-ccart-button-hover-bg);
	--xco-mcart-checkout-button-hover-text: var(--xco-ccart-button-text);
	--xco-mcart-checkout-button-hover-border: var(--xco-ccart-button-hover-bg);
	position: relative;
	display: inline-block;
	width: auto;
	max-width: none;
}

.xco-ccart--menu-inline {
	display: block;
	width: 100%;
	max-width: var(--xco-mcart-panel-width);
}

.xco-mcart__trigger-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
}

.xco-mcart__trigger {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--xco-mcart-trigger-gap);
	min-height: 44px;
	border: 1px solid var(--xco-mcart-trigger-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-mcart-trigger-bg);
	color: var(--xco-mcart-trigger-text);
	font-family: var(--xco-ccart-font);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
	padding: 10px 16px;
	cursor: pointer;
	appearance: none;
}

.xco-mcart__trigger:hover,
.xco-mcart__trigger:focus-visible {
	background: var(--xco-mcart-trigger-hover-bg);
	border-color: var(--xco-mcart-trigger-hover-border);
	color: var(--xco-mcart-trigger-hover-text);
	outline: none;
}

.xco-mcart__trigger-icon,
.xco-mcart__trigger-label,
.xco-mcart__trigger-total {
	display: inline-flex;
	align-items: center;
}

.xco-mcart__trigger-icon .xco-ccart__cart-icon {
	display: block;
	width: var(--xco-mcart-trigger-icon-size);
	height: var(--xco-mcart-trigger-icon-size);
}

.xco-mcart__trigger-total {
	font-weight: 900;
	white-space: nowrap;
}

.xco-mcart__trigger-total .woocommerce-Price-amount {
	color: inherit;
}

.xco-mcart__trigger-bubble {
	position: absolute;
	top: -8px;
	right: -8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	border: 2px solid var(--xco-mcart-bubble-border);
	border-radius: 999px;
	background: var(--xco-mcart-bubble-bg);
	color: var(--xco-mcart-bubble-text);
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	padding: 0 6px;
}

.xco-mcart__panel {
	width: 100%;
	max-width: var(--xco-mcart-panel-width);
}

.xco-ccart--menu-dropdown.is-open::after {
	content: "";
	position: absolute;
	top: 100%;
	right: 0;
	z-index: 9998;
	width: min(var(--xco-mcart-panel-width), calc(100vw - 32px));
	height: var(--xco-mcart-dropdown-offset);
	pointer-events: auto;
}

.xco-ccart--menu-dropdown .xco-mcart__panel {
	position: absolute;
	top: calc(100% + var(--xco-mcart-dropdown-offset));
	right: 0;
	z-index: 9999;
	width: min(var(--xco-mcart-panel-width), calc(100vw - 32px));
	max-height: var(--xco-mcart-dropdown-max-height);
	overflow-y: auto;
	overflow-x: hidden;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
	touch-action: pan-y;
	background: var(--xco-mcart-dropdown-bg);
	padding: var(--xco-mcart-dropdown-padding);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	pointer-events: none;
	transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
}

.xco-ccart--menu-dropdown.is-open .xco-mcart__panel {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	pointer-events: auto;
}

.xco-ccart--menu-off_canvas .xco-mcart__overlay {
	position: fixed;
	inset: 0;
	z-index: 9998;
	background: rgba(0, 0, 0, 0.38);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 180ms ease, visibility 180ms ease;
}

.xco-ccart--menu-off_canvas.is-open .xco-mcart__overlay {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.xco-ccart--menu-off_canvas .xco-mcart__panel {
	position: fixed;
	top: 0;
	bottom: 0;
	right: 0;
	z-index: 9999;
	width: min(var(--xco-mcart-panel-width), calc(100vw - 24px));
	max-width: min(var(--xco-mcart-panel-width), calc(100vw - 24px));
	height: 100vh;
	overflow-y: auto;
	overflow-x: hidden;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
	touch-action: pan-y;
	background: var(--xco-ccart-card-bg);
	padding: var(--xco-mcart-panel-padding);
	box-shadow: -24px 0 60px rgba(0, 0, 0, 0.18);
	transform: translateX(110%);
	transition: transform 220ms ease;
}

.xco-ccart--drawer-left.xco-ccart--menu-off_canvas .xco-mcart__panel {
	left: 0;
	right: auto;
	box-shadow: 24px 0 60px rgba(0, 0, 0, 0.18);
	transform: translateX(-110%);
}

.xco-ccart--menu-off_canvas.is-open .xco-mcart__panel {
	transform: translateX(0);
}

.xco-ccart--menu-inline .xco-mcart__panel {
	margin-top: var(--xco-mcart-dropdown-offset);
}

.xco-mcart__close {
	position: sticky;
	top: 0;
	left: 100%;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	margin: 0 0 12px auto;
	border: 1px solid var(--xco-ccart-border);
	border-radius: 999px;
	background: var(--xco-ccart-card-bg);
	color: var(--xco-ccart-text);
	font-size: 24px;
	font-weight: 400;
	line-height: 1;
	cursor: pointer;
	appearance: none;
}

.xco-mcart__close:hover,
.xco-mcart__close:focus-visible {
	border-color: var(--xco-ccart-hover-text);
	color: var(--xco-ccart-hover-text);
	outline: none;
}

.xco-mcart {
	display: grid;
	gap: var(--xco-mcart-section-gap);
	width: 100%;
}

.xco-mcart__section,
.xco-mcart__empty {
	background: var(--xco-ccart-card-bg);
	border: 1px solid var(--xco-ccart-border);
	border-radius: var(--xco-ccart-panel-radius);
	padding: 18px;
}

.xco-mcart__section--heading {
	padding-top: 16px;
	padding-bottom: 16px;
}

.xco-mcart__heading-copy {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.xco-mcart__title {
	margin: 0;
	font-size: 22px;
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.03em;
	color: var(--xco-ccart-text);
}

.xco-mcart__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 28px;
	border-radius: var(--xco-ccart-pill-radius);
	background: #f5f5f5;
	color: var(--xco-ccart-muted);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	font-variant-numeric: tabular-nums;
	line-height: 1;
	padding: 0 12px;
	white-space: nowrap;
}

.xco-mcart__section-title {
	margin: 0 0 var(--xco-mcart-section-title-margin-bottom) 0;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.01em;
	color: var(--xco-ccart-text);
}

.xco-mcart__products {
	display: grid;
	gap: var(--xco-mcart-product-list-gap);
}

.xco-mcart__product {
	display: grid;
	grid-template-columns: var(--xco-mcart-thumb-size) minmax(0, 1fr);
	gap: var(--xco-mcart-product-item-gap);
	align-items: start;
	padding-bottom: var(--xco-mcart-product-padding-bottom);
	border-bottom: 1px solid var(--xco-ccart-border-soft);
}

.xco-mcart__product:last-child {
	padding-bottom: 0;
	border-bottom: none;
}

.xco-mcart__thumb {
	display: block;
	width: var(--xco-mcart-thumb-size);
	height: var(--xco-mcart-thumb-size);
	border-radius: var(--xco-ccart-thumb-radius);
	overflow: hidden;
	background: #f5f5f5;
	text-decoration: none;
}

.xco-mcart__thumb-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.xco-mcart__product-main {
	min-width: 0;
}

.xco-mcart__product-top,
.xco-mcart__product-bottom {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 10px;
}

.xco-mcart__product-bottom {
	align-items: center;
	margin-top: 10px;
}

.xco-mcart__product-title {
	display: block;
	font-size: 14px;
	font-weight: 800;
	line-height: 1.25;
	letter-spacing: -0.02em;
	color: var(--xco-ccart-text);
	text-decoration: none;
}

.xco-mcart__product-title:hover {
	color: var(--xco-ccart-hover-text);
	text-decoration: none;
}

.xco-mcart__product-meta,
.xco-mcart__product-meta * {
	margin: 4px 0 0 0;
	padding: 0;
	font-size: 11px;
	font-weight: 500;
	line-height: 1.35;
	color: var(--xco-ccart-muted);
}

.xco-mcart__product-meta dl,
.xco-mcart__product-meta dt,
.xco-mcart__product-meta dd,
.xco-mcart__product-meta p {
	display: inline;
	margin: 0;
	padding: 0;
}

.xco-mcart__product-meta dt::after {
	content: ': ';
}

.xco-mcart__product-meta dd::after {
	content: ' ';
}

.xco-mcart__remove {
	width: 28px;
	height: 28px;
	border: none;
	background: transparent;
	color: var(--xco-ccart-remove-icon);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	cursor: pointer;
	appearance: none;
	flex: 0 0 auto;
}

.xco-mcart__remove:hover {
	color: var(--xco-ccart-remove-icon-hover);
}

.xco-mcart__remove .xco-ccart__trash-icon {
	width: 16px;
	height: 16px;
}

.xco-mcart__qty {
	display: inline-grid;
	grid-template-columns: 28px minmax(54px, auto) 28px;
	align-items: center;
	justify-content: center;
	height: 30px;
	border: 1px solid var(--xco-ccart-qty-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-qty-bg);
	overflow: hidden;
}

.xco-mcart__qty-btn {
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	color: var(--xco-ccart-qty-text);
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	appearance: none;
}

.xco-mcart__qty-btn:disabled {
	cursor: not-allowed;
	opacity: 0.25;
}

.xco-mcart__qty-input {
	width: 54px;
	min-width: 54px;
	max-width: none;
	height: 28px;
	border: 0 !important;
	box-shadow: none !important;
	outline: 0 !important;
	background: transparent !important;
	text-align: center;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	font-variant-numeric: tabular-nums;
	color: var(--xco-ccart-qty-text);
	padding: 0;
	appearance: textfield;
}

.xco-mcart__qty-input:focus,
.xco-mcart__qty-input:focus-visible {
	border: 0 !important;
	box-shadow: none !important;
	outline: 0 !important;
}

.xco-mcart__qty-input::-webkit-outer-spin-button,
.xco-mcart__qty-input::-webkit-inner-spin-button {
	margin: 0;
	appearance: none;
}

.xco-mcart__line-total {
	font-size: 13px;
	font-weight: 900;
	line-height: 1.2;
	color: var(--xco-ccart-text);
	white-space: nowrap;
}

.xco-mcart__coupon-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: var(--xco-mcart-coupon-gap);
}

.xco-mcart__coupon-input {
	height: 40px;
}

.xco-mcart__coupon-button {
	height: 40px;
	min-width: 74px;
}

.xco-mcart__applied-coupons {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.xco-mcart__coupon-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	height: 28px;
	border: 1px solid var(--xco-ccart-border);
	border-radius: var(--xco-ccart-pill-radius);
	background: var(--xco-ccart-secondary-button-bg);
	color: var(--xco-ccart-secondary-button-text);
	font-size: 11px;
	font-weight: 800;
	padding: 0 10px;
	cursor: pointer;
	appearance: none;
}

.xco-mcart__benefits-list,
.xco-mcart__coupon-about-list {
	display: grid;
	gap: 10px;
}

.xco-mcart__benefit-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px 14px;
	align-items: start;
	font-size: 13px;
	line-height: 1.3;
	color: var(--xco-ccart-text);
}

.xco-mcart__benefit-label {
	font-weight: 600;
	color: var(--xco-ccart-text);
}

.xco-mcart__benefit-value {
	font-weight: 900;
	text-align: right;
	white-space: nowrap;
	color: var(--xco-ccart-text);
}

.xco-mcart__benefit-value--free {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
}

.xco-mcart__benefit-value--free del {
	color: var(--xco-ccart-muted);
	font-weight: 700;
}

.xco-mcart__benefit-value--free strong {
	color: var(--xco-mcart-green);
	font-weight: 900;
}

.xco-mcart__benefit-note {
	grid-column: 1 / -1;
	margin-top: -4px;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.4;
	color: var(--xco-ccart-muted);
}

.xco-mcart__coupon-about-empty {
	margin: 0;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.5;
	color: var(--xco-ccart-muted);
}

.xco-mcart__coupon-about-item {
	display: grid;
	gap: 4px;
	padding: 10px 12px;
	border: 1px solid var(--xco-ccart-border-soft);
	border-radius: 14px;
	background: #fafafa;
}

.xco-mcart__coupon-about-code {
	font-size: 11px;
	font-weight: 900;
	line-height: 1.2;
	letter-spacing: 0.04em;
	color: var(--xco-ccart-text);
}

.xco-mcart__coupon-about-description {
	font-size: 12px;
	font-weight: 600;
	line-height: 1.45;
	color: var(--xco-ccart-muted);
}

.xco-mcart__actions {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--xco-mcart-actions-gap);
}

.xco-mcart__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: var(--xco-mcart-button-min-height);
	border-radius: var(--xco-mcart-button-radius);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
	text-decoration: none;
	padding: 0 18px;
	cursor: pointer;
}

.xco-mcart__button--primary {
	border: 1px solid var(--xco-mcart-checkout-button-border);
	background: var(--xco-mcart-checkout-button-bg);
	color: var(--xco-mcart-checkout-button-text);
}

.xco-mcart__button--primary:hover {
	background: var(--xco-mcart-checkout-button-hover-bg);
	border-color: var(--xco-mcart-checkout-button-hover-border);
	color: var(--xco-mcart-checkout-button-hover-text);
	text-decoration: none;
}

.xco-mcart__button--secondary {
	border: 1px solid var(--xco-mcart-cart-button-border);
	background: var(--xco-mcart-cart-button-bg);
	color: var(--xco-mcart-cart-button-text);
}

.xco-mcart__button--secondary:hover {
	background: var(--xco-mcart-cart-button-hover-bg);
	border-color: var(--xco-mcart-cart-button-hover-border);
	color: var(--xco-mcart-cart-button-hover-text);
	text-decoration: none;
}

.xco-mcart__empty {
	text-align: center;
}

.xco-mcart__empty-title {
	margin: 0 0 8px 0;
	font-size: 20px;
	font-weight: 900;
	line-height: 1.15;
	color: var(--xco-ccart-text);
}

.xco-mcart__empty-text {
	margin: 0 0 18px 0;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
	color: var(--xco-ccart-muted);
}


.xco-mcart__remove:hover,
.xco-mcart__remove:focus-visible,
.xco-ccart__remove-btn:hover,
.xco-ccart__remove-btn:focus-visible,
.xco-mcart__coupon-pill:hover,
.xco-mcart__coupon-pill:focus-visible {
	color: var(--xco-ccart-hover-text);
	border-color: var(--xco-ccart-hover-text);
	outline: none;
}

.xco-mcart__coupon-button:hover,
.xco-mcart__coupon-button:focus-visible {
	border-color: var(--xco-ccart-hover-text);
	color: var(--xco-ccart-hover-text);
	outline: none;
}

.xco-ccart--menu a:hover,
.xco-ccart--menu a:focus-visible {
	color: var(--xco-ccart-hover-text);
}

.xco-mcart__button--primary:hover,
.xco-mcart__button--primary:focus-visible {
	color: var(--xco-mcart-checkout-button-hover-text);
}

.xco-mcart__button--secondary:hover,
.xco-mcart__button--secondary:focus-visible {
	color: var(--xco-mcart-cart-button-hover-text);
}

@media (max-width: 420px) {
	.xco-mcart__coupon-form,
	.xco-mcart__actions {
		grid-template-columns: 1fr;
	}

	.xco-mcart__product {
		grid-template-columns: 56px minmax(0, 1fr);
	}

	.xco-mcart__thumb {
		width: 56px;
		height: 56px;
	}
}
