.wvs-has-image-tooltip, [data-wvstooltip] {
	--font-size: 14px;
	--arrow-width: 5px;
	--arrow-distance: 10px;
	--arrow-position: calc(var(--arrow-distance) * -1);
	--tip-redius: 3px;
	--tip-min-width: 100px;
	--tip-min-height: 100px;
	--tip-height: 30px;
	--tip-breakpoint-start: 53vw;
	--tip-distance: calc(var(--arrow-distance) + var(--tip-height));
	--tip-position: calc(var(--tip-distance) * -1);
	--image-tip-min-height: calc(var(--tip-min-height) + var(--tip-height));
	--image-tip-max-height: calc(var(--tooltip-height) + var(--tip-height));
	--image-tip-width-dynamic: clamp(var(--tip-min-width), var(--tip-breakpoint-start), var(--tooltip-width));
	--image-tip-height-dynamic: clamp(var(--tip-min-height), var(--tip-breakpoint-start), var(--tooltip-height));
	--image-tip-ratio: calc(var(--tooltip-height) / var(--tooltip-width));
	--image-tip-position: calc(100% + var(--arrow-distance));
	--horizontal-position: 0px;
	cursor: pointer;
	outline: none;
	position: relative;
}

.wvs-has-image-tooltip:after, .wvs-has-image-tooltip:before, [data-wvstooltip]:after, [data-wvstooltip]:before {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: row;
	flex-direction: row;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-transition: opacity .5s ease-in-out;
	transition: opacity .5s ease-in-out;
	visibility: hidden;
	z-index: 999;
}

.wvs-has-image-tooltip:before, [data-wvstooltip]:before {
	background-color: var(--wvs-tooltip-background-color, #333);
	border-radius: var(--tip-redius);
	bottom: var(--image-tip-position);
	-webkit-box-shadow: 0 0 5px 1px rgba(0, 0, 0, .3);
	box-shadow: 0 0 5px 1px rgba(0, 0, 0, .3);
	color: var(--wvs-tooltip-text-color, #fff);
	font-size: var(--font-size);
	height: var(--tip-height);
	line-height: var(--tip-height);
	min-width: var(--tip-min-width);
	padding-inline: 10px;
	top: auto;
	-webkit-transform: translateX(var(--horizontal-position));
	-ms-transform: translateX(var(--horizontal-position));
	transform: translateX(var(--horizontal-position));
	width: -webkit-max-content;
	width: -moz-max-content;
	width: max-content;
}

[data-wvstooltip]:before {
	content: attr(data-wvstooltip) " " attr(data-wvstooltip-out-of-stock);
}

.wvs-has-image-tooltip:after, [data-wvstooltip]:after {
	border-top-color: transparent;
	border-top-color: var(--wvs-tooltip-background-color, #333);
	border: var(--arrow-width) solid transparent;
	bottom: auto;
	content: " ";
	font-size: 0;
	line-height: 0;
	top: var(--arrow-position);
	width: 0;
}

.wvs-has-image-tooltip:hover:after, .wvs-has-image-tooltip:hover:before, [data-wvstooltip]:hover:after, [data-wvstooltip]:hover:before {
	opacity: 1;
	visibility: visible;
}