/**
 * Preview AI - Google Try-On Style
 * Mobile-first, minimal, elegant
 */

/* ─────────────────────────────────────────────────────────────
   Base Reset - Prevent theme overrides
───────────────────────────────────────────────────────────── */
.preview-ai-chip-wrapper,
.preview-ai-modal,
.preview-ai-modal-content {
	font-size: 16px;
	line-height: 1.5;
	text-transform: none;
	letter-spacing: normal;
	box-sizing: border-box;
}

/* Reset para botones dentro del widget - evita estilos de tema */
.preview-ai-modal button,
.preview-ai-modal a,
.preview-ai-chip-wrapper button {
	box-sizing: border-box !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	text-decoration: none !important;
	outline: none !important;
	background-image: none !important;
}

/* ─────────────────────────────────────────────────────────────
   CSS Variables
───────────────────────────────────────────────────────────── */
:root {
	--pai-primary: #1e1e2e;
	--pai-primary-hover: #2d2d3d;
	--pai-accent: #3b82f6;
	--pai-accent-hover: #5558e3;
	--pai-accent-soft: rgba(99, 102, 241, 0.08);
	--pai-accent-border: rgba(99, 102, 241, 0.2);
	--pai-bg: #fff;
	--pai-bg-soft: #fafbff;
	--pai-text: #1e1e2e;
	--pai-text-secondary: #5f6368;
	--pai-text-muted: #9aa0a6;
	--pai-border: rgba(0, 0, 0, 0.08);
	--pai-border-strong: rgba(0, 0, 0, 0.12);
	--pai-radius-full: 999px;
	--pai-radius-lg: 20px;
	--pai-radius-md: 12px;
	--pai-radius-sm: 8px;
	--pai-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
	--pai-shadow-md: 0 2px 8px -2px rgba(0, 0, 0, 0.1), 0 4px 16px -4px rgba(0, 0, 0, 0.08);
	--pai-shadow-lg: 0 8px 24px -4px rgba(0, 0, 0, 0.12), 0 16px 48px -8px rgba(0, 0, 0, 0.1);
	--pai-shadow-accent: 0 2px 8px -2px rgba(99, 102, 241, 0.2), 0 4px 16px -4px rgba(99, 102, 241, 0.15);
	--pai-transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	--pai-transition-fast: 0.15s ease;
}

/* ─────────────────────────────────────────────────────────────
   Action Chip Container
   Forzado a ocupar 100% para aparecer debajo del botón "Añadir al carrito"
───────────────────────────────────────────────────────────── */
.preview-ai-chip-wrapper {
	display: block !important;
	flex: 0 0 100% !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 1rem 0 0.5rem 0 !important;
	padding: 0 !important;
	clear: both !important;
	order: 9999 !important;
	grid-column: 1 / -1 !important; /* Para padres con CSS Grid */
	text-align: center;
}

.preview-ai-position-left { text-align: left !important; }
.preview-ai-position-center { text-align: center !important; }
.preview-ai-position-right { text-align: right !important; }

/* ─────────────────────────────────────────────────────────────
   Action Chip
───────────────────────────────────────────────────────────── */
button.preview-ai-chip {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	height: 38px !important;
	padding: 0 16px 0 12px !important;
	margin: 0 !important;
	border: 1px solid var(--pai-accent-border) !important;
	border-radius: var(--pai-radius-full) !important;
	background: linear-gradient(to bottom, #fff, var(--pai-bg-soft)) !important;
	box-shadow: var(--pai-shadow-accent) !important;
	font-family: inherit !important;
	cursor: pointer !important;
	transition: all var(--pai-transition-fast) !important;
	-webkit-tap-highlight-color: transparent !important;
	vertical-align: middle !important;
}

button.preview-ai-chip:hover {
	background: linear-gradient(to bottom, var(--pai-bg-soft), #f0f3ff) !important;
	border-color: rgba(99, 102, 241, 0.3) !important;
	box-shadow: 0 4px 12px -2px rgba(99, 102, 241, 0.25) !important;
	transform: translateY(-1px) !important;
}

button.preview-ai-chip:active {
	background: linear-gradient(to bottom, #eef1ff, #e8ebff) !important;
	box-shadow: var(--pai-shadow-sm) !important;
	transform: translateY(0) !important;
}

/* Button Shape Variants */
button.preview-ai-chip.preview-ai-shape-pill {
	border-radius: var(--pai-radius-full) !important;
}

button.preview-ai-chip.preview-ai-shape-squared {
	border-radius: var(--pai-radius-sm) !important;
}

button.preview-ai-chip.preview-ai-shape-sharp {
	border-radius: 0 !important;
}

.preview-ai-chip-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	color: var(--pai-accent);
}

.preview-ai-chip-icon svg {
	width: 18px;
	height: 18px;
}

.preview-ai-chip-text {
	font-size: 14px !important;
	font-weight: 500 !important;
	color: var(--pai-text) !important;
	white-space: nowrap !important;
	letter-spacing: -0.01em !important;
}

/* ─────────────────────────────────────────────────────────────
   Modal
───────────────────────────────────────────────────────────── */
.preview-ai-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 999999;
	background: rgba(30, 30, 46, 0.4);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	opacity: 0;
	transition: opacity var(--pai-transition);
}

.preview-ai-modal.is-open {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}

.preview-ai-modal.is-visible {
	opacity: 1;
}

.preview-ai-modal-content {
	position: relative;
	width: 100%;
	max-width: 380px;
	max-height: 90vh;
	overflow-y: auto;
	padding: 1.75rem;
	background: var(--pai-bg);
	border: 1px solid var(--pai-border);
	border-radius: var(--pai-radius-lg);
	box-shadow: var(--pai-shadow-lg);
	transform: translateY(16px) scale(0.98);
	transition: transform var(--pai-transition);
}

.preview-ai-modal.is-visible .preview-ai-modal-content {
	transform: translateY(0) scale(1);
}

.preview-ai-modal-content::-webkit-scrollbar { width: 6px; }
.preview-ai-modal-content::-webkit-scrollbar-track { background: transparent; }
.preview-ai-modal-content::-webkit-scrollbar-thumb { background: var(--pai-border-strong); border-radius: 3px; }

/* ─────────────────────────────────────────────────────────────
   Close Button
───────────────────────────────────────────────────────────── */
.preview-ai-close {
	position: absolute !important;
	top: 0.875rem !important;
	right: 0.875rem !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 28px !important;
	height: 28px !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 1px solid var(--pai-border) !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-bg) !important;
	color: var(--pai-text-secondary) !important;
	font-size: 1rem !important;
	line-height: 1 !important;
	cursor: pointer !important;
	transition: all var(--pai-transition-fast) !important;
	z-index: 10 !important;
	box-shadow: none !important;
}

.preview-ai-close:hover {
	background: var(--pai-bg-soft) !important;
	border-color: var(--pai-border-strong) !important;
	color: var(--pai-text) !important;
}

/* ─────────────────────────────────────────────────────────────
   Saved Photo Section
───────────────────────────────────────────────────────────── */
.preview-ai-saved-photo {
	display: none;
	text-align: center;
}

.preview-ai-saved-photo.is-visible {
	display: block;
	animation: pai-fade-in 0.3s ease-out;
}

.preview-ai-saved-photo.is-visible ~ .preview-ai-instructions {
	display: none;
}

.preview-ai-tryons.is-visible ~ .preview-ai-instructions {
	display: none;
}

.preview-ai-saved-photo-header {
	margin-bottom: 1rem;
}

.preview-ai-saved-photo-header h3 {
	margin: 0 0 0.25rem !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	color: var(--pai-text) !important;
	letter-spacing: -0.02em !important;
}

.preview-ai-saved-photo-header p {
	margin: 0 !important;
	font-size: 13px !important;
	color: var(--pai-text-secondary) !important;
	line-height: 1.4 !important;
}

.preview-ai-saved-photo-preview {
	position: relative;
	width: 200px;
	height: 260px;
	margin: 0 auto 1rem;
	border-radius: var(--pai-radius-md);
	overflow: hidden;
	border: 2px solid var(--pai-accent);
	box-shadow: var(--pai-shadow-accent);
}

.preview-ai-saved-photo-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.preview-ai-stage img,
.preview-ai-saved-photo-preview img,
.preview-ai-lightbox img {
  image-orientation: from-image;
}


button.preview-ai-use-saved-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
	width: 100% !important;
	height: 44px !important;
	padding: 0 1.5rem !important;
	border: none !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-accent) !important;
	color: #fff !important;
	font-family: inherit !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	box-shadow: var(--pai-shadow-accent) !important;
	transition: all var(--pai-transition-fast) !important;
}

button.preview-ai-use-saved-btn:hover {
	background: var(--pai-accent-hover) !important;
	box-shadow: 0 4px 16px -2px rgba(99, 102, 241, 0.35) !important;
	transform: translateY(-1px) !important;
}

.preview-ai-use-saved-btn:active {
	transform: translateY(0);
}

.preview-ai-new-photo-link {
	display: block !important;
	margin: 0.875rem 0 0 !important;
	font-size: 13px !important;
	color: var(--pai-text-secondary) !important;
	text-decoration: underline !important;
	cursor: pointer !important;
	transition: color var(--pai-transition-fast) !important;
}

.preview-ai-new-photo-link:hover {
	color: var(--pai-accent);
}

.preview-ai-saved-photo-privacy {
	margin-top: 1.25rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.4rem;
}

.preview-ai-privacy-info {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--pai-text-secondary);
}

.preview-ai-privacy-icon {
	display: flex;
	color: var(--pai-accent);
}

.preview-ai-saved-photo-privacy p {
	margin: 0 !important;
	font-size: 13px !important;
	color: inherit !important;
}

.preview-ai-forget-link {
	font-size: 11px !important;
	color: var(--pai-text-muted) !important;
	text-decoration: underline !important;
}

.preview-ai-forget-link:hover {
	opacity: 1;
}

/* ─────────────────────────────────────────────────────────────
   Instructions
───────────────────────────────────────────────────────────── */
.preview-ai-instructions {
	text-align: center;
}

.preview-ai-instructions.is-hidden {
	display: none;
}

.preview-ai-instructions-header {
	margin-bottom: 0.75rem;
}

.preview-ai-instructions-header h3 {
	margin: 0 0 0.125rem !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	color: var(--pai-text) !important;
	letter-spacing: -0.02em !important;
}

.preview-ai-instructions-header p {
	margin: 0 !important;
	font-size: 13px !important;
	color: var(--pai-text-secondary) !important;
	line-height: 1.3 !important;
}

.preview-ai-illustration {
	display: flex;
	justify-content: center;
	margin: 0.75rem 0;
	padding: 0.625rem;
	border-radius: var(--pai-radius-md);
	background: var(--pai-bg-soft);
}

.preview-ai-illustration svg {
	width: 72px;
	height: 72px;
}

/* ─────────────────────────────────────────────────────────────
   Example photos (Good/Bad) - auto fade + crop highlight by subtype
───────────────────────────────────────────────────────────── */
.pai-examples {
	position: relative;
	width: 100%;
	max-width: 280px;
	margin: 0 auto;
}

.pai-examples__stage {
	position: relative;
	aspect-ratio: 4 / 3;
	min-height: 160px;
	border-radius: var(--pai-radius-md);
	border: 1px solid var(--pai-border);
	background: #fff;
	overflow: hidden;
	box-shadow: var(--pai-shadow-sm);
}

.pai-example {
	position: absolute;
	inset: 0;
	margin: 0;
	padding: 8px;
	opacity: 0;
	transition: opacity var(--pai-transition-fast);
	will-change: opacity;
}

.pai-example img {
	width: 100% !important;
	height: 100% !important;
	max-width: 100% !important;
	display: block !important;
	object-fit: contain;
	object-position: center;
	background: #fff;
}

/* Fade loop (2 slides) */
.pai-example--good {
	animation: pai-example-good 8s ease-in-out infinite;
}
.pai-example--bad {
	animation: pai-example-bad 8s ease-in-out infinite;
}

@keyframes pai-example-good {
	0% { opacity: 1; }
	45% { opacity: 1; }
	65% { opacity: 0; } /* longer crossfade window */
	100% { opacity: 0; }
}

@keyframes pai-example-bad {
	0% { opacity: 0; }
	45% { opacity: 0; }
	65% { opacity: 1; } /* longer crossfade window */
	96% { opacity: 1; }
	100% { opacity: 0; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
	.pai-example--good,
	.pai-example--bad {
		animation: none;
	}
	.pai-example--good { opacity: 1; }
	.pai-example--bad { opacity: 0; }
}

.pai-examples__label {
	margin-top: 0.5rem !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	color: var(--pai-text) !important;
	text-align: center !important;
	letter-spacing: -0.01em !important;
}

.preview-ai-tips {
	margin: 1.5rem 0;
	padding: 0;
	background: transparent;
	text-align: left;
}

.preview-ai-tips-title {
	margin: 0 0 0.75rem !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	color: var(--pai-text) !important;
	letter-spacing: -0.01em !important;
}

.preview-ai-tips-title::before {
	content: none !important;
}

.preview-ai-tips ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.preview-ai-tips li {
	display: flex !important;
	align-items: flex-start !important;
	gap: 0.75rem !important;
	padding: 0.35rem 0 !important;
	font-size: 14.5px !important;
	line-height: 1.5 !important;
	color: var(--pai-text-secondary) !important;
}

.preview-ai-tips li::before {
	content: "";
	flex-shrink: 0;
	width: 5px;
	height: 5px;
	margin-top: 0.55rem;
	border-radius: 50%;
	background: var(--pai-text-muted);
	opacity: 0.6;
}

.preview-ai-tips-pro {
	margin: 1rem 0 0 !important;
	padding-top: 1rem !important;
	border-top: 1px solid var(--pai-border) !important;
	font-size: 13.5px !important;
	font-style: normal !important;
	color: var(--pai-text-secondary) !important;
	line-height: 1.5 !important;
	opacity: 0.8;
}

/* ─────────────────────────────────────────────────────────────
   Upload Button
───────────────────────────────────────────────────────────── */
label.preview-ai-upload-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
	width: 100% !important;
	height: 48px !important;
	padding: 0 1.5rem !important;
	border: none !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-accent) !important;
	color: #fff !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	box-shadow: var(--pai-shadow-accent) !important;
	transition: all var(--pai-transition-fast) !important;
}

label.preview-ai-upload-btn:hover {
	background: var(--pai-accent-hover) !important;
	box-shadow: 0 4px 16px -2px rgba(99, 102, 241, 0.35) !important;
	transform: translateY(-1px) !important;
}

.preview-ai-upload-btn:active {
	background: #4f52d9;
	box-shadow: var(--pai-shadow-sm);
	transform: translateY(0);
}

.preview-ai-upload-icon {
	font-size: 1.125rem;
}

.preview-ai-file-input {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ─────────────────────────────────────────────────────────────
   Image Stage
───────────────────────────────────────────────────────────── */
.preview-ai-stage {
	display: none;
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 4;
	max-height: 320px;
	border-radius: var(--pai-radius-md);
	overflow: hidden;
	background: var(--pai-bg-soft);
	border: 1px solid var(--pai-border);
}

.preview-ai-stage.is-visible {
	display: block;
	animation: pai-fade-in 0.3s ease-out;
}

.preview-ai-img-before,
.preview-ai-img-after {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	background: var(--pai-bg-soft);
}

.preview-ai-img-before {
	z-index: 1;
}

.preview-ai-img-after {
	z-index: 2;
	opacity: 0;
	transition: opacity 0.5s ease-out;
}

.preview-ai-stage.is-result .preview-ai-img-after {
	opacity: 1;
	cursor: pointer;
}

/* ─────────────────────────────────────────────────────────────
   Loading Overlay
───────────────────────────────────────────────────────────── */
.preview-ai-loading {
	display: none;
	position: absolute;
	inset: 0;
	z-index: 20;
	background: rgba(255, 255, 255, 0.88);
	backdrop-filter: blur(6px);
}

.preview-ai-stage.is-loading .preview-ai-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	animation: pai-fade-in 0.2s ease-out;
}

.preview-ai-loading-shimmer {
	position: absolute;
	inset: 0;
	background: 
		linear-gradient(135deg, transparent 40%, rgba(99, 102, 241, 0.12) 50%, transparent 60%),
		linear-gradient(45deg, transparent 40%, rgba(59, 130, 246, 0.08) 50%, transparent 60%);
	background-size: 400% 400%;
	animation: pai-shimmer 3s ease-in-out infinite;
}

@keyframes pai-shimmer {
	0%, 100% { background-position: 100% 0%; }
	50% { background-position: 0% 100%; }
}

.preview-ai-loading-content {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 1.5rem 2rem;
	background: var(--pai-bg);
	border-radius: var(--pai-radius-md);
	box-shadow: var(--pai-shadow-lg);
	border: 1px solid var(--pai-border);
}

.preview-ai-loading-spinner {
	position: relative;
	width: 40px;
	height: 40px;
}

.preview-ai-loading-spinner::before,
.preview-ai-loading-spinner::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
}

.preview-ai-loading-spinner::before {
	border: 2px solid var(--pai-border);
}

.preview-ai-loading-spinner::after {
	border: 2px solid transparent;
	border-top-color: var(--pai-accent);
	border-right-color: var(--pai-accent);
	animation: pai-spin 0.8s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

/* Loading Steps - Rotating messages */
.preview-ai-loading-steps {
	position: relative;
	height: 1.25rem;
	min-width: 160px;
	text-align: center;
	overflow: hidden;
}

.preview-ai-step {
	position: absolute !important;
	inset: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--pai-text-secondary) !important;
	opacity: 0;
	transform: translateY(8px);
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.preview-ai-step.is-active {
	opacity: 1;
	transform: translateY(0);
}

.preview-ai-step.is-exiting {
	opacity: 0;
	transform: translateY(-8px);
}

/* ─────────────────────────────────────────────────────────────
   Action Buttons
───────────────────────────────────────────────────────────── */
.preview-ai-actions {
	display: none;
	margin-top: 1rem;
}

.preview-ai-actions.is-visible {
	display: block;
}

/* Change photo link */
.preview-ai-change-link {
	display: block !important;
	width: 100% !important;
	margin-bottom: 0.5rem !important;
	padding: 0 !important;
	border: none !important;
	background: none !important;
	font-family: inherit !important;
	font-size: 13px !important;
	color: var(--pai-text-secondary) !important;
	text-align: center !important;
	text-decoration: underline !important;
	cursor: pointer !important;
	transition: color var(--pai-transition-fast) !important;
}

.preview-ai-change-link:hover {
	color: var(--pai-accent);
}

.preview-ai-change-link.is-hidden {
	display: none !important;
}

button.preview-ai-generate {
	width: 100% !important;
	height: 48px !important;
	padding: 0 1.5rem !important;
	border: none !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-primary) !important;
	color: #fff !important;
	font-family: inherit !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	box-shadow: var(--pai-shadow-md) !important;
	transition: all var(--pai-transition-fast) !important;
}

button.preview-ai-generate:hover {
	background: var(--pai-primary-hover) !important;
	box-shadow: var(--pai-shadow-lg) !important;
	transform: translateY(-1px) !important;
}

.preview-ai-generate:active {
	transform: translateY(0);
	box-shadow: var(--pai-shadow-sm);
}

.preview-ai-generate.is-hidden {
	display: none;
}

.preview-ai-generate:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
	box-shadow: var(--pai-shadow-sm);
}

/* Pre-check status (before generate) */
.preview-ai-check-status {
	margin-top: 0.75rem !important;
	font-size: 14px !important;
	line-height: 1.5 !important;
	color: var(--pai-text-secondary) !important;
	min-height: 18px !important; /* prevents layout jump */
}

.preview-ai-check-status.is-ok {
	color: #166534;
}

.preview-ai-check-status.is-warning {
	color: #92400e;
}

.preview-ai-check-status.is-error {
	color: #991b1b;
}

/* Warnings list */
.preview-ai-warnings-list {
	margin: 0.5rem 0 0;
	padding: 0.75rem 1rem;
	list-style: none;
	background: rgba(245, 158, 11, 0.08);
	border-radius: var(--pai-radius-sm);
	border-left: 3px solid currentColor;
}

.preview-ai-warnings-list li {
	position: relative !important;
	padding: 0.25rem 0 0.25rem 1.25rem !important;
	font-size: 14px !important;
	line-height: 1.5 !important;
}

.preview-ai-warnings-list li + li {
	margin-top: 0.25rem;
}

.preview-ai-check-status.is-error .preview-ai-warnings-list {
	background: rgba(239, 68, 68, 0.08);
}

.preview-ai-result-actions {
	display: none;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.preview-ai-result-actions.is-visible {
	display: flex;
	animation: pai-fade-in 0.3s ease-out;
}

button.preview-ai-action-btn,
a.preview-ai-action-btn {
	flex: 1 !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
	height: 40px !important;
	padding: 0 1rem !important;
	border: 1px solid var(--pai-accent-border) !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-bg) !important;
	color: var(--pai-accent) !important;
	font-family: inherit !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	text-decoration: none !important;
	transition: all var(--pai-transition-fast) !important;
}

button.preview-ai-action-btn svg,
a.preview-ai-action-btn svg {
	width: 16px !important;
	height: 16px !important;
	flex-shrink: 0 !important;
}

button.preview-ai-action-btn:hover,
a.preview-ai-action-btn:hover {
	background: var(--pai-accent-soft) !important;
	border-color: var(--pai-accent) !important;
	color: var(--pai-accent) !important;
}

button.preview-ai-action-btn--secondary,
a.preview-ai-action-btn--secondary {
	border-color: var(--pai-border-strong) !important;
	color: var(--pai-text-secondary) !important;
}

button.preview-ai-action-btn--secondary:hover,
a.preview-ai-action-btn--secondary:hover {
	background: var(--pai-bg-soft) !important;
	border-color: var(--pai-text-muted) !important;
	color: var(--pai-text) !important;
}

/* ─────────────────────────────────────────────────────────────
   AI Disclaimer
───────────────────────────────────────────────────────────── */
.preview-ai-disclaimer {
	display: none;
	align-items: flex-start;
	gap: 0.5rem;
	margin-top: 0.75rem;
	padding: 0.75rem 1rem;
	border-radius: var(--pai-radius-sm);
	background: linear-gradient(135deg, #fef9e7 0%, #fef3c7 100%);
	border: 1px solid rgba(245, 158, 11, 0.2);
}

.preview-ai-disclaimer.is-visible {
	display: flex;
	animation: pai-fade-in 0.3s ease-out;
}

.preview-ai-disclaimer-icon {
	flex-shrink: 0;
	font-size: 1rem;
	line-height: 1.5;
}

.preview-ai-disclaimer p {
	margin: 0 !important;
	font-size: 13px !important;
	line-height: 1.5 !important;
	color: #92400e !important;
}

.preview-ai-disclaimer strong {
	font-size: inherit !important;
	font-weight: 600;
	color: #78350f;
}

/* ─────────────────────────────────────────────────────────────
   Error Overlay
───────────────────────────────────────────────────────────── */
.preview-ai-error-overlay {
	position: absolute;
	inset: 0;
	z-index: 25;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.95);
	animation: pai-fade-in 0.2s ease-out;
}

.preview-ai-error-overlay .preview-ai-error-icon {
	font-size: 2.5rem;
	margin-bottom: 0.5rem;
}

.preview-ai-error-overlay p {
	margin: 0 !important;
	font-size: 14px !important;
	color: var(--pai-text-secondary) !important;
	text-align: center !important;
	max-width: 80% !important;
}

/* ─────────────────────────────────────────────────────────────
   Lightbox
───────────────────────────────────────────────────────────── */
.preview-ai-lightbox {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 9999999;
	background: rgba(0, 0, 0, 0.92);
	cursor: pointer;
}

.preview-ai-lightbox.is-open {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.5rem;
	animation: pai-fade-in 0.2s ease-out;
}

.preview-ai-lightbox img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	border-radius: var(--pai-radius-sm);
	box-shadow: 0 0 60px rgba(0, 0, 0, 0.5);
}

/* ─────────────────────────────────────────────────────────────
   Your Previews Section
───────────────────────────────────────────────────────────── */
/* Your Looks button in instructions section */
.preview-ai-instructions-looks-btn {
	display: none !important;
	width: 100% !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
	height: 44px !important;
	margin-top: 0.75rem !important;
	padding: 0 1rem !important;
	border: 1px solid var(--pai-border) !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-bg) !important;
	color: var(--pai-text-secondary) !important;
	font-family: inherit !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	transition: all var(--pai-transition-fast) !important;
	box-shadow: none !important;
}

.preview-ai-instructions-looks-btn.has-looks {
	display: inline-flex !important;
}

.preview-ai-instructions-looks-btn:hover {
	background: var(--pai-bg-soft) !important;
	border-color: var(--pai-text-muted) !important;
	color: var(--pai-text) !important;
}

.preview-ai-instructions-looks-btn svg {
	width: 18px !important;
	height: 18px !important;
	flex-shrink: 0 !important;
}

.preview-ai-view-tryons-btn {
	display: none !important;
	width: 100% !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
	height: 44px !important;
	margin-top: 0.75rem !important;
	padding: 0 1rem !important;
	border: 1px solid var(--pai-border) !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-bg) !important;
	color: var(--pai-text-secondary) !important;
	font-family: inherit !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	transition: all var(--pai-transition-fast) !important;
	box-shadow: none !important;
}

.preview-ai-view-tryons-btn.has-tryons {
	display: inline-flex !important;
}

.preview-ai-view-tryons-btn:hover {
	background: var(--pai-bg-soft) !important;
	border-color: var(--pai-text-muted) !important;
	color: var(--pai-text) !important;
}

.preview-ai-view-tryons-btn svg {
	width: 18px !important;
	height: 18px !important;
	flex-shrink: 0 !important;
}

.preview-ai-tryons-badge {
	display: none;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	border-radius: 10px;
	background: var(--pai-accent);
	color: white;
	font-size: 11px;
	font-weight: 600;
	line-height: 20px;
	text-align: center;
}

.preview-ai-tryons-badge.is-visible {
	display: inline-block;
}

.preview-ai-tryons {
	display: none;
}

.preview-ai-tryons.is-visible {
	display: block;
	animation: pai-fade-in 0.2s ease-out;
}

.preview-ai-tryons-header {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--pai-border);
}

.preview-ai-tryons-back {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 36px !important;
	height: 36px !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	border-radius: 50% !important;
	background: var(--pai-bg-soft) !important;
	color: var(--pai-text-secondary) !important;
	cursor: pointer !important;
	transition: all var(--pai-transition-fast) !important;
	box-shadow: none !important;
}

.preview-ai-tryons-back:hover {
	background: var(--pai-bg) !important;
	color: var(--pai-text) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

.preview-ai-tryons-back svg {
	width: 20px !important;
	height: 20px !important;
}

.preview-ai-tryons-title {
	flex: 1;
}

.preview-ai-tryons-title h3 {
	margin: 0 0 0.125rem 0 !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	color: var(--pai-text) !important;
	line-height: 1.2 !important;
}

.preview-ai-tryons-count {
	display: block;
	font-size: 13px;
	color: var(--pai-text-muted);
}

.preview-ai-tryons-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	max-height: calc(80vh - 80px);
	overflow-y: auto;
	overflow-x: hidden;
	padding-right: 0.25rem;
}

.preview-ai-tryons-list::-webkit-scrollbar {
	width: 4px;
}

.preview-ai-tryons-list::-webkit-scrollbar-track {
	background: transparent;
}

.preview-ai-tryons-list::-webkit-scrollbar-thumb {
	background: var(--pai-border-strong);
	border-radius: 2px;
}

.preview-ai-tryons-empty {
	display: none;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 3rem 1rem;
	text-align: center;
}

.preview-ai-tryons-empty.is-visible {
	display: flex;
}

.preview-ai-tryons-empty-icon {
	font-size: 3rem;
	margin-bottom: 0.75rem;
	opacity: 0.5;
}

.preview-ai-tryons-empty p {
	margin: 0 !important;
	font-size: 14px !important;
	color: var(--pai-text-muted) !important;
}

.preview-ai-powered-by {
	margin-top: 1.5rem;
	padding-top: 1rem;
	border-top: 1px solid var(--pai-border);
	font-size: 11px;
	color: var(--pai-text-muted);
	text-align: center;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.preview-ai-powered-by a {
	color: inherit !important;
	text-decoration: none !important;
	transition: color var(--pai-transition-fast) !important;
}

.preview-ai-powered-by a:hover {
	color: var(--pai-accent) !important;
	text-decoration: underline !important;
}

/* Look Card */
.preview-ai-tryon-card {
	display: block !important;
	position: relative !important;
	border: 1px solid var(--pai-border) !important;
	border-radius: var(--pai-radius-lg) !important;
	background: var(--pai-bg) !important;
	overflow: visible !important;
	transition: box-shadow var(--pai-transition-fast) !important;
}

.preview-ai-tryon-card:hover {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
}

/* Card needs overflow hidden for rounded corners on image */
.preview-ai-tryon-card::after {
	content: '';
	display: block;
	clear: both;
}

.preview-ai-tryon-img-container {
	position: relative !important;
	width: 100% !important;
	aspect-ratio: 3 / 4 !important;
	max-height: 280px !important;
	background: var(--pai-bg-soft) !important;
	overflow: hidden !important;
	border-radius: var(--pai-radius-lg) var(--pai-radius-lg) 0 0 !important;
}

.preview-ai-tryon-img-container > img:first-child {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	cursor: pointer !important;
	transition: transform var(--pai-transition) !important;
}

.preview-ai-tryon-card:hover .preview-ai-tryon-img-container > img:first-child {
	transform: scale(1.02);
}

.preview-ai-tryon-product-thumb {
	position: absolute !important;
	bottom: 0.75rem !important;
	right: 0.75rem !important;
	width: 72px !important;
	height: 72px !important;
	object-fit: cover !important;
	border-radius: var(--pai-radius-sm) !important;
	background: white !important;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15) !important;
	border: 2px solid white !important;
}

.preview-ai-tryon-info {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 0.5rem !important;
	padding: 0.75rem 1rem 0.5rem !important;
}

.preview-ai-tryon-name {
	flex: 1 !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	color: var(--pai-text) !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	white-space: nowrap !important;
}

.preview-ai-tryon-date {
	flex-shrink: 0 !important;
	font-size: 12px !important;
	color: var(--pai-text-muted) !important;
}

.preview-ai-tryon-btns {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 0.5rem !important;
	padding: 0 1rem 1rem !important;
}

button.preview-ai-tryon-btn,
a.preview-ai-tryon-btn {
	flex: 1 !important;
	min-width: calc(50% - 0.25rem) !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.4rem !important;
	height: 38px !important;
	padding: 0 0.75rem !important;
	border: 1px solid var(--pai-border) !important;
	border-radius: var(--pai-radius-full) !important;
	background: var(--pai-bg) !important;
	color: var(--pai-text-secondary) !important;
	font-family: inherit !important;
	font-size: 12px !important;
	font-weight: 500 !important;
	text-decoration: none !important;
	cursor: pointer !important;
	transition: all var(--pai-transition-fast) !important;
}

button.preview-ai-tryon-btn svg,
a.preview-ai-tryon-btn svg {
	width: 14px !important;
	height: 14px !important;
	flex-shrink: 0 !important;
}

button.preview-ai-tryon-btn:hover,
a.preview-ai-tryon-btn:hover {
	background: var(--pai-bg-soft) !important;
	border-color: var(--pai-text-muted) !important;
	color: var(--pai-text) !important;
}

button.preview-ai-tryon-btn--primary,
a.preview-ai-tryon-btn--primary {
	flex: 1 1 100% !important;
	background: var(--pai-accent) !important;
	border-color: var(--pai-accent) !important;
	color: white !important;
}

button.preview-ai-tryon-btn--primary:hover,
a.preview-ai-tryon-btn--primary:hover {
	background: var(--pai-accent-hover) !important;
	border-color: var(--pai-accent-hover) !important;
	color: white !important;
}

.preview-ai-tryon-delete {
	position: absolute !important;
	top: 0.5rem !important;
	right: 0.5rem !important;
	z-index: 5 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 28px !important;
	height: 28px !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	border-radius: 50% !important;
	background: rgba(0, 0, 0, 0.5) !important;
	color: white !important;
	font-size: 18px !important;
	font-weight: 400 !important;
	line-height: 1 !important;
	cursor: pointer !important;
	opacity: 0;
	transition: all var(--pai-transition-fast) !important;
	box-shadow: none !important;
}

.preview-ai-tryon-card:hover .preview-ai-tryon-delete {
	opacity: 1;
}

.preview-ai-tryon-delete:hover {
	background: rgba(239, 68, 68, 0.9) !important;
	transform: scale(1.1) !important;
}

/* Action button tertiary style - full width row below */
button.preview-ai-action-btn--tertiary,
a.preview-ai-action-btn--tertiary {
	flex: 1 1 100% !important;
	width: 100% !important;
	margin-top: 0.5rem !important;
	border-color: var(--pai-border) !important;
	color: var(--pai-text-secondary) !important;
}

button.preview-ai-action-btn--tertiary:hover,
a.preview-ai-action-btn--tertiary:hover {
	background: var(--pai-bg-soft) !important;
	border-color: var(--pai-text-muted) !important;
	color: var(--pai-text) !important;
}

/* ─────────────────────────────────────────────────────────────
   Animations
───────────────────────────────────────────────────────────── */
@keyframes pai-fade-in {
	from { opacity: 0; transform: scale(0.98); }
	to { opacity: 1; transform: scale(1); }
}

@keyframes pai-spin {
	to { transform: rotate(360deg); }
}

/* ─────────────────────────────────────────────────────────────
   Responsive
───────────────────────────────────────────────────────────── */
@media (min-width: 640px) {
	.preview-ai-modal-content { padding: 2rem !important; }
	.preview-ai-instructions-header h3 { font-size: 22px !important; }
	.preview-ai-saved-photo-header h3 { font-size: 22px !important; }
	.preview-ai-stage { max-height: 380px !important; }
	.preview-ai-tryons-title h3 { font-size: 20px !important; }
	.preview-ai-tryon-img-container { max-height: 320px; }
}

@media (min-width: 768px) {
	.preview-ai-modal.is-open { padding: 2rem !important; }
	.preview-ai-modal-content { max-width: 520px !important; }
	.preview-ai-stage { max-height: 460px !important; }
	.preview-ai-tryon-product-thumb { width: 80px; height: 80px; }
	.preview-ai-tryon-img-container { max-height: 360px; }
}
