/**
 * WC Variation Qty Grid v1.1.7
 * Compatible Astra + Elementor.
 */

/* ── Ocultar formulario nativo ── */
body.di-varqty-active .variations_form table.variations,
body.di-varqty-active .variations_form .variations,
body.di-varqty-active .variations_form .variations tr,
body.di-varqty-active .variations_form .variations td,
body.di-varqty-active .variations_form select,
body.di-varqty-active .variations_form .reset_variations,
body.di-varqty-active .variations_form .woocommerce-variation,
body.di-varqty-active .variations_form .single_variation_wrap,
body.di-varqty-active .variations_form .woocommerce-variation-add-to-cart,
body.di-varqty-active .variations_form .quantity,
body.di-varqty-active form.cart .variations_button,
body.di-varqty-active form.cart .single_add_to_cart_button,
body.di-varqty-active .di-varqty-native-hidden {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	max-height: 0 !important;
	overflow: hidden !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	opacity: 0 !important;
	pointer-events: none !important;
	position: absolute !important;
	left: -9999px !important;
}

/* ── Contenedor ── */
.di-varqty-wrap {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	box-sizing: border-box !important;
	clear: both !important;
}

.di-varqty-grid {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1px solid #d4d4d4 !important;
	border-radius: 6px !important;
	overflow: hidden !important;
	background: #ffffff !important;
	box-sizing: border-box !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
	font-size: 14px !important;
	line-height: 1.4 !important;
}

/* ── Columnas ── */
.di-varqty-head,
.di-varqty-item {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) 100px 112px !important;
	align-items: center !important;
	gap: 6px 10px !important;
	padding: 9px 12px !important;
	margin: 0 !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

.di-varqty-head {
	background: #f3f3f3 !important;
	border-bottom: 1px solid #d4d4d4 !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	color: #666666 !important;
}

.di-varqty-item {
	border-bottom: 1px solid #ececec !important;
	background: #ffffff !important;
}

.di-varqty-item:last-child {
	border-bottom: none !important;
}

.di-varqty-item:hover {
	background: #fafafa !important;
}

.di-varqty-item.di-varqty-is-loading {
	opacity: 0.55 !important;
	pointer-events: none !important;
}

.di-varqty-item.di-varqty-is-error {
	background: #fff6f6 !important;
}

.di-varqty-cell {
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	min-width: 0 !important;
	box-sizing: border-box !important;
}

.di-varqty-cell-name {
	text-align: left !important;
}

.di-varqty-cell-price {
	text-align: center !important;
}

.di-varqty-cell-qty {
	text-align: right !important;
	justify-self: end !important;
}

.di-varqty-name {
	font-size: 13px !important;
	font-weight: 600 !important;
	color: #222222 !important;
	word-break: break-word !important;
}

.di-varqty-unavailable-label {
	display: inline-block !important;
	margin-left: 6px !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	color: #888888 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.03em !important;
}

.di-varqty-item-unavailable {
	opacity: 0.55 !important;
	background: #f9f9f9 !important;
}

.di-varqty-item-unavailable:hover {
	background: #f9f9f9 !important;
}

.di-varqty-item-unavailable .di-varqty-name {
	color: #888888 !important;
}

.di-varqty-item-unavailable .di-varqty-stepper {
	opacity: 0.7 !important;
	pointer-events: none !important;
}

.di-varqty-item-unavailable.di-varqty-item-can-remove .di-varqty-stepper {
	pointer-events: auto !important;
}

.di-varqty-item-unavailable.di-varqty-item-can-remove .di-varqty-stepper-sub {
	pointer-events: auto !important;
	cursor: pointer !important;
}

.di-varqty-item-unavailable .di-varqty-stepper-add,
.di-varqty-item-unavailable .di-varqty-stepper-field {
	pointer-events: none !important;
}

.di-varqty-item-unavailable .di-varqty-stepper-field {
	background: #f3f3f3 !important;
	color: #999999 !important;
}

.di-varqty-price {
	font-size: 12px !important;
	font-weight: 600 !important;
	color: #333333 !important;
}

.di-varqty-price del {
	display: block !important;
	font-size: 10px !important;
	font-weight: 400 !important;
	color: #999999 !important;
}

.di-varqty-price ins {
	text-decoration: none !important;
}

/* ── Stepper ── */
.di-varqty-stepper {
	display: inline-flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: stretch !important;
	justify-content: space-between !important;
	width: 108px !important;
	max-width: 108px !important;
	min-width: 108px !important;
	height: 34px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1px solid #bbbbbb !important;
	border-radius: 4px !important;
	overflow: visible !important;
	background: #ffffff !important;
	box-shadow: none !important;
	float: none !important;
	position: relative !important;
	vertical-align: middle !important;
	z-index: 2 !important;
}

.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add,
.ast-container .di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub,
.ast-container .di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add,
.elementor-widget-woocommerce-product-add-to-cart .di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub,
.elementor-widget-woocommerce-product-add-to-cart .di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add,
.woocommerce .di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub,
.woocommerce .di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add {
	all: unset !important;
	box-sizing: border-box !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex: 0 0 32px !important;
	width: 32px !important;
	min-width: 32px !important;
	max-width: 32px !important;
	height: 32px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	border-radius: 0 !important;
	background: #f0f0f0 !important;
	background-image: none !important;
	color: #333333 !important;
	font-family: inherit !important;
	font-size: 18px !important;
	font-weight: 400 !important;
	line-height: 1 !important;
	text-align: center !important;
	cursor: pointer !important;
	box-shadow: none !important;
	text-shadow: none !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	user-select: none !important;
	-webkit-user-select: none !important;
	-webkit-tap-highlight-color: transparent !important;
}

.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub:hover,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add:hover,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub:focus,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add:focus {
	background: #e4e4e4 !important;
	color: #111111 !important;
	outline: none !important;
	box-shadow: none !important;
}

.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub.di-varqty-stepper-off,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add.di-varqty-stepper-off,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-sub:disabled,
.di-varqty-wrap .di-varqty-stepper button.di-varqty-stepper-add:disabled {
	opacity: 0.35 !important;
	cursor: not-allowed !important;
	pointer-events: none !important;
}

.di-varqty-item:not(.di-varqty-is-loading) .di-varqty-stepper button.di-varqty-stepper-sub:not(.di-varqty-stepper-off),
.di-varqty-item:not(.di-varqty-is-loading) .di-varqty-stepper button.di-varqty-stepper-add:not(.di-varqty-stepper-off) {
	opacity: 1 !important;
	cursor: pointer !important;
	pointer-events: auto !important;
}

.di-varqty-stepper-glyph {
	display: block !important;
	pointer-events: none !important;
	line-height: 1 !important;
	font-size: 18px !important;
	font-weight: 600 !important;
}

.di-varqty-wrap .di-varqty-stepper input.di-varqty-stepper-field,
.ast-container .di-varqty-wrap input.di-varqty-stepper-field,
.elementor-widget-woocommerce-product-add-to-cart .di-varqty-wrap input.di-varqty-stepper-field,
.woocommerce .di-varqty-wrap input.di-varqty-stepper-field {
	display: block !important;
	flex: 0 0 44px !important;
	width: 44px !important;
	min-width: 44px !important;
	max-width: 44px !important;
	height: 32px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	border-left: 1px solid #bbbbbb !important;
	border-right: 1px solid #bbbbbb !important;
	border-radius: 0 !important;
	background: #ffffff !important;
	background-image: none !important;
	color: #222222 !important;
	font-family: inherit !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	line-height: 32px !important;
	text-align: center !important;
	box-shadow: none !important;
	float: none !important;
	position: static !important;
	appearance: none !important;
	-webkit-appearance: none !important;
}

.di-varqty-stepper-field:focus {
	outline: none !important;
	box-shadow: inset 0 0 0 1px #888888 !important;
}

/* ── Notificación carrito ── */
.di-varqty-toast-wrap {
	position: fixed !important;
	right: 16px !important;
	bottom: 16px !important;
	z-index: 999999 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
	max-width: min(360px, calc(100vw - 32px)) !important;
	pointer-events: none !important;
}

.di-varqty-toast {
	display: flex !important;
	align-items: flex-start !important;
	gap: 10px !important;
	padding: 12px 14px !important;
	border-radius: 8px !important;
	background: #1f7a3f !important;
	color: #ffffff !important;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18) !important;
	opacity: 0 !important;
	transform: translateY(12px) !important;
	transition: opacity 0.25s ease, transform 0.25s ease !important;
	pointer-events: auto !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
	font-size: 13px !important;
	line-height: 1.35 !important;
}

.di-varqty-toast.is-visible {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

.di-varqty-toast-removed {
	background: #555555 !important;
}

.di-varqty-toast-icon {
	flex: 0 0 auto !important;
	width: 22px !important;
	height: 22px !important;
	border-radius: 50% !important;
	background: rgba(255, 255, 255, 0.2) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 13px !important;
	font-weight: 700 !important;
}

.di-varqty-toast-content {
	display: flex !important;
	flex-direction: column !important;
	gap: 2px !important;
	flex: 1 !important;
	min-width: 0 !important;
}

.di-varqty-toast-title {
	display: block !important;
	font-weight: 600 !important;
}

.di-varqty-toast-meta {
	display: block !important;
	font-size: 11px !important;
	opacity: 0.9 !important;
}

.di-varqty-toast-close {
	all: unset !important;
	box-sizing: border-box !important;
	flex: 0 0 auto !important;
	width: 24px !important;
	height: 24px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	cursor: pointer !important;
	font-size: 18px !important;
	line-height: 1 !important;
	opacity: 0.85 !important;
	border-radius: 4px !important;
}

.di-varqty-toast-close:hover {
	opacity: 1 !important;
	background: rgba(255, 255, 255, 0.15) !important;
}

@media (max-width: 600px) {
	.di-varqty-toast-wrap {
		right: 10px !important;
		bottom: 10px !important;
		left: 10px !important;
		max-width: none !important;
	}

	.di-varqty-head {
		display: none !important;
	}

	.di-varqty-item {
		grid-template-columns: 1fr auto !important;
		grid-template-rows: auto auto !important;
		gap: 6px 10px !important;
		padding: 10px !important;
	}

	.di-varqty-cell-name {
		grid-column: 1 / 2 !important;
		grid-row: 1 !important;
	}

	.di-varqty-cell-price {
		grid-column: 2 / 3 !important;
		grid-row: 1 !important;
		text-align: right !important;
	}

	.di-varqty-cell-qty {
		grid-column: 2 / 3 !important;
		grid-row: 2 !important;
	}
}
