/**
 * Hello Elementor child — Side Cart WooCommerce (Xootix) tweaks only.
 *
 * Floating basket is disabled in plugin settings; the live trigger is the
 * [xoo_wsc_cart] shortcode in the HFE header (see Header template HTML widget).
 */

/* Keep drawer chrome inert until the cart is actually open.
   Root cause: the fullscreen Xootix shell/overlay could remain fixed above
   the page in a closed state, blocking header taps on mobile. */
body:not(.xoo-wsc-cart-active):not(.xoo-wsc-active) .xoo-wsc-markup,
body:not(.xoo-wsc-cart-active):not(.xoo-wsc-active) .xoo-wsc-markup .xoo-wsc-modal,
body:not(.xoo-wsc-cart-active):not(.xoo-wsc-active) .xoo-wsc-markup .xoo-wsc-opac {
	visibility: hidden !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

body.xoo-wsc-cart-active .xoo-wsc-markup,
body.xoo-wsc-active .xoo-wsc-markup,
body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-modal,
body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-modal,
body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-opac,
body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-opac {
	visibility: visible !important;
	opacity: 1 !important;
	pointer-events: auto !important;
}

/* Never show the plugin's default floating basket (footer-fixed). */
html body .xoo-wsc-basket {
	display: none !important;
	visibility: hidden !important;
	pointer-events: none !important;
	width: 0 !important;
	height: 0 !important;
	overflow: hidden !important;
	position: absolute !important;
	clip: rect(0, 0, 0, 0) !important;
}

/* Header trigger: align with account link, stay above nav overlays */
#masthead .mia-header-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: nowrap;
	gap: clamp(12px, 2vw, 22px);
}

#masthead .mia-header-cart {
	position: relative;
	z-index: 1005;
	line-height: 1;
	flex: 0 0 auto;
}

#masthead .mia-header-account {
	flex: 0 0 auto;
	position: relative;
	z-index: 1005;
}

/* Account link colors come from mia-premium.css (.mia-header-account a pill).
   Do not force #fff here — it overrode dark text and caused white-on-white on the light homepage header. */

#masthead .mia-header-cart .xoo-wsc-cart-trigger {
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-width: 44px;
	min-height: 44px;
	padding: 4px 6px;
	box-sizing: border-box;
}

/* Dark header: force visible icon + count */
#masthead .mia-header-cart .xoo-wsc-sc-bki {
	color: #fff !important;
}

#masthead .mia-header-cart .xoo-wsc-sc-cont {
	color: #fff !important;
}

#masthead .mia-header-cart .xoo-wsc-sc-count {
	background-color: #fff !important;
	color: #000 !important;
}

/* -------------------------------------------------------------------------- */
/* Xootix side cart drawer: footer actions must stay readable + clickable      */
/* (plugin inline “custom” colors can produce white text on white backgrounds) */
/* -------------------------------------------------------------------------- */
.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 48px !important;
	width: 100% !important;
	box-sizing: border-box !important;
	opacity: 1 !important;
	visibility: visible !important;
	pointer-events: auto !important;
	position: relative !important;
	clip: auto !important;
	height: auto !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	border-radius: 6px !important;
}

.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout {
	color: #ffffff !important;
	background-color: #0a0a0a !important;
	border: 1px solid #0a0a0a !important;
}

.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout:hover,
.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout:focus {
	color: #ffffff !important;
	background-color: #111111 !important;
	border-color: #111111 !important;
}

.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-cart,
.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-continue {
	color: #0a0a0a !important;
	background-color: #ffffff !important;
	border: 1px solid #0a0a0a !important;
}

.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-cart:hover,
.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-continue:hover {
	background-color: #f3f4f6 !important;
	color: #0a0a0a !important;
}

.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout .amount,
.xoo-wsc-container .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout * {
	color: inherit !important;
}

.xoo-wsc-container .xoo-wsc-footer .xoo-wsc-ft-amt-label,
.xoo-wsc-container .xoo-wsc-footer .xoo-wsc-ft-amt-value,
.xoo-wsc-container .xoo-wsc-footer span.xoo-wsc-ft-amt-label {
	color: #111111 !important;
	opacity: 1 !important;
}

/* -------------------------------------------------------------------------- */
/* Footer never clipped: flex column layout + sticky totals can hide buttons     */
/* Scope under .xoo-wsc-markup; mirror .xoo-wsc-slider if fragments use it.   */
/* -------------------------------------------------------------------------- */
/* Keep drawer column layout stable: body scrolls, footer + buttons stay visible */
.xoo-wsc-markup .xoo-wsc-container {
	display: flex !important;
	flex-direction: column !important;
	min-height: 0 !important;
}

.xoo-wsc-markup .xoo-wsc-container .xoo-wsc-body {
	flex: 1 1 auto !important;
	min-height: 0 !important;
}

.xoo-wsc-markup .xoo-wsc-container .xoo-wsc-footer,
.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-footer {
	flex: 0 0 auto !important;
	flex-shrink: 0 !important;
	position: relative !important;
	/* Do not raise z-index above .xoo-wsc-loader (loading overlay must stay on top). */
	width: 100% !important;
	overflow: visible !important;
	padding-bottom: max(16px, env(safe-area-inset-bottom, 0px)) !important;
}

.xoo-wsc-markup .xoo-wsc-ft-buttons-cont,
.xoo-wsc-container .xoo-wsc-ft-buttons-cont,
.xoo-wsc-slider .xoo-wsc-ft-buttons-cont {
	display: grid !important;
	grid-template-columns: 1fr !important;
	width: 100% !important;
	min-height: min-content !important;
	visibility: visible !important;
	opacity: 1 !important;
}

/* Duplicate action contrast rules for slider-based fragments (same inner markup) */
.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn,
.xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 48px !important;
	width: 100% !important;
	box-sizing: border-box !important;
	opacity: 1 !important;
	visibility: visible !important;
	pointer-events: auto !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	border-radius: 6px !important;
}

.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout,
.xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout {
	color: #ffffff !important;
	background-color: #0a0a0a !important;
	border: 1px solid #0a0a0a !important;
}

.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-cart,
.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-continue,
.xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-cart,
.xoo-wsc-slider .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-continue {
	color: #0a0a0a !important;
	background-color: #ffffff !important;
	border: 1px solid #0a0a0a !important;
}

/* -------------------------------------------------------------------------- */
/* Mia hard footer: one visible Checkout (canonical URL row is reinforced)     */
/* -------------------------------------------------------------------------- */
.xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn-checkout:not(.mia-wsc-checkout-reinforced) {
	display: none !important;
}

.xoo-wsc-ft-buttons-cont a.mia-wsc-checkout-reinforced {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 52px !important;
	width: 100% !important;
	box-sizing: border-box !important;
	color: #ffffff !important;
	background-color: #0a0a0a !important;
	border: 1px solid #0a0a0a !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	border-radius: 6px !important;
	opacity: 1 !important;
	visibility: visible !important;
	pointer-events: auto !important;
	order: 99 !important;
}

.xoo-wsc-ft-buttons-cont a.mia-wsc-checkout-reinforced:hover,
.xoo-wsc-ft-buttons-cont a.mia-wsc-checkout-reinforced:focus {
	background-color: #111111 !important;
	border-color: #111111 !important;
	color: #ffffff !important;
}

.xoo-wsc-ft-buttons-cont .mia-wsc-empty-footer-note {
	margin-top: 10px !important;
	padding: 12px 14px !important;
	border: 1px solid #e5e7eb !important;
	border-radius: 6px !important;
	background: #fafafa !important;
	color: #111111 !important;
	text-align: center !important;
	font-size: 13px !important;
	line-height: 1.45 !important;
}

.xoo-wsc-ft-buttons-cont .mia-wsc-empty-footer-note__text {
	margin: 0 !important;
}

@media (max-width: 767px) {
	/* Mobile cart scroll lock:
	   keep the page behind the drawer still while the cart body scrolls. */
	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-container,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-container,
	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-slider,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-slider {
		display: flex !important;
		flex-direction: column !important;
		min-height: 0 !important;
		overflow: hidden !important;
		overscroll-behavior: contain !important;
		touch-action: pan-y !important;
	}

	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-header,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-header,
	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-footer,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-footer {
		flex: 0 0 auto !important;
	}

	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-body,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-body {
		flex: 1 1 auto !important;
		min-height: 0 !important;
		overflow-y: auto !important;
		overflow-x: hidden !important;
		-webkit-overflow-scrolling: touch !important;
		overscroll-behavior: contain !important;
		touch-action: pan-y !important;
	}
}

/* -------------------------------------------------------------------------- */
/* Home / shop / cart: beat page-specific theme rules that clip the drawer      */
/* -------------------------------------------------------------------------- */
body.home .xoo-wsc-markup .xoo-wsc-container,
body.post-type-archive-product.woocommerce-shop .xoo-wsc-markup .xoo-wsc-container,
body.woocommerce-cart .xoo-wsc-markup .xoo-wsc-container {
	display: flex !important;
	flex-direction: column !important;
	min-height: 0 !important;
}

body.home .xoo-wsc-markup .xoo-wsc-container .xoo-wsc-footer,
body.post-type-archive-product.woocommerce-shop .xoo-wsc-markup .xoo-wsc-container .xoo-wsc-footer,
body.woocommerce-cart .xoo-wsc-markup .xoo-wsc-container .xoo-wsc-footer {
	flex: 0 0 auto !important;
	flex-shrink: 0 !important;
	overflow: visible !important;
}

body.home .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn,
body.post-type-archive-product.woocommerce-shop .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn,
body.woocommerce-cart .xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn {
	opacity: 1 !important;
	visibility: visible !important;
}

/* -------------------------------------------------------------------------- */
/* Side cart viewport hardening (2026-04-13)                                   */
/* Fix: drawer was inheriting full page height on home/shop/product, pushing   */
/* footer actions below the visible panel. Keep the panel locked to viewport   */
/* height and pin the footer so Checkout stays visible after fragment refresh. */
/* -------------------------------------------------------------------------- */
.xoo-wsc-opac,
.xoo-wsc-container,
.xoo-wsc-slider,
.xoo-wsc-markup .xoo-wsc-container,
.xoo-wsc-markup .xoo-wsc-slider {
	top: 0 !important;
	bottom: 0 !important;
	height: 100vh !important;
	max-height: 100vh !important;
}

@supports (height: 100svh) {
	.xoo-wsc-opac,
	.xoo-wsc-container,
	.xoo-wsc-slider,
	.xoo-wsc-markup .xoo-wsc-container,
	.xoo-wsc-markup .xoo-wsc-slider {
		height: 100svh !important;
		max-height: 100svh !important;
	}
}

.xoo-wsc-container,
.xoo-wsc-slider,
.xoo-wsc-markup .xoo-wsc-container,
.xoo-wsc-markup .xoo-wsc-slider {
	overflow: hidden !important;
}

.xoo-wsc-container .xoo-wsc-body,
.xoo-wsc-slider .xoo-wsc-body,
.xoo-wsc-markup .xoo-wsc-container .xoo-wsc-body,
.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-body {
	flex: 1 1 auto !important;
	min-height: 0 !important;
	overflow-y: auto !important;
	overflow-x: hidden !important;
	overscroll-behavior: contain !important;
	-webkit-overflow-scrolling: touch;
}

.xoo-wsc-container .xoo-wsc-footer,
.xoo-wsc-slider .xoo-wsc-footer,
.xoo-wsc-markup .xoo-wsc-container .xoo-wsc-footer,
.xoo-wsc-markup .xoo-wsc-slider .xoo-wsc-footer {
	position: sticky !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	z-index: 2 !important;
	background: #ffffff !important;
	border-top: 1px solid #e5e7eb !important;
}

@media (max-width: 767px) {
	/* Root cause: on mobile the drawer could inherit page flow/ancestor layout because
	   only height was hardened; explicitly pin the modal and panel to the viewport. */
	.xoo-wsc-markup,
	.xoo-wsc-markup .xoo-wsc-modal {
		position: fixed !important;
		inset: 0 !important;
		width: 100vw !important;
		height: 100dvh !important;
		max-height: 100dvh !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.xoo-wsc-opac,
	.xoo-wsc-markup .xoo-wsc-opac {
		position: fixed !important;
		inset: 0 !important;
		width: 100vw !important;
		height: 100dvh !important;
		max-height: 100dvh !important;
		z-index: 999998 !important;
	}

	.xoo-wsc-container,
	.xoo-wsc-slider,
	.xoo-wsc-markup .xoo-wsc-container,
	.xoo-wsc-markup .xoo-wsc-slider {
		position: fixed !important;
		top: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		left: auto !important;
		width: min(420px, 100vw) !important;
		max-width: 100vw !important;
		height: 100dvh !important;
		max-height: 100dvh !important;
		margin: 0 !important;
		transform: translateX(100%) !important;
		transition: transform 0.25s ease !important;
		z-index: 999999 !important;
	}

	body.xoo-wsc-active .xoo-wsc-container,
	body.xoo-wsc-active .xoo-wsc-slider,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-container,
	body.xoo-wsc-active .xoo-wsc-markup .xoo-wsc-slider,
	body.xoo-wsc-cart-active .xoo-wsc-container,
	body.xoo-wsc-cart-active .xoo-wsc-slider,
	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-container,
	body.xoo-wsc-cart-active .xoo-wsc-markup .xoo-wsc-slider {
		transform: translateX(0) !important;
	}
}

/* -------------------------------------------------------------------------- */
/* Side-cart suggested add-on: compact BAC Water card between items and totals */
/* -------------------------------------------------------------------------- */
.xoo-wsc-body .mia-sidecart-suggestion {
	margin: 16px 0 8px !important;
	padding: 14px !important;
	border: 1px solid #e5e7eb !important;
	border-radius: 10px !important;
	background: #fafafa !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__media {
	display: grid !important;
	grid-template-columns: 72px minmax(0, 1fr) !important;
	gap: 12px !important;
	align-items: center !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__thumb {
	display: block !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__image {
	display: block !important;
	width: 72px !important;
	height: 72px !important;
	object-fit: cover !important;
	border-radius: 8px !important;
	background: #ffffff !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__content {
	min-width: 0 !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__eyebrow {
	margin: 0 0 4px !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: #6b7280 !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__title {
	margin: 0 0 4px !important;
	font-size: 15px !important;
	line-height: 1.3 !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__title a {
	color: #111111 !important;
	text-decoration: none !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__meta {
	margin: 0 0 10px !important;
	font-size: 13px !important;
	line-height: 1.4 !important;
	color: #4b5563 !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__support {
	margin: 0 0 12px !important;
	font-size: 12px !important;
	line-height: 1.45 !important;
	color: #6b7280 !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__form {
	margin: 0 !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__button {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 42px !important;
	width: 100% !important;
	padding: 10px 14px !important;
	border-radius: 6px !important;
	background: #111111 !important;
	border: 1px solid #111111 !important;
	color: #ffffff !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	line-height: 1.35 !important;
	text-align: center !important;
	text-decoration: none !important;
	white-space: normal !important;
}

.xoo-wsc-body .mia-sidecart-suggestion__button:hover,
.xoo-wsc-body .mia-sidecart-suggestion__button:focus {
	background: #1f2937 !important;
	border-color: #1f2937 !important;
	color: #ffffff !important;
}

@media (max-width: 480px) {
	.xoo-wsc-body .mia-sidecart-suggestion__media {
		grid-template-columns: 60px minmax(0, 1fr) !important;
	}

	.xoo-wsc-body .mia-sidecart-suggestion__image {
		width: 60px !important;
		height: 60px !important;
	}

	.xoo-wsc-body .mia-sidecart-suggestion__button {
		font-size: 12px !important;
		padding: 10px 12px !important;
	}
}


/* -------------------------------------------------------------------------- */
/* Side cart scroll containment (2026-04-16)                                  */
/* Keep the page behind the drawer locked while the cart body remains the only */
/* scrollable surface.                                                         */
/* -------------------------------------------------------------------------- */
html.mia-xoo-scroll-lock,
body.mia-xoo-scroll-lock {
	overflow: hidden !important;
	overscroll-behavior: none !important;
}

.xoo-wsc-markup,
.xoo-wsc-markup .xoo-wsc-modal,
.xoo-wsc-opac,
.xoo-wsc-container,
.xoo-wsc-slider,
.xoo-wsc-markup .xoo-wsc-container,
.xoo-wsc-markup .xoo-wsc-slider {
	overscroll-behavior: none !important;
}

/* Age gate must fully own the viewport until accepted. */
html.age-gate__restricted .xoo-wsc-basket,
html.age-gate__restricted--js .xoo-wsc-basket,
body.age-restriction .xoo-wsc-basket,
html.age-gate__restricted .xoo-wsc-markup,
html.age-gate__restricted--js .xoo-wsc-markup,
body.age-restriction .xoo-wsc-markup {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

html.age-gate__restricted .age-gate__wrapper,
html.age-gate__restricted--js .age-gate__wrapper,
body.age-restriction .age-gate__wrapper,
html.age-gate__restricted .age-gate-wrapper,
html.age-gate__restricted--js .age-gate-wrapper,
body.age-restriction .age-gate-wrapper {
  z-index: 2147483000 !important;
}

html.age-gate__restricted .age-gate__content,
html.age-gate__restricted--js .age-gate__content,
body.age-restriction .age-gate__content,
html.age-gate__restricted .age-gate__buttons,
html.age-gate__restricted--js .age-gate__buttons,
body.age-restriction .age-gate__buttons,
html.age-gate__restricted .age-gate__submit,
html.age-gate__restricted--js .age-gate__submit,
body.age-restriction .age-gate__submit {
  position: relative !important;
  z-index: 2147483001 !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}
