.vlx-aipb-widget {
	position: relative;
	width: var(--vlx-aipb-width, 1080px);
	height: var(--vlx-aipb-height, 1920px);
	min-width: var(--vlx-aipb-width, 1080px);
	min-height: var(--vlx-aipb-height, 1920px);
	max-width: none;
	max-height: none;
	margin: 0 auto;
	overflow: hidden;
	background: #101113;
	color: #fff;
	font-family: Arial, Helvetica, sans-serif;
	touch-action: manipulation;
	isolation: isolate;
	--vlx-aipb-backdrop-photo-opacity: 40%;
}

.vlx-aipb-widget [x-cloak],
.vlx-aipb-widget [x-show="false"] {
	display: none !important;
}

.vlx-aipb-background-base,
.vlx-aipb-background-state {
	position: absolute;
	inset: 0;
	z-index: 0;
	background: radial-gradient(circle at 50% 20%, #4d5862, #101113 62%);
}

.vlx-aipb-background-state {
	opacity: 0;
	pointer-events: none;
}

.vlx-aipb-background-video {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	max-width: none;
	max-height: none;
	object-fit: cover;
	object-position: center center;
	pointer-events: none;
}

.vlx-aipb-widget.is-booting:not(.is-loaded) > :not(.vlx-aipb-preloader) {
	visibility: hidden !important;
	opacity: 0 !important;
}

.vlx-aipb-stage,
.vlx-aipb-screen,
.vlx-aipb-start-screen,
.vlx-aipb-preloader,
.vlx-aipb-permission {
	position: absolute;
	inset: 0;
	z-index: 5;
}

.vlx-aipb-screen {
	pointer-events: none;
}

.vlx-aipb-screen-sharing {
	pointer-events: auto;
}

.vlx-aipb-control,
.vlx-aipb-nav-button,
.vlx-aipb-start-button,
.vlx-aipb-style-card,
.vlx-aipb-process-button,
.vlx-aipb-style-gallery,
.vlx-aipb-start-screen,
.vlx-aipb-permission .vlx-aipb-control {
	pointer-events: auto;
}

.vlx-aipb-camera-stage {
	position: absolute;
	top: 10%;
	left: 0;
	width: 100%;
	height: 80%;
	z-index: 2;
	overflow: hidden;
	background: #050607;
}

.vlx-aipb-mask-vertical-fade {
	--vlx-aipb-mask-top-height: 15%;
	--vlx-aipb-mask-bottom-height: 15%;
	--vlx-aipb-mask-left-width: 0%;
	--vlx-aipb-mask-right-width: 0%;
	-webkit-mask-image:
		linear-gradient(to bottom, transparent 0%, #000 var(--vlx-aipb-mask-top-height), #000 calc(100% - var(--vlx-aipb-mask-bottom-height)), transparent 100%),
		linear-gradient(to right, transparent 0%, #000 var(--vlx-aipb-mask-left-width), #000 calc(100% - var(--vlx-aipb-mask-right-width)), transparent 100%);
	mask-image:
		linear-gradient(to bottom, transparent 0%, #000 var(--vlx-aipb-mask-top-height), #000 calc(100% - var(--vlx-aipb-mask-bottom-height)), transparent 100%),
		linear-gradient(to right, transparent 0%, #000 var(--vlx-aipb-mask-left-width), #000 calc(100% - var(--vlx-aipb-mask-right-width)), transparent 100%);
	-webkit-mask-composite: source-in;
	mask-composite: intersect;
}

.vlx-aipb-camera-video,
.vlx-aipb-frozen-frame,
.vlx-aipb-editor-placeholder {
	position: absolute;
	inset: 0;
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	min-width: 100%;
	min-height: 100%;
	object-fit: cover !important;
	object-position: center center !important;
}

.vlx-aipb-camera-video {
	z-index: 1;
}

.vlx-aipb-frozen-frame,
.vlx-aipb-editor-placeholder {
	z-index: 2;
	opacity: 0;
	pointer-events: none;
}

.vlx-aipb-editor .vlx-aipb-editor-placeholder,
.vlx-aipb-force-image .vlx-aipb-editor-placeholder {
	opacity: 1;
}

.vlx-aipb-frozen-frame.is-visible {
	opacity: 1;
}

.vlx-aipb-widget.is-photo-backdrop-state .vlx-aipb-frozen-frame.is-visible {
	opacity: var(--vlx-aipb-backdrop-photo-opacity, 40%);
}

.vlx-aipb-widget.is-photo-backdrop-state .vlx-aipb-camera-video,
.vlx-aipb-widget.is-photo-backdrop-state .vlx-aipb-editor-placeholder,
.vlx-aipb-widget.is-photo-backdrop-state.vlx-aipb-editor .vlx-aipb-editor-placeholder,
.vlx-aipb-widget.is-photo-backdrop-state.vlx-aipb-force-image .vlx-aipb-editor-placeholder {
	opacity: 0;
}

.vlx-aipb-camera-canvas {
	display: none;
}

.vlx-aipb-camera-dim {
	position: absolute;
	inset: 0;
	z-index: 4;
	background: rgba(0, 0, 0, 0.38);
	backdrop-filter: blur(7px);
}

.vlx-aipb-preloader,
.vlx-aipb-permission {
	z-index: 200;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(8, 9, 10, 0.96);
}

.vlx-aipb-preloader-inner {
	width: min(28%, 260px);
	text-align: center;
}

.vlx-aipb-permission-card {
	width: min(78%, 760px);
	text-align: center;
}

.vlx-aipb-preloader-title {
	font-size: clamp(16px, 2vw, 28px);
	font-weight: 800;
	line-height: 1;
	margin-bottom: 14px;
}

.vlx-aipb-preloader-bar {
	width: 100%;
	height: 9px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.18);
	overflow: hidden;
}

.vlx-aipb-preloader-bar span {
	display: block;
	height: 100%;
	width: 0;
	border-radius: inherit;
	background: #fff;
	transition: width 180ms ease;
}

.vlx-aipb-preloader-label {
	margin-top: 8px;
	font-size: clamp(9px, 1vw, 12px);
	color: rgba(255, 255, 255, 0.82);
}

.vlx-aipb-permission-card {
	padding: 64px;
	border-radius: 8px;
	background: #fff;
	color: #101113;
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.36);
}

.vlx-aipb-permission-icon {
	width: 108px;
	height: 78px;
	margin: 0 auto 28px;
	border: 8px solid currentColor;
	border-radius: 18px;
	position: relative;
}

.vlx-aipb-permission-icon::before {
	content: "";
	position: absolute;
	width: 34px;
	height: 34px;
	border: 7px solid currentColor;
	border-radius: 50%;
	top: 15px;
	left: 29px;
}

.vlx-aipb-permission-card h2 {
	margin: 0 0 16px;
	font-size: clamp(46px, 6vw, 78px);
	line-height: 1;
}

.vlx-aipb-permission-card p {
	margin: 0 auto 34px;
	font-size: clamp(24px, 3vw, 36px);
	line-height: 1.25;
	max-width: 620px;
}

.vlx-aipb-primary-command,
.vlx-aipb-start-button,
.vlx-aipb-process-button,
.vlx-aipb-nav-button {
	box-sizing: border-box;
	appearance: none;
	-webkit-appearance: none;
	border: 0;
	border-radius: 8px;
	background: #fff;
	color: #111;
	font: inherit;
	font-weight: 800;
	cursor: pointer;
	outline: none;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
	box-shadow: none;
}

.vlx-aipb-primary-command,
.vlx-aipb-start-button,
.vlx-aipb-process-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.vlx-aipb-primary-command {
	min-height: 88px;
	padding: 0 52px;
	font-size: clamp(24px, 3vw, 34px);
}

.vlx-aipb-start-screen {
	z-index: 70;
	background: #050607;
	cursor: pointer;
}

.vlx-aipb-start-screen img {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
}

.vlx-aipb-start-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: clamp(52px, 8vw, 104px);
	font-weight: 900;
}

.vlx-aipb-nav-button {
	position: absolute;
	min-width: 112px;
	min-height: 76px;
	padding: 12px 24px;
	z-index: 40;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	font-size: 24px;
}

.vlx-aipb-nav-button.is-hidden {
	display: none;
}

.vlx-aipb-nav-button img,
.vlx-aipb-start-button img,
.vlx-aipb-process-button img {
	display: block !important;
	height: auto !important;
	max-width: 100% !important;
}

.vlx-aipb-nav-button.is-transparent-hitbox {
	width: var(--vlx-aipb-hitbox-width, auto);
	height: var(--vlx-aipb-hitbox-height, 76px);
	min-width: 0;
	min-height: 0;
	padding: 0;
	background: transparent !important;
	color: transparent !important;
	border-color: transparent !important;
	box-shadow: none !important;
	outline: none !important;
}

.vlx-aipb-nav-button.is-transparent-hitbox > * {
	opacity: 0 !important;
}

.vlx-aipb-editor .vlx-aipb-nav-button.is-transparent-hitbox {
	background: rgba(255, 0, 0, 0.28) !important;
	outline: 2px solid rgba(255, 0, 0, 0.72) !important;
	outline-offset: -2px;
}

.vlx-aipb-start-button.is-neon-animated,
.vlx-aipb-process-button.is-neon-animated,
.vlx-aipb-nav-button.is-neon-animated:not(.is-transparent-hitbox),
.vlx-aipb-start-button.is-full-neon,
.vlx-aipb-process-button.is-full-neon,
.vlx-aipb-nav-button.is-full-neon:not(.is-transparent-hitbox) {
	overflow: visible;
	isolation: isolate;
}

.vlx-aipb-start-button.is-neon-animated > *,
.vlx-aipb-process-button.is-neon-animated > *,
.vlx-aipb-nav-button.is-neon-animated:not(.is-transparent-hitbox) > *,
.vlx-aipb-start-button.is-full-neon > *,
.vlx-aipb-process-button.is-full-neon > *,
.vlx-aipb-nav-button.is-full-neon:not(.is-transparent-hitbox) > * {
	position: relative;
	z-index: 1;
}

.vlx-aipb-start-button.is-neon-animated > span,
.vlx-aipb-process-button.is-neon-animated > span,
.vlx-aipb-nav-button.is-neon-animated:not(.is-transparent-hitbox) > span {
	animation: vlx-aipb-neon-text-pulse 1.85s ease-in-out infinite;
}

.vlx-aipb-start-button.is-neon-animated::before,
.vlx-aipb-process-button.is-neon-animated::before,
.vlx-aipb-nav-button.is-neon-animated:not(.is-transparent-hitbox)::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	border-radius: inherit;
	pointer-events: none;
	border: 2px solid rgba(74, 250, 255, 0.34);
	box-shadow:
		inset 0 0 13px rgba(46, 255, 190, 0.22),
		0 0 12px rgba(0, 244, 255, 0.24),
		0 0 24px rgba(255, 46, 137, 0.14);
	animation: vlx-aipb-neon-breathe 1.85s ease-in-out infinite;
}

.vlx-aipb-start-button.is-neon-animated::after,
.vlx-aipb-process-button.is-neon-animated::after,
.vlx-aipb-nav-button.is-neon-animated:not(.is-transparent-hitbox)::after {
	--vlx-aipb-neon-angle: 0deg;
	--vlx-aipb-neon-thickness: 3px;
	content: '';
	position: absolute;
	inset: 3px;
	z-index: 0;
	padding: var(--vlx-aipb-neon-thickness);
	border-radius: inherit;
	pointer-events: none;
	background:
		conic-gradient(
			from var(--vlx-aipb-neon-angle),
			rgba(0, 244, 255, 0) 0deg,
			rgba(0, 244, 255, 0) 238deg,
			rgba(58, 255, 203, 0.1) 250deg,
			rgba(58, 255, 203, 0.95) 263deg,
			rgba(255, 255, 255, 1) 271deg,
			rgba(255, 46, 137, 0.86) 280deg,
			rgba(255, 46, 137, 0) 298deg,
			rgba(0, 244, 255, 0) 360deg
		);
	box-shadow:
		0 0 10px rgba(0, 244, 255, 0.66),
		0 0 18px rgba(58, 255, 203, 0.48),
		0 0 26px rgba(255, 46, 137, 0.22);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	mask-composite: exclude;
	animation: vlx-aipb-neon-trace 3.4s linear infinite;
}

.vlx-aipb-start-button.is-full-neon,
.vlx-aipb-process-button.is-full-neon,
.vlx-aipb-nav-button.is-full-neon:not(.is-transparent-hitbox) {
	--vlx-aipb-full-neon-color-1: #ff3f9f;
	--vlx-aipb-full-neon-color-2: #ff3f9f;
	animation: vlx-aipb-full-neon-button 7.8s ease-in-out infinite;
	box-shadow: none;
}

.vlx-aipb-start-button.is-full-neon > span,
.vlx-aipb-process-button.is-full-neon > span,
.vlx-aipb-nav-button.is-full-neon:not(.is-transparent-hitbox) > span {
	animation: vlx-aipb-full-neon-text 4.8s steps(2, end) infinite;
	text-shadow:
		0 0 8px rgba(255, 63, 159, 0.38),
		0 0 18px rgba(255, 46, 137, 0.2);
}

.vlx-aipb-start-button.is-full-neon::before,
.vlx-aipb-process-button.is-full-neon::before,
.vlx-aipb-nav-button.is-full-neon:not(.is-transparent-hitbox)::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	border-radius: inherit;
	pointer-events: none;
	background:
		linear-gradient(105deg, transparent 0%, rgba(255, 255, 255, 0) 36%, rgba(255, 255, 255, 0.26) 48%, rgba(255, 255, 255, 0.14) 54%, rgba(255, 255, 255, 0) 68%, transparent 100%),
		linear-gradient(120deg, color-mix(in srgb, var(--vlx-aipb-full-neon-color-1) 7%, transparent), color-mix(in srgb, var(--vlx-aipb-full-neon-color-1) 6%, transparent)),
		radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--vlx-aipb-full-neon-color-1) 8%, transparent), transparent 30%),
		radial-gradient(circle at 82% 80%, color-mix(in srgb, var(--vlx-aipb-full-neon-color-1) 7%, transparent), transparent 34%);
	background-size: 260% 100%, 100% 100%, 100% 100%, 100% 100%;
	background-position: -170% 0, 0 0, 0 0, 0 0;
	box-shadow:
		inset 0 0 0 2px rgba(255, 255, 245, 0.98),
		inset 0 0 0 5px var(--vlx-aipb-full-neon-color-1),
		inset 0 0 13px rgba(255, 245, 205, 0.36),
		inset 0 0 24px color-mix(in srgb, var(--vlx-aipb-full-neon-color-1) 34%, transparent);
	opacity: 0.62;
	animation: vlx-aipb-full-neon-inner 8.6s steps(1, end) infinite, vlx-aipb-full-neon-shine 10.8s ease-in-out infinite;
}

.vlx-aipb-start-button.is-full-neon::after,
.vlx-aipb-process-button.is-full-neon::after,
.vlx-aipb-nav-button.is-full-neon:not(.is-transparent-hitbox)::after {
	content: none;
}

@property --vlx-aipb-neon-angle {
	syntax: '<angle>';
	inherits: false;
	initial-value: 0deg;
}

@keyframes vlx-aipb-neon-trace {
	to {
		--vlx-aipb-neon-angle: 360deg;
	}
}

@keyframes vlx-aipb-neon-breathe {
	0%,
	100% {
		opacity: 0.62;
	}
	50% {
		opacity: 0.94;
	}
}

@keyframes vlx-aipb-neon-text-pulse {
	0%,
	100% {
		filter: brightness(1);
		text-shadow: 0 0 0 rgba(58, 255, 203, 0);
	}
	50% {
		filter: brightness(1.13);
		text-shadow: 0 0 8px rgba(58, 255, 203, 0.22), 0 0 16px rgba(0, 244, 255, 0.12);
	}
}

@keyframes vlx-aipb-full-neon-button {
	0%,
	100% {
		filter: saturate(1) brightness(1);
		box-shadow: none;
	}
	48% {
		filter: saturate(1.22) brightness(1.08);
		box-shadow: none;
	}
	52% {
		filter: saturate(0.9) brightness(0.94);
	}
	56% {
		filter: saturate(1.28) brightness(1.12);
	}
}

@keyframes vlx-aipb-full-neon-inner {
	0%,
	100% {
		opacity: 0.62;
		transform: translate3d(0, 0, 0);
	}
	38% {
		opacity: 0.68;
	}
	41% {
		opacity: 0.5;
		transform: translate3d(1px, 0, 0);
	}
	43% {
		opacity: 0.7;
		transform: translate3d(-1px, 0, 0);
	}
	70% {
		opacity: 0.58;
	}
	72% {
		opacity: 0.48;
	}
	74% {
		opacity: 0.66;
	}
}

@keyframes vlx-aipb-full-neon-shine {
	0%,
	24% {
		background-position: -170% 0, 0 0, 0 0, 0 0;
	}
	52% {
		background-position: 165% 0, 0 0, 0 0, 0 0;
	}
	100% {
		background-position: 165% 0, 0 0, 0 0, 0 0;
	}
}

@keyframes vlx-aipb-full-neon-border {
	0%,
	100% {
		opacity: 0.95;
		filter: hue-rotate(0deg) brightness(1.05);
	}
	9% {
		opacity: 0.18;
	}
	11% {
		opacity: 1;
	}
	32% {
		opacity: 0.76;
		filter: hue-rotate(32deg) brightness(1.2);
	}
	34% {
		opacity: 0.12;
	}
	36% {
		opacity: 1;
	}
	62% {
		opacity: 0.86;
		filter: hue-rotate(-24deg) brightness(1.1);
	}
	64% {
		opacity: 0.34;
	}
	66% {
		opacity: 1;
	}
}

@keyframes vlx-aipb-full-neon-text {
	0%,
	100% {
		filter: brightness(1);
		text-shadow: 0 0 8px rgba(255, 63, 159, 0.35), 0 0 18px rgba(255, 46, 137, 0.18);
	}
	42% {
		filter: brightness(1.18);
		text-shadow: 0 0 10px rgba(255, 255, 255, 0.36), 0 0 24px rgba(255, 63, 159, 0.28), 0 0 34px rgba(255, 46, 137, 0.24);
	}
	45% {
		filter: brightness(0.9);
		text-shadow: 1px 0 0 rgba(255, 46, 137, 0.55), -1px 0 0 rgba(255, 63, 159, 0.45);
	}
	48% {
		filter: brightness(1.22);
	}
}

.vlx-aipb-start-button {
	position: absolute;
	transform: translate(-50%, -50%);
	min-width: 250px;
	min-height: 96px;
	padding: 0 42px;
	font-size: clamp(30px, 5vw, 58px);
}

.vlx-aipb-source-selection-label {
	position: absolute;
	top: 72%;
	left: 50%;
	z-index: 29;
	width: min(86%, 760px);
	transform: translate(-50%, -50%);
	color: #fff;
	font-size: clamp(26px, 4vw, 54px);
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	pointer-events: none;
}

.vlx-aipb-source-buttons {
	position: absolute;
	top: 82%;
	left: 50%;
	z-index: 30;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: 48px;
	transform: translate(-50%, -50%);
}

.vlx-aipb-source-buttons .vlx-aipb-source-button {
	position: relative;
	top: auto;
	left: auto;
	transform: none;
}

.vlx-aipb-source-button {
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: var(--vlx-aipb-source-button-gap, 10px);
	line-height: 1;
	max-width: none;
	white-space: normal;
	overflow-wrap: anywhere;
	background-repeat: no-repeat;
	background-size: cover;
}

.vlx-aipb-source-button.is-full-neon::before {
	background: transparent !important;
}

.vlx-aipb-source-button img {
	width: 100%;
	height: auto;
}

.vlx-aipb-source-button span {
	max-width: 100%;
}

.vlx-aipb-source-button-icon {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	line-height: 1;
	color: currentColor;
	align-self: center;
}

.vlx-aipb-source-button-icon > * {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.vlx-aipb-source-button-icon i,
.vlx-aipb-source-button-icon svg {
	display: block;
	width: 1em;
	height: 1em;
	font-size: 1em;
	line-height: 1;
	vertical-align: middle;
	color: currentColor;
	fill: currentColor;
}

.vlx-aipb-source-button-label {
	display: inline-flex !important;
	align-items: center;
	flex: 0 1 auto;
	line-height: 1;
}

.vlx-aipb-source-preview {
	position: absolute;
	inset: 0 !important;
	z-index: 3;
	width: 100% !important;
	height: 100% !important;
	aspect-ratio: auto !important;
	transform: none !important;
	border-radius: 0 !important;
	pointer-events: none;
}

.vlx-aipb-photo-grid-preview {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 4px;
	background: var(--vlx-aipb-photo-grid-separator-color, #fff);
	overflow: hidden;
}

.vlx-aipb-photo-grid-cell {
	position: relative;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.08);
	isolation: isolate;
}

.vlx-aipb-photo-grid-cell img,
.vlx-aipb-photo-grid-live-canvas {
	position: absolute;
	inset: 0;
	display: block;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover;
	z-index: 1;
}

.vlx-aipb-photo-grid-cell.is-active::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 2;
	box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.72);
	pointer-events: none;
}

.vlx-aipb-countdown-box {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 24;
	transform: translate(-50%, -50%);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 300px;
	height: 300px;
	min-width: 220px;
	min-height: 220px;
	padding: 24px;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.22);
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.36), inset 0 0 0 3px rgba(255, 255, 255, 0.24);
	--vlx-aipb-countdown-progress: 0%;
}

.vlx-aipb-countdown-box::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	border-radius: inherit;
	background: conic-gradient(rgba(255, 255, 255, 0.94) var(--vlx-aipb-countdown-progress, 0%), rgba(255, 255, 255, 0.16) 0);
}

.vlx-aipb-countdown-core {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.58);
	box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.18);
}

.vlx-aipb-countdown-number {
	font-size: clamp(120px, 18vw, 240px);
	font-weight: 900;
	line-height: 1;
}

.vlx-aipb-flash {
	position: absolute;
	inset: 0;
	z-index: 90;
	background: #fff;
	opacity: 0;
	pointer-events: none;
}

.vlx-aipb-photo-card {
	position: absolute;
	top: 10%;
	left: 14%;
	width: 72%;
	aspect-ratio: 4 / 5;
	z-index: 15;
	overflow: hidden;
	background: #111;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
	transform-origin: center center;
	will-change: transform, opacity;
	isolation: isolate;
}

.vlx-aipb-photo-image,
.vlx-aipb-processed-image,
.vlx-aipb-frame-overlay,
.vlx-aipb-matrix {
	position: absolute;
	inset: 0;
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
}

.vlx-aipb-processed-image {
	z-index: 1;
	opacity: 0;
	pointer-events: none;
}

.vlx-aipb-frame-overlay {
	z-index: 3;
	pointer-events: none;
}

.vlx-aipb-matrix {
	z-index: 2;
	opacity: 0;
	pointer-events: none;
	mix-blend-mode: screen;
}

.vlx-aipb-style-label {
	position: absolute;
	z-index: 20;
	--vlx-aipb-review-y: 0px;
	transform: translate(-50%, calc(-50% + var(--vlx-aipb-review-y)));
	font-size: clamp(28px, 4vw, 54px);
	font-weight: 800;
}

.vlx-aipb-style-gallery {
	position: absolute;
	z-index: 20;
	width: 86%;
	height: auto;
	--vlx-aipb-review-y: 0px;
	transform: translate(-50%, calc(-50% + var(--vlx-aipb-review-y)));
	overflow: visible;
	touch-action: pan-y;
	--vlx-aipb-item-gap: 28px;
	--vlx-aipb-item-aspect-ratio: 4 / 5;
	--vlx-aipb-arrow-offset: 10px;
}

.vlx-aipb-style-arrow {
	position: absolute;
	top: 50%;
	z-index: 3;
	width: 38px;
	height: 64px;
	transform: translateY(-50%);
	cursor: pointer;
	pointer-events: auto;
	opacity: 0.76;
	transition: opacity 160ms ease, transform 160ms ease;
}

.vlx-aipb-style-arrow:hover,
.vlx-aipb-style-arrow:focus-visible {
	opacity: 1;
}

.vlx-aipb-style-arrow::before {
	content: "";
	position: absolute;
	top: 50%;
	width: 22px;
	height: 22px;
	border-top: 4px solid rgba(255, 255, 255, 0.92);
	border-left: 4px solid rgba(255, 255, 255, 0.92);
}

.vlx-aipb-style-arrow-prev {
	left: calc((38px + var(--vlx-aipb-arrow-offset, 10px)) * -1);
}

.vlx-aipb-style-arrow-prev::before {
	left: 12px;
	transform: translateY(-50%) rotate(-45deg);
}

.vlx-aipb-style-arrow-next {
	right: calc((38px + var(--vlx-aipb-arrow-offset, 10px)) * -1);
}

.vlx-aipb-style-arrow-next::before {
	right: 12px;
	transform: translateY(-50%) rotate(135deg);
}

.vlx-aipb-style-window {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.vlx-aipb-style-track {
	display: flex;
	align-items: center;
	gap: var(--vlx-aipb-effective-item-gap, var(--vlx-aipb-item-gap, 28px));
	height: auto;
	will-change: transform;
}

.vlx-aipb-style-card {
	position: relative;
	box-sizing: border-box;
	flex: 0 0 var(--vlx-aipb-card-width, calc((100% / var(--vlx-aipb-items-shown, 3)) - var(--vlx-aipb-item-gap, 28px)));
	width: var(--vlx-aipb-card-width, calc((100% / var(--vlx-aipb-items-shown, 3)) - var(--vlx-aipb-item-gap, 28px)));
	height: auto;
	aspect-ratio: var(--vlx-aipb-item-aspect-ratio);
	overflow: hidden;
	border: 3px solid rgba(255, 255, 255, 0.38);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.12);
	padding: 0;
	transform: scale(var(--vlx-aipb-normal-item-scale, 0.9));
	transition: transform 180ms ease, border-color 180ms ease, opacity 180ms ease;
	opacity: 0.72;
	cursor: pointer;
	outline: none;
	user-select: none;
}

.vlx-aipb-style-card.is-active {
	transform: scale(var(--vlx-aipb-active-item-scale, 1));
	border-color: #fff;
	opacity: 1;
}

.vlx-aipb-style-card img {
	position: absolute;
	inset: 0;
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
	will-change: transform;
	pointer-events: none;
	-webkit-user-drag: none;
	user-select: none;
}

.vlx-aipb-style-card-label {
	position: absolute;
	left: 0;
	right: 0;
	padding: 10px 12px;
	background: rgba(0, 0, 0, 0.62);
	color: #fff;
	text-align: center;
	font-weight: 800;
	font-size: 18px;
	pointer-events: none;
	user-select: none;
}

.vlx-aipb-style-card-label.is-top {
	top: 0;
}

.vlx-aipb-style-card-label.is-bottom {
	bottom: 0;
}

.vlx-aipb-process-button {
	position: absolute;
	z-index: 22;
	--vlx-aipb-review-y: 0px;
	transform: translate(-50%, calc(-50% + var(--vlx-aipb-review-y)));
	min-width: 260px;
	min-height: 90px;
	padding: 0 36px;
	font-size: clamp(26px, 4vw, 42px);
}

.vlx-aipb-processing-label {
	position: absolute;
	top: 70%;
	left: 50%;
	z-index: 35;
	transform: translate(-50%, -50%);
	font-size: clamp(34px, 5vw, 68px);
	font-weight: 900;
	text-align: center;
	text-shadow: 0 4px 24px rgba(0, 0, 0, 0.65);
	white-space: nowrap;
	min-width: min(86%, 920px);
	min-height: 3.7em;
	pointer-events: none;
}

.vlx-aipb-processing-lines {
	position: relative;
	width: 100%;
	min-height: 3.7em;
}

.vlx-aipb-processing-line {
	position: absolute;
	top: 0;
	left: 50%;
	width: 100%;
	transform: translate3d(-50%, calc(var(--vlx-aipb-processing-line-slot, 0) * 1.24em), 0);
	transition:
		transform 0.72s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.72s ease;
	will-change: transform, opacity;
}

.vlx-aipb-processing-line.is-removing {
	transform: translate3d(-50%, -0.64em, 0);
}

.vlx-aipb-processing-label.is-erasing .vlx-aipb-processing-line {
	transition:
		transform 0.18s ease,
		opacity 0.18s ease;
}

.vlx-aipb-photo-processor-ui {
	position: absolute;
	inset: 0;
	z-index: 20;
	pointer-events: none;
}

.vlx-aipb-photo-processor-ui > * {
	pointer-events: auto;
}

.vlx-aipb-processing-cursor {
	display: inline-block;
	width: 0.08em;
	height: 0.9em;
	margin-left: 0.12em;
	vertical-align: -0.08em;
	background: currentColor;
	animation: vlx-aipb-processing-cursor 0.78s steps(2, start) infinite;
}

.vlx-aipb-processing-cursor.is-quick {
	animation-duration: 0.22s;
}

@keyframes vlx-aipb-processing-cursor {
	0%,
	45% {
		opacity: 1;
	}
	46%,
	100% {
		opacity: 0;
	}
}

.vlx-aipb-qr-card {
	position: absolute;
	z-index: 45;
	top: 76%;
	left: 50%;
	right: auto;
	bottom: auto;
	translate: none;
	transform: translate3d(-50%, -50%, 0);
	transform-origin: center center;
	display: grid;
	grid-template-rows: auto auto auto;
	justify-items: center;
	align-content: start;
	justify-content: stretch;
	row-gap: 0;
	width: 50%;
	padding: 32px;
	box-sizing: border-box;
	border-radius: 8px;
	background: transparent;
	color: #111;
	text-align: center;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
}

.vlx-aipb-sharing-result-card {
	position: absolute;
	z-index: 45;
	top: 50%;
	left: 50%;
	width: 72%;
	aspect-ratio: 4 / 5;
	overflow: hidden;
	background: #111;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
	transform: translate3d(-50%, -50%, 0);
	transform-origin: center center;
	will-change: transform, opacity;
}

.vlx-aipb-sharing-result-image {
	position: absolute;
	inset: 0;
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
}

.vlx-aipb-qr-label {
	margin: 0 0 var(--vlx-aipb-label-qr-gap, 16px) !important;
	padding: 0 !important;
	font-size: clamp(22px, 3vw, 34px);
	font-weight: 800;
	line-height: 1.2;
}

.vlx-aipb-qr-code {
	position: relative;
	display: block;
	width: min(320px, 100%);
	aspect-ratio: 1;
	max-width: 100%;
	margin: 0 auto;
	padding: 0 !important;
	flex: 0 0 auto;
	min-height: 0;
	line-height: 0;
}

.vlx-aipb-qr-progress-loader,
.vlx-aipb-qr-media {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.vlx-aipb-qr-media {
	opacity: 0;
}

.vlx-aipb-qr-code.is-local-preview-link,
.vlx-aipb-qr-code.is-local-preview-link .vlx-aipb-qr-media {
	pointer-events: auto;
}

.vlx-aipb-qr-code.is-local-preview-link {
	cursor: pointer;
}

.vlx-aipb-qr-media.is-local-preview-link,
.vlx-aipb-qr-media.is-local-preview-link canvas,
.vlx-aipb-qr-media.is-local-preview-link img {
	cursor: pointer;
}

.vlx-aipb-qr-preview-link {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: block;
	cursor: pointer;
}

.vlx-aipb-qr-progress-loader {
	opacity: 1;
}

.vlx-aipb-qr-progress-ring {
	position: relative;
	width: min(72%, 230px);
	aspect-ratio: 1;
	border-radius: 50%;
	background:
		conic-gradient(from 0deg, transparent 0deg, rgba(0, 0, 0, 0.1) 92deg, currentColor 178deg, rgba(0, 0, 0, 0.1) 252deg, transparent 360deg),
		radial-gradient(circle, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0) 62%);
	color: var(--vlx-aipb-qr-loader-color, #111);
	box-shadow: 0 0 28px rgba(0, 0, 0, 0.12);
	animation: vlx-aipb-qr-loader-spin 1s linear infinite;
}

.vlx-aipb-qr-progress-ring::before {
	content: "";
	position: absolute;
	inset: 16%;
	border-radius: inherit;
	background: var(--vlx-aipb-qr-loader-center, #fff);
	box-shadow: inset 0 0 24px rgba(0, 0, 0, 0.08);
}

.vlx-aipb-qr-progress-ring::after {
	content: "";
	position: absolute;
	inset: 36%;
	border-radius: inherit;
	background: currentColor;
	opacity: 0.2;
	animation: vlx-aipb-qr-loader-pulse 0.9s ease-in-out infinite;
}

.vlx-aipb-qr-code canvas,
.vlx-aipb-qr-code img {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

@keyframes vlx-aipb-qr-loader-pulse {
	0%,
	100% {
		transform: scale(0.72);
		opacity: 0.14;
	}
	50% {
		transform: scale(1);
		opacity: 0.34;
	}
}

@keyframes vlx-aipb-qr-loader-spin {
	to {
		transform: rotate(360deg);
	}
}

.vlx-aipb-error-dialog {
	position: absolute;
	inset: 0;
	z-index: 90;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 7%;
	background: rgba(5, 8, 18, 0.58);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	pointer-events: auto;
}

.vlx-aipb-error-card {
	width: min(76%, 620px);
	padding: clamp(28px, 4vw, 54px);
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 18px;
	background: rgba(16, 23, 35, 0.92);
	box-shadow: 0 26px 80px rgba(0, 0, 0, 0.42);
	color: #f8fafc;
	text-align: center;
}

.vlx-aipb-error-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	margin-bottom: 18px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
	color: #ffffff;
	font-size: 32px;
	font-weight: 800;
	line-height: 1;
}

.vlx-aipb-error-card h2 {
	margin: 0 0 12px;
	color: #ffffff;
	font-size: clamp(28px, 3.5vw, 46px);
	font-weight: 760;
	letter-spacing: 0;
	line-height: 1.05;
}

.vlx-aipb-error-card p {
	margin: 0 auto;
	max-width: 28em;
	color: rgba(248, 250, 252, 0.82);
	font-size: clamp(18px, 2vw, 26px);
	line-height: 1.35;
}

.vlx-aipb-error-detail {
	margin: 18px auto 0;
	max-width: 34em;
	padding: 12px 14px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.08);
	color: rgba(248, 250, 252, 0.68);
	font-size: clamp(13px, 1.25vw, 16px);
	line-height: 1.35;
	overflow-wrap: anywhere;
}

.vlx-aipb-error-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 150px;
	margin-top: 28px;
	padding: 14px 28px;
	border: 0;
	border-radius: 999px;
	background: #ffffff;
	color: #101827;
	font-size: 18px;
	font-weight: 760;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 10px 26px rgba(0, 0, 0, 0.28);
}

.vlx-aipb-error-button:focus-visible {
	outline: 3px solid rgba(255, 255, 255, 0.5);
	outline-offset: 4px;
}

.vlx-aipb-share-progress {
	width: 100%;
	height: 16px;
	margin-top: var(--vlx-aipb-qr-progress-gap, 12px) !important;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	padding: 0 !important;
	flex: 0 0 auto;
	overflow: hidden;
	background: rgba(0, 0, 0, 0.16);
	border-radius: 999px;
}

.vlx-aipb-share-progress-fill {
	display: block;
	width: 0;
	height: 100%;
	background: #111;
	border-radius: inherit;
	transition: width 100ms linear;
}

@media (max-width: 767px) {
	.vlx-aipb-photo-card {
		width: 78%;
	}

	.vlx-aipb-style-gallery {
		width: 94%;
	}
}
