/* =========================================================
   VIVI WooCommerce Cart Shortcode Page
   Version: 0.9.687
   Scope: /cart/ VIVI Lite Pages shell only
   Rule: follow VIVI website foundation tokens. WooCommerce handles cart logic.
========================================================= */

/* =========================================================
   1. Page foundation
   Only use existing VIVI base tokens for color, type, radius, spacing and shadow.
========================================================= */
body.vivi-cart-shell-page {
	--vivi-cart-shell-max: var(--vivi-container-wide, 1120px);
	--vivi-cart-item-image: 76px;
	margin: 0;
	background: var(--vivi-color-bg);
	color: var(--vivi-color-text);
	font-family: var(--vivi-font-main);
}

body.vivi-cart-shell-page *,
body.vivi-cart-shell-page *::before,
body.vivi-cart-shell-page *::after {
	box-sizing: border-box;
}

/* Cart page uses standard VIVI Lite Pages Header / Footer from vivi-base.css.
   Do not redefine header grid, logo, nav, mobile controls or footer here. */

/* =========================================================
   2. Page shell
========================================================= */
body.vivi-cart-shell-page .vivi-cart-shell-main {
	width: min(var(--vivi-cart-shell-max), calc(100vw - (var(--vivi-space-xl) * 2)));
	margin: 0 auto;
	padding: calc(var(--vivi-page-main-padding-top) + 40px) 0 var(--vivi-space-xl);
}

body.admin-bar.vivi-cart-shell-page .vivi-cart-shell-main {
	padding-top: calc(var(--vivi-page-main-padding-top) + 32px + 40px);
}

body.vivi-cart-shell-page .vivi-cart-shell-hero {
	display: grid;
	gap: var(--vivi-space-xs);
	margin: 0 0 var(--vivi-space-lg);
}

body.vivi-cart-shell-page .vivi-section-kicker {
	margin: 0;
	color: var(--vivi-color-orange);
	font-size: var(--vivi-fs-xs);
	font-weight: var(--vivi-fw-bold);
	letter-spacing: .12em;
	text-transform: uppercase;
}

body.vivi-cart-shell-page .vivi-cart-shell-hero h1 {
	margin: 0;
	color: var(--vivi-color-heading);
	font-size: var(--vivi-fs-h2);
	font-weight: var(--vivi-fw-bold);
	line-height: var(--vivi-lh-compact);
}

body.vivi-cart-shell-page .vivi-cart-shell-hero p {
	max-width: 720px;
	margin: 0;
	color: var(--vivi-color-text);
	font-size: var(--vivi-fs-body);
	font-weight: var(--vivi-fw-regular);
	line-height: var(--vivi-lh-body);
}

body.vivi-cart-shell-page .vivi-cart-shell-card {
	overflow: hidden;
	border: 1px solid var(--vivi-color-border);
	border-radius: var(--vivi-radius-lg);
	background: var(--vivi-color-card);
	box-shadow: var(--vivi-shadow-card);
}

/* =========================================================
   3. WooCommerce shortcode hard reset
   The shortcode stays native. CSS only changes visual structure.
========================================================= */
body.vivi-cart-shell-page .woocommerce,
body.vivi-cart-shell-page .woocommerce-cart-form,
body.vivi-cart-shell-page .woocommerce-cart-form__contents,
body.vivi-cart-shell-page .cart-collaterals {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
}

body.vivi-cart-shell-page .woocommerce::before,
body.vivi-cart-shell-page .woocommerce::after,
body.vivi-cart-shell-page .cart-collaterals::before,
body.vivi-cart-shell-page .cart-collaterals::after {
	display: none !important;
	content: none !important;
}

body.vivi-cart-shell-page .woocommerce-notices-wrapper {
	margin: 0 0 var(--vivi-space-md) !important;
}

body.vivi-cart-shell-page .woocommerce-message,
body.vivi-cart-shell-page .woocommerce-info,
body.vivi-cart-shell-page .woocommerce-error {
	margin: 0 0 var(--vivi-space-md) !important;
	padding: var(--vivi-space-sm) var(--vivi-space-md) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-small) !important;
	font-weight: var(--vivi-fw-regular) !important;
	line-height: var(--vivi-lh-body) !important;
}

/* =========================================================
   4. Convert Woo table into VIVI cart item rows
========================================================= */
body.vivi-cart-shell-page table.cart,
body.vivi-cart-shell-page table.cart tbody,
body.vivi-cart-shell-page table.cart tr,
body.vivi-cart-shell-page table.cart td,
body.vivi-cart-shell-page table.shop_table {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	border-collapse: collapse !important;
	border-spacing: 0 !important;
	background: transparent !important;
}

body.vivi-cart-shell-page table.cart thead {
	display: none !important;
}

body.vivi-cart-shell-page table.cart tr.cart_item {
	position: relative !important;
	display: grid !important;
	grid-template-columns: 36px var(--vivi-cart-item-image) minmax(0, 1fr) 120px 140px 120px !important;
	align-items: center !important;
	gap: var(--vivi-space-md) !important;
	padding: var(--vivi-space-md) var(--vivi-space-lg) !important;
	border-bottom: 1px solid var(--vivi-color-border) !important;
	background: var(--vivi-color-card) !important;
}

body.vivi-cart-shell-page table.cart tr.cart_item td {
	min-width: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
}

/* Remove */
body.vivi-cart-shell-page table.cart td.product-remove {
	grid-column: 1 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 36px !important;
}

body.vivi-cart-shell-page table.cart a.remove {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 28px !important;
	height: 28px !important;
	margin: 0 !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: 999px !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-text-light) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 1 !important;
	text-decoration: none !important;
}

body.vivi-cart-shell-page table.cart a.remove:hover {
	border-color: var(--vivi-color-orange) !important;
	background: var(--vivi-color-orange) !important;
	color: var(--vivi-color-text-inverse) !important;
}

/* Thumbnail */
body.vivi-cart-shell-page table.cart td.product-thumbnail {
	grid-column: 2 !important;
	width: var(--vivi-cart-item-image) !important;
}

body.vivi-cart-shell-page table.cart td.product-thumbnail::before {
	display: none !important;
	content: none !important;
}

body.vivi-cart-shell-page table.cart td.product-thumbnail img {
	display: block !important;
	width: var(--vivi-cart-item-image) !important;
	height: var(--vivi-cart-item-image) !important;
	object-fit: cover !important;
	border-radius: var(--vivi-radius-sm) !important;
	background: var(--vivi-color-bg-soft) !important;
}

/* Name */
body.vivi-cart-shell-page table.cart td.product-name {
	grid-column: 3 !important;
}

body.vivi-cart-shell-page table.cart td.product-name a {
	display: block !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: var(--vivi-lh-body) !important;
	text-decoration: none !important;
}

body.vivi-cart-shell-page table.cart td.product-name a:hover {
	color: var(--vivi-color-orange) !important;
}

/* Price / subtotal */
body.vivi-cart-shell-page table.cart td.product-price,
body.vivi-cart-shell-page table.cart td.product-subtotal {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-start !important;
	color: var(--vivi-color-orange) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: var(--vivi-lh-compact) !important;
	white-space: nowrap !important;
}

body.vivi-cart-shell-page table.cart td.product-price {
	grid-column: 4 !important;
}

body.vivi-cart-shell-page table.cart td.product-subtotal {
	grid-column: 6 !important;
	justify-content: flex-end !important;
}

/* Quantity */
body.vivi-cart-shell-page table.cart td.product-quantity {
	grid-column: 5 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	white-space: nowrap !important;
}

body.vivi-cart-shell-page table.cart td.product-quantity label,
body.vivi-cart-shell-page table.cart td.product-quantity .screen-reader-text,
body.vivi-cart-shell-page table.cart td.product-quantity [class*="screen-reader"] {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	margin: -1px !important;
	padding: 0 !important;
	overflow: hidden !important;
	clip: rect(0 0 0 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

body.vivi-cart-shell-page .quantity {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: var(--vivi-space-xs) !important;
	min-width: 0 !important;
	margin: 0 !important;
}

body.vivi-cart-shell-page .quantity input.qty {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 58px !important;
	height: 40px !important;
	min-height: 40px !important;
	margin: 0 !important;
	padding: 0 var(--vivi-space-xs) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-sm) !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 40px !important;
	text-align: center !important;
}

/* Keep Woo / theme quantity buttons inline if they exist */
body.vivi-cart-shell-page .quantity .minus,
body.vivi-cart-shell-page .quantity .plus,
body.vivi-cart-shell-page .quantity button.minus,
body.vivi-cart-shell-page .quantity button.plus {
	position: static !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 28px !important;
	height: 28px !important;
	min-width: 28px !important;
	min-height: 28px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-body-lg) !important;
	line-height: 1 !important;
}

/* =========================================================
   5. Actions row
========================================================= */
body.vivi-cart-shell-page table.cart tr:last-child {
	display: block !important;
	width: 100% !important;
	background: color-mix(in srgb, var(--vivi-color-bg-soft) 56%, transparent) !important;
}

body.vivi-cart-shell-page table.cart tr:last-child td.actions,
body.vivi-cart-shell-page table.cart td.actions {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: var(--vivi-space-md) !important;
	width: 100% !important;
	padding: var(--vivi-space-md) var(--vivi-space-lg) !important;
	border: 0 !important;
	background: transparent !important;
}

body.vivi-cart-shell-page table.cart td.actions .coupon {
	display: flex !important;
	align-items: center !important;
	gap: var(--vivi-space-xs) !important;
	float: none !important;
	margin: 0 !important;
}

body.vivi-cart-shell-page table.cart td.actions .coupon label {
	display: none !important;
}

body.vivi-cart-shell-page table.cart td.actions input.input-text {
	min-height: 42px !important;
	margin: 0 !important;
	padding: 0 var(--vivi-space-sm) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-sm) !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-small) !important;
}

body.vivi-cart-shell-page button.button,
body.vivi-cart-shell-page a.button,
body.vivi-cart-shell-page input.button,
body.vivi-cart-shell-page .wc-proceed-to-checkout a.checkout-button {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: var(--vivi-button-height, 42px) !important;
	margin: 0 !important;
	padding: 0 var(--vivi-button-padding-x, 22px) !important;
	border: 1px solid var(--vivi-color-black) !important;
	border-radius: var(--vivi-radius-sm) !important;
	background: var(--vivi-color-black) !important;
	color: var(--vivi-color-text-inverse) !important;
	font-size: var(--vivi-fs-small) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 1 !important;
	text-decoration: none !important;
	cursor: pointer !important;
}

body.vivi-cart-shell-page button.button:hover,
body.vivi-cart-shell-page a.button:hover,
body.vivi-cart-shell-page input.button:hover,
body.vivi-cart-shell-page .wc-proceed-to-checkout a.checkout-button:hover {
	border-color: var(--vivi-color-orange) !important;
	background: var(--vivi-color-orange) !important;
	color: var(--vivi-color-text-inverse) !important;
}

body.vivi-cart-shell-page table.cart td.actions button[name="update_cart"],
body.vivi-cart-shell-page table.cart td.actions .button[name="update_cart"] {
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-heading) !important;
	border-color: var(--vivi-color-border) !important;
}

/* =========================================================
   6. Totals
========================================================= */
body.vivi-cart-shell-page .cart-collaterals {
	display: flex !important;
	justify-content: flex-end !important;
	padding: var(--vivi-space-lg) !important;
	border-top: 1px solid var(--vivi-color-border) !important;
	background: color-mix(in srgb, var(--vivi-color-bg-soft) 56%, transparent) !important;
}

body.vivi-cart-shell-page .cart-collaterals .cart_totals {
	float: none !important;
	width: min(100%, 380px) !important;
	margin: 0 !important;
	padding: var(--vivi-space-md) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-card) !important;
	box-shadow: none !important;
}

body.vivi-cart-shell-page .cart_totals h2 {
	margin: 0 0 var(--vivi-space-md) !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-h3) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: var(--vivi-lh-compact) !important;
}

body.vivi-cart-shell-page .cart_totals table.shop_table,
body.vivi-cart-shell-page .cart_totals table.shop_table tbody,
body.vivi-cart-shell-page .cart_totals table.shop_table tr,
body.vivi-cart-shell-page .cart_totals table.shop_table th,
body.vivi-cart-shell-page .cart_totals table.shop_table td {
	display: revert !important;
	width: auto !important;
	margin: 0 !important;
	border-collapse: collapse !important;
}

body.vivi-cart-shell-page .cart_totals table.shop_table {
	width: 100% !important;
	margin: 0 0 var(--vivi-space-md) !important;
	border: 0 !important;
	background: transparent !important;
}

body.vivi-cart-shell-page .cart_totals table.shop_table th,
body.vivi-cart-shell-page .cart_totals table.shop_table td {
	padding: var(--vivi-space-sm) 0 !important;
	border: 0 !important;
	border-bottom: 1px solid var(--vivi-color-border) !important;
	background: transparent !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-small) !important;
	text-align: left !important;
}

body.vivi-cart-shell-page .cart_totals table.shop_table td {
	text-align: right !important;
	color: var(--vivi-color-heading) !important;
	font-weight: var(--vivi-fw-bold) !important;
}

body.vivi-cart-shell-page .cart_totals .order-total th,
body.vivi-cart-shell-page .cart_totals .order-total td,
body.vivi-cart-shell-page .cart_totals .order-total .amount {
	color: var(--vivi-color-orange) !important;
	font-size: var(--vivi-fs-body-lg) !important;
	font-weight: var(--vivi-fw-bold) !important;
}

body.vivi-cart-shell-page .wc-proceed-to-checkout {
	margin: var(--vivi-space-md) 0 0 !important;
	padding: 0 !important;
}

body.vivi-cart-shell-page .wc-proceed-to-checkout a.checkout-button {
	width: 100% !important;
	min-height: 48px !important;
	font-size: var(--vivi-fs-body) !important;
}

/* =========================================================
   7. Empty cart
========================================================= */
body.vivi-cart-shell-page .cart-empty,
body.vivi-cart-shell-page .return-to-shop {
	max-width: 760px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	text-align: center !important;
}

body.vivi-cart-shell-page .cart-empty {
	margin: 0 !important;
	padding: var(--vivi-space-xl) var(--vivi-space-md) !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-body) !important;
}

/* =========================================================
   8. Mobile
========================================================= */
@media (max-width: 767px) {
	body.vivi-cart-shell-page {
		--vivi-cart-item-image: 78px;
	}

	body.vivi-cart-shell-page .vivi-cart-shell-main {
		width: min(100%, calc(100vw - (var(--vivi-space-sm) * 2))) !important;
		padding: calc(var(--vivi-header-height-mobile) + 40px) 0 calc(var(--vivi-mobile-bottom-nav-height) + var(--vivi-space-lg)) !important;
	}

	body.admin-bar.vivi-cart-shell-page .vivi-cart-shell-main {
		padding-top: calc(var(--vivi-header-height-mobile) + 40px + 32px) !important;
	}

	body.vivi-cart-shell-page .vivi-cart-shell-hero {
		margin-bottom: var(--vivi-space-md) !important;
	}

	body.vivi-cart-shell-page .vivi-cart-shell-hero h1 {
		font-size: var(--vivi-fs-h3) !important;
	}

	body.vivi-cart-shell-page .vivi-cart-shell-hero p {
		font-size: var(--vivi-fs-small) !important;
	}

	body.vivi-cart-shell-page .vivi-cart-shell-card {
		border-radius: var(--vivi-radius-md) !important;
	}

	body.vivi-cart-shell-page table.cart tr.cart_item {
		grid-template-columns: 28px var(--vivi-cart-item-image) minmax(0, 1fr) !important;
		grid-template-areas:
			"remove thumb name"
			"remove thumb price"
			"remove thumb qty"
			"remove thumb subtotal" !important;
		gap: var(--vivi-space-xs) var(--vivi-space-sm) !important;
		padding: var(--vivi-space-sm) !important;
	}

	body.vivi-cart-shell-page table.cart td.product-remove {
		grid-column: auto !important;
		grid-area: remove !important;
		align-self: start !important;
		width: 28px !important;
		padding-top: 2px !important;
	}

	body.vivi-cart-shell-page table.cart td.product-thumbnail {
		grid-column: auto !important;
		grid-area: thumb !important;
		width: var(--vivi-cart-item-image) !important;
	}

	body.vivi-cart-shell-page table.cart td.product-name {
		grid-column: auto !important;
		grid-area: name !important;
	}

	body.vivi-cart-shell-page table.cart td.product-name a {
		font-size: var(--vivi-fs-small) !important;
		line-height: var(--vivi-lh-body) !important;
	}

	body.vivi-cart-shell-page table.cart td.product-price,
	body.vivi-cart-shell-page table.cart td.product-quantity,
	body.vivi-cart-shell-page table.cart td.product-subtotal {
		display: flex !important;
		align-items: center !important;
		justify-content: space-between !important;
		gap: var(--vivi-space-sm) !important;
		font-size: var(--vivi-fs-small) !important;
	}

	body.vivi-cart-shell-page table.cart td.product-price {
		grid-column: auto !important;
		grid-area: price !important;
	}

	body.vivi-cart-shell-page table.cart td.product-quantity {
		grid-column: auto !important;
		grid-area: qty !important;
		justify-content: space-between !important;
	}

	body.vivi-cart-shell-page table.cart td.product-subtotal {
		grid-column: auto !important;
		grid-area: subtotal !important;
		font-size: var(--vivi-fs-body) !important;
	}

	body.vivi-cart-shell-page table.cart td.product-price::before,
	body.vivi-cart-shell-page table.cart td.product-quantity::before,
	body.vivi-cart-shell-page table.cart td.product-subtotal::before {
		content: attr(data-title) !important;
		color: var(--vivi-color-text-light) !important;
		font-size: var(--vivi-fs-xs) !important;
		font-weight: var(--vivi-fw-bold) !important;
	}

	body.vivi-cart-shell-page .quantity input.qty {
		width: 54px !important;
		height: 36px !important;
		min-height: 36px !important;
		font-size: var(--vivi-fs-small) !important;
		line-height: 36px !important;
	}

	body.vivi-cart-shell-page table.cart tr:last-child,
	body.vivi-cart-shell-page table.cart tr:last-child td.actions {
		display: block !important;
		padding: var(--vivi-space-sm) !important;
		background: color-mix(in srgb, var(--vivi-color-bg-soft) 56%, transparent) !important;
	}

	body.vivi-cart-shell-page table.cart td.actions .coupon {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: var(--vivi-space-xs) !important;
		margin-bottom: var(--vivi-space-xs) !important;
	}

	body.vivi-cart-shell-page table.cart td.actions input.input-text,
	body.vivi-cart-shell-page table.cart td.actions .button,
	body.vivi-cart-shell-page table.cart td.actions button.button {
		width: 100% !important;
	}

	body.vivi-cart-shell-page .cart-collaterals {
		display: block !important;
		padding: var(--vivi-space-sm) !important;
	}

	body.vivi-cart-shell-page .cart-collaterals .cart_totals {
		width: 100% !important;
		padding: var(--vivi-space-md) !important;
	}

	body.vivi-cart-shell-page .cart_totals h2 {
		font-size: var(--vivi-fs-body-lg) !important;
	}

	body.vivi-cart-shell-page .wc-proceed-to-checkout a.checkout-button {
		min-height: 46px !important;
		font-size: var(--vivi-fs-small) !important;
	}
}

/* v0.9.609 Cart action alignment: keep WooCommerce native button, move update cart to the right. */
body.vivi-cart-shell-page table.cart tr:last-child td.actions,
body.vivi-cart-shell-page table.cart td.actions {
	justify-content: flex-end !important;
}

body.vivi-cart-shell-page table.cart td.actions .coupon {
	margin-right: auto !important;
}

body.vivi-cart-shell-page table.cart td.actions button[name="update_cart"],
body.vivi-cart-shell-page table.cart td.actions .button[name="update_cart"] {
	margin-left: auto !important;
}

/* v0.9.610 Cart quantity: hide theme plus/minus controls, keep WooCommerce native quantity input. */
body.vivi-cart-shell-page .quantity .minus,
body.vivi-cart-shell-page .quantity .plus,
body.vivi-cart-shell-page .quantity button.minus,
body.vivi-cart-shell-page .quantity button.plus,
body.vivi-cart-shell-page .quantity input.minus,
body.vivi-cart-shell-page .quantity input.plus,
body.vivi-cart-shell-page .quantity [class*="minus"],
body.vivi-cart-shell-page .quantity [class*="plus"] {
	display: none !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

body.vivi-cart-shell-page .quantity {
	gap: 0 !important;
	min-width: 0 !important;
}

body.vivi-cart-shell-page .quantity input.qty {
	margin: 0 !important;
}

/* v0.9.611 Cart quantity: hide theme/BuddyBoss injected quantity steppers, keep WooCommerce input.qty. */
body.vivi-cart-shell-page .quantity .bs-quantity,
body.vivi-cart-shell-page .quantity .qty-nav,
body.vivi-cart-shell-page .quantity .quantity-button,
body.vivi-cart-shell-page .quantity .quantity-up,
body.vivi-cart-shell-page .quantity .quantity-down,
body.vivi-cart-shell-page .quantity div[class*="quantity-up"],
body.vivi-cart-shell-page .quantity div[class*="quantity-down"],
body.vivi-cart-shell-page .quantity div[class*="qty-nav"] {
	display: none !important;
	visibility: hidden !important;
	width: 0 !important;
	height: 0 !important;
	min-width: 0 !important;
	min-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	pointer-events: none !important;
}

body.vivi-cart-shell-page .quantity,
body.vivi-cart-shell-page .bs-quantity {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0 !important;
}

body.vivi-cart-shell-page .quantity input.qty {
	display: inline-flex !important;
	position: static !important;
	margin: 0 !important;
}

/* v0.9.612 Cart quantity: block BuddyBoss/theme-injected quantity wrappers; VIVI template outputs only native input.qty. */
body.vivi-cart-shell-page .product-quantity .bs-quantity,
body.vivi-cart-shell-page .product-quantity .qty-nav,
body.vivi-cart-shell-page .product-quantity .quantity-button,
body.vivi-cart-shell-page .product-quantity .quantity-up,
body.vivi-cart-shell-page .product-quantity .quantity-down {
	display: none !important;
	visibility: hidden !important;
	width: 0 !important;
	height: 0 !important;
	min-width: 0 !important;
	min-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	pointer-events: none !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native input.qty {
	margin: 0 !important;
}

/* v0.9.614 Cart quantity redesign: simple, clean, VIVI-styled stepper. */
body.vivi-cart-shell-page .vivi-cart-quantity-native {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0 !important;
	min-width: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-sm) !important;
	background: var(--vivi-color-card) !important;
	overflow: hidden !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native .vivi-cart-qty-button {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 34px !important;
	height: 38px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-body-lg) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 1 !important;
	cursor: pointer !important;
	box-shadow: none !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native .vivi-cart-qty-button:hover {
	background: var(--vivi-color-bg-soft) !important;
	color: var(--vivi-color-orange) !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native .vivi-cart-qty-button:focus-visible {
	outline: 0 !important;
	background: var(--vivi-color-bg-soft) !important;
	color: var(--vivi-color-orange) !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native .vivi-cart-qty-button-dec {
	border-right: 1px solid var(--vivi-color-border) !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native .vivi-cart-qty-button-inc {
	border-left: 1px solid var(--vivi-color-border) !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native input.qty {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 52px !important;
	height: 38px !important;
	min-height: 38px !important;
	margin: 0 !important;
	padding: 0 6px !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 38px !important;
	text-align: center !important;
	box-shadow: none !important;
	appearance: textfield !important;
	-moz-appearance: textfield !important;
}

body.vivi-cart-shell-page .vivi-cart-quantity-native input.qty::-webkit-outer-spin-button,
body.vivi-cart-shell-page .vivi-cart-quantity-native input.qty::-webkit-inner-spin-button {
	-webkit-appearance: none !important;
	margin: 0 !important;
}

@media (max-width: 767px) {
	body.vivi-cart-shell-page .vivi-cart-quantity-native .vivi-cart-qty-button {
		width: 32px !important;
		height: 36px !important;
		font-size: var(--vivi-fs-body) !important;
	}

	body.vivi-cart-shell-page .vivi-cart-quantity-native input.qty {
		width: 48px !important;
		height: 36px !important;
		min-height: 36px !important;
		line-height: 36px !important;
		font-size: var(--vivi-fs-small) !important;
	}
}

/* v0.9.615 Cart layout polish: align product information, refine borders, and style WooCommerce notices with VIVI foundation tokens. */

/* Make the cart card feel like one controlled VIVI component. */
body.vivi-cart-shell-page .vivi-cart-shell-card {
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-lg) !important;
	background: var(--vivi-color-card) !important;
	box-shadow: var(--vivi-shadow-card) !important;
	overflow: hidden !important;
}

/* Notice / warning area: place it as a proper VIVI alert, not as a loose WooCommerce row. */
body.vivi-cart-shell-page .woocommerce-notices-wrapper {
	margin: 0 !important;
	padding: var(--vivi-space-md) var(--vivi-space-lg) 0 !important;
	background: var(--vivi-color-card) !important;
}

body.vivi-cart-shell-page .woocommerce-notices-wrapper:empty {
	display: none !important;
}

body.vivi-cart-shell-page .woocommerce-message,
body.vivi-cart-shell-page .woocommerce-info,
body.vivi-cart-shell-page .woocommerce-error {
	position: relative !important;
	display: flex !important;
	align-items: center !important;
	gap: var(--vivi-space-sm) !important;
	width: 100% !important;
	margin: 0 0 var(--vivi-space-md) !important;
	padding: var(--vivi-space-sm) var(--vivi-space-md) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-bg-soft) !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-small) !important;
	font-weight: var(--vivi-fw-regular) !important;
	line-height: var(--vivi-lh-body) !important;
	box-shadow: none !important;
}

body.vivi-cart-shell-page .woocommerce-message::before,
body.vivi-cart-shell-page .woocommerce-info::before,
body.vivi-cart-shell-page .woocommerce-error::before {
	content: "" !important;
	display: inline-flex !important;
	width: 8px !important;
	height: 8px !important;
	flex: 0 0 8px !important;
	border-radius: 999px !important;
	background: var(--vivi-color-orange) !important;
}

body.vivi-cart-shell-page .woocommerce-message a,
body.vivi-cart-shell-page .woocommerce-info a,
body.vivi-cart-shell-page .woocommerce-error a {
	color: var(--vivi-color-orange) !important;
	font-weight: var(--vivi-fw-bold) !important;
	text-decoration: none !important;
}

body.vivi-cart-shell-page .woocommerce-message a:hover,
body.vivi-cart-shell-page .woocommerce-info a:hover,
body.vivi-cart-shell-page .woocommerce-error a:hover {
	text-decoration: underline !important;
}

/* Product list layout: reduce empty gaps and align the right-side data cleanly. */
body.vivi-cart-shell-page table.cart tr.cart_item {
	grid-template-columns: 36px var(--vivi-cart-item-image) minmax(220px, 1fr) minmax(104px, .36fr) minmax(124px, .34fr) minmax(104px, .36fr) !important;
	gap: var(--vivi-space-md) !important;
	padding: var(--vivi-space-md) var(--vivi-space-lg) !important;
	min-height: calc(var(--vivi-cart-item-image) + (var(--vivi-space-md) * 2)) !important;
	border-bottom: 1px solid var(--vivi-color-border) !important;
	background: var(--vivi-color-card) !important;
}

body.vivi-cart-shell-page table.cart tr.cart_item:hover {
	background: color-mix(in srgb, var(--vivi-color-bg-soft) 42%, var(--vivi-color-card)) !important;
}

body.vivi-cart-shell-page table.cart td.product-remove {
	justify-content: center !important;
}

body.vivi-cart-shell-page table.cart td.product-thumbnail img {
	width: var(--vivi-cart-item-image) !important;
	height: var(--vivi-cart-item-image) !important;
	border-radius: var(--vivi-radius-sm) !important;
}

body.vivi-cart-shell-page table.cart td.product-name {
	align-self: center !important;
}

body.vivi-cart-shell-page table.cart td.product-name a {
	max-width: 100% !important;
	color: var(--vivi-color-heading) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: var(--vivi-lh-body) !important;
}

body.vivi-cart-shell-page table.cart td.product-price,
body.vivi-cart-shell-page table.cart td.product-quantity,
body.vivi-cart-shell-page table.cart td.product-subtotal {
	align-self: center !important;
}

body.vivi-cart-shell-page table.cart td.product-price {
	justify-content: flex-start !important;
}

body.vivi-cart-shell-page table.cart td.product-quantity {
	justify-content: center !important;
}

body.vivi-cart-shell-page table.cart td.product-subtotal {
	justify-content: flex-end !important;
}

/* Action row border and spacing. */
body.vivi-cart-shell-page table.cart tr:last-child {
	border-bottom: 1px solid var(--vivi-color-border) !important;
	background: var(--vivi-color-bg-soft) !important;
}

body.vivi-cart-shell-page table.cart tr:last-child td.actions,
body.vivi-cart-shell-page table.cart td.actions {
	min-height: 72px !important;
	padding: var(--vivi-space-md) var(--vivi-space-lg) !important;
	border-top: 0 !important;
	background: transparent !important;
}

/* Totals area: stable card position, cleaner frame. */
body.vivi-cart-shell-page .cart-collaterals {
	padding: var(--vivi-space-lg) !important;
	border-top: 0 !important;
	background: var(--vivi-color-bg-soft) !important;
}

body.vivi-cart-shell-page .cart-collaterals .cart_totals {
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-card) !important;
	box-shadow: none !important;
}

body.vivi-cart-shell-page .cart_totals table.shop_table th,
body.vivi-cart-shell-page .cart_totals table.shop_table td {
	border-bottom: 1px solid var(--vivi-color-border) !important;
}

/* Empty cart: use one centered VIVI notice block instead of a loose WooCommerce box. */
body.vivi-cart-shell-page .cart-empty {
	width: min(100%, 720px) !important;
	margin: var(--vivi-space-lg) auto !important;
	padding: var(--vivi-space-lg) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-body) !important;
	text-align: center !important;
}

/* Mobile: keep the same visual language but switch item rows to compact cards. */
@media (max-width: 767px) {
	body.vivi-cart-shell-page .woocommerce-notices-wrapper {
		padding: var(--vivi-space-sm) var(--vivi-space-sm) 0 !important;
	}

	body.vivi-cart-shell-page .woocommerce-message,
	body.vivi-cart-shell-page .woocommerce-info,
	body.vivi-cart-shell-page .woocommerce-error {
		align-items: flex-start !important;
		padding: var(--vivi-space-sm) !important;
		font-size: var(--vivi-fs-small) !important;
	}

	body.vivi-cart-shell-page table.cart tr.cart_item {
		grid-template-columns: 28px var(--vivi-cart-item-image) minmax(0, 1fr) !important;
		gap: var(--vivi-space-xs) var(--vivi-space-sm) !important;
		padding: var(--vivi-space-sm) !important;
		min-height: auto !important;
	}

	body.vivi-cart-shell-page table.cart td.product-price,
	body.vivi-cart-shell-page table.cart td.product-quantity,
	body.vivi-cart-shell-page table.cart td.product-subtotal {
		justify-content: space-between !important;
	}

	body.vivi-cart-shell-page table.cart tr:last-child td.actions,
	body.vivi-cart-shell-page table.cart td.actions {
		min-height: auto !important;
		padding: var(--vivi-space-sm) !important;
	}

	body.vivi-cart-shell-page .cart-collaterals {
		padding: var(--vivi-space-sm) !important;
	}

	body.vivi-cart-shell-page .cart-empty {
		width: auto !important;
		margin: var(--vivi-space-sm) !important;
		padding: var(--vivi-space-md) !important;
	}
}

/* v0.9.616 Empty cart state: align the return-to-shop button with the empty-cart message as one VIVI empty-state block. */
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) !important;
	gap: 0 !important;
}

body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .cart-empty {
	width: min(100%, 720px) !important;
	margin: var(--vivi-space-lg) auto var(--vivi-space-sm) !important;
	padding: var(--vivi-space-lg) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-body) !important;
	font-weight: var(--vivi-fw-regular) !important;
	line-height: var(--vivi-lh-body) !important;
	text-align: center !important;
	box-shadow: none !important;
}

body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop {
	width: min(100%, 720px) !important;
	margin: 0 auto var(--vivi-space-lg) !important;
	padding: 0 !important;
	text-align: center !important;
}

body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop .button,
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop a.button,
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop a.wc-backward {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 128px !important;
	min-height: var(--vivi-button-height, 42px) !important;
	margin: 0 !important;
	padding: 0 var(--vivi-button-padding-x, 22px) !important;
	border: 1px solid var(--vivi-color-black) !important;
	border-radius: var(--vivi-radius-sm) !important;
	background: var(--vivi-color-black) !important;
	color: var(--vivi-color-text-inverse) !important;
	font-size: var(--vivi-fs-small) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 1 !important;
	text-decoration: none !important;
}

body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop .button:hover,
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop a.button:hover,
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop a.wc-backward:hover {
	border-color: var(--vivi-color-orange) !important;
	background: var(--vivi-color-orange) !important;
	color: var(--vivi-color-text-inverse) !important;
	text-decoration: none !important;
}

@media (max-width: 767px) {
	body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .cart-empty {
		width: auto !important;
		margin: var(--vivi-space-sm) var(--vivi-space-sm) var(--vivi-space-xs) !important;
		padding: var(--vivi-space-md) !important;
		font-size: var(--vivi-fs-small) !important;
	}

	body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop {
		width: auto !important;
		margin: 0 var(--vivi-space-sm) var(--vivi-space-md) !important;
	}

	body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop .button,
	body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop a.button,
	body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop a.wc-backward {
		width: 100% !important;
	}
}

/* v0.9.617 Empty cart actions: hide WooCommerce default shop button and show VIVI navigation buttons. */
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .return-to-shop {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
}

body.vivi-cart-shell-page .vivi-cart-empty-actions {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-wrap: wrap !important;
	gap: var(--vivi-space-sm) !important;
	width: min(100%, 720px) !important;
	margin: 0 auto var(--vivi-space-lg) !important;
	padding: 0 !important;
	text-align: center !important;
}

body.vivi-cart-shell-page .vivi-cart-empty-action {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 140px !important;
	min-height: var(--vivi-button-height, 42px) !important;
	margin: 0 !important;
	padding: 0 var(--vivi-button-padding-x, 22px) !important;
	border-radius: var(--vivi-radius-sm) !important;
	font-size: var(--vivi-fs-small) !important;
	font-weight: var(--vivi-fw-bold) !important;
	line-height: 1 !important;
	text-decoration: none !important;
}

body.vivi-cart-shell-page .vivi-cart-empty-action-primary {
	border: 1px solid var(--vivi-color-black) !important;
	background: var(--vivi-color-black) !important;
	color: var(--vivi-color-text-inverse) !important;
}

body.vivi-cart-shell-page .vivi-cart-empty-action-secondary {
	border: 1px solid var(--vivi-color-border) !important;
	background: var(--vivi-color-card) !important;
	color: var(--vivi-color-heading) !important;
}

body.vivi-cart-shell-page .vivi-cart-empty-action-primary:hover,
body.vivi-cart-shell-page .vivi-cart-empty-action-secondary:hover {
	border-color: var(--vivi-color-orange) !important;
	background: var(--vivi-color-orange) !important;
	color: var(--vivi-color-text-inverse) !important;
	text-decoration: none !important;
}

@media (max-width: 767px) {
	body.vivi-cart-shell-page .vivi-cart-empty-actions {
		display: grid !important;
		grid-template-columns: 1fr 1fr !important;
		width: auto !important;
		margin: 0 var(--vivi-space-sm) var(--vivi-space-md) !important;
		gap: var(--vivi-space-xs) !important;
	}

	body.vivi-cart-shell-page .vivi-cart-empty-action {
		width: 100% !important;
		min-width: 0 !important;
	}
}

/* v0.9.618 Cart notices: floating notice, so product row position stays identical before/after notices appear. */
body.vivi-cart-shell-page .vivi-cart-shell-card {
	position: relative !important;
}

/* Remove WooCommerce notices from cart layout flow. */
body.vivi-cart-shell-page .woocommerce-notices-wrapper {
	position: fixed !important;
	top: calc(var(--vivi-header-height) + var(--vivi-space-sm)) !important;
	left: 50% !important;
	right: auto !important;
	z-index: 100020 !important;
	display: grid !important;
	gap: var(--vivi-space-xs) !important;
	width: min(var(--vivi-cart-shell-max, 1120px), calc(100vw - (var(--vivi-space-xl) * 2))) !important;
	margin: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	transform: translateX(-50%) !important;
	pointer-events: none !important;
}

body.admin-bar.vivi-cart-shell-page .woocommerce-notices-wrapper {
	top: calc(var(--vivi-header-height) + 32px + var(--vivi-space-sm)) !important;
}

body.vivi-cart-shell-page .woocommerce-notices-wrapper:empty {
	display: none !important;
}

body.vivi-cart-shell-page .woocommerce-message,
body.vivi-cart-shell-page .woocommerce-info,
body.vivi-cart-shell-page .woocommerce-error {
	position: relative !important;
	display: flex !important;
	align-items: center !important;
	gap: var(--vivi-space-sm) !important;
	width: 100% !important;
	margin: 0 !important;
	padding: var(--vivi-space-sm) var(--vivi-space-md) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: color-mix(in srgb, var(--vivi-color-bg-soft) 88%, var(--vivi-color-card)) !important;
	color: var(--vivi-color-text) !important;
	font-size: var(--vivi-fs-small) !important;
	font-weight: var(--vivi-fw-regular) !important;
	line-height: var(--vivi-lh-body) !important;
	box-shadow: var(--vivi-shadow-card) !important;
	pointer-events: auto !important;
}

body.vivi-cart-shell-page .woocommerce-message::before,
body.vivi-cart-shell-page .woocommerce-info::before,
body.vivi-cart-shell-page .woocommerce-error::before {
	content: "" !important;
	display: inline-flex !important;
	width: 8px !important;
	height: 8px !important;
	flex: 0 0 8px !important;
	border-radius: 999px !important;
	background: var(--vivi-color-orange) !important;
}

body.vivi-cart-shell-page .woocommerce-message a,
body.vivi-cart-shell-page .woocommerce-info a,
body.vivi-cart-shell-page .woocommerce-error a {
	color: var(--vivi-color-orange) !important;
	font-weight: var(--vivi-fw-bold) !important;
	text-decoration: none !important;
}

body.vivi-cart-shell-page .woocommerce-message a:hover,
body.vivi-cart-shell-page .woocommerce-info a:hover,
body.vivi-cart-shell-page .woocommerce-error a:hover {
	text-decoration: underline !important;
}

/* Since notice no longer participates in layout, keep product rows at the same top position. */
body.vivi-cart-shell-page .woocommerce-cart-form {
	margin-top: 0 !important;
}

@media (max-width: 767px) {
	body.vivi-cart-shell-page .woocommerce-notices-wrapper {
		top: calc(var(--vivi-header-height-mobile) + var(--vivi-space-xs)) !important;
		width: calc(100vw - (var(--vivi-space-sm) * 2)) !important;
	}

	body.admin-bar.vivi-cart-shell-page .woocommerce-notices-wrapper {
		top: calc(var(--vivi-header-height-mobile) + 32px + var(--vivi-space-xs)) !important;
	}

	body.vivi-cart-shell-page .woocommerce-message,
	body.vivi-cart-shell-page .woocommerce-info,
	body.vivi-cart-shell-page .woocommerce-error {
		align-items: flex-start !important;
		padding: var(--vivi-space-sm) !important;
		font-size: var(--vivi-fs-small) !important;
	}
}


/* v0.9.646 Empty cart message: use full available card width while keeping design-system spacing, padding and border. */
body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .wc-empty-cart-message {
	width: 100% !important;
	max-width: none !important;
	box-sizing: border-box !important;
}

body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .cart-empty.woocommerce-info {
	width: auto !important;
	max-width: none !important;
	box-sizing: border-box !important;
	margin: var(--vivi-space-lg) var(--vivi-space-lg) var(--vivi-space-sm) !important;
	padding: var(--vivi-space-lg) !important;
	border: 1px solid var(--vivi-color-border) !important;
	border-radius: var(--vivi-radius-md) !important;
	background: var(--vivi-color-card) !important;
}

@media (max-width: 767px) {
	body.vivi-cart-shell-page .woocommerce:has(.cart-empty) .cart-empty.woocommerce-info {
		margin: var(--vivi-space-sm) var(--vivi-space-sm) var(--vivi-space-xs) !important;
		padding: var(--vivi-space-md) !important;
	}
}

/* =========================================================
   v0.9.647 Cart notices: keep WooCommerce alerts inside page flow.
   The previous floating notice layer could sit above the shared header
   submenu. This is visual only and does not touch cart/session logic.
========================================================= */
body.vivi-cart-shell-page .woocommerce-notices-wrapper {
	position: static !important;
	top: auto !important;
	left: auto !important;
	right: auto !important;
	z-index: auto !important;
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 0 var(--vivi-space-md) !important;
	padding: 0 !important;
	background: transparent !important;
	transform: none !important;
	pointer-events: auto !important;
}

body.admin-bar.vivi-cart-shell-page .woocommerce-notices-wrapper {
	top: auto !important;
}

body.vivi-cart-shell-page .woocommerce-notices-wrapper:empty {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

body.vivi-cart-shell-page .woocommerce-message,
body.vivi-cart-shell-page .woocommerce-info,
body.vivi-cart-shell-page .woocommerce-error {
	position: relative !important;
	z-index: 0 !important;
	width: 100% !important;
	margin: 0 0 var(--vivi-space-md) !important;
	box-shadow: none !important;
}

@media (max-width: 767px) {
	body.vivi-cart-shell-page .woocommerce-notices-wrapper {
		position: static !important;
		top: auto !important;
		width: 100% !important;
		margin: 0 0 var(--vivi-space-sm) !important;
	}

	body.admin-bar.vivi-cart-shell-page .woocommerce-notices-wrapper {
		top: auto !important;
	}
}
