/**
 * Wizard Completion Modal
 *
 * @package    SmartCycleDiscounts
 * @subpackage SmartCycleDiscounts/resources/assets/css/wizard/wizard-completion-modal.css
 * @author     Webstepper.io <contact@webstepper.io>
 * @copyright  2025 Webstepper.io
 * @license    GPL-3.0-or-later https://www.gnu.org/licenses/gpl-3.0.html
 * @link       https://webstepper.io/wordpress/plugins/smart-cycle-discounts/
 * @since      1.0.0
 */

/* ===== OVERLAY ===== */
.wsscd-completion-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--wsscd-overlay-heavy);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: var(--wsscd-z-modal);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--wsscd-transition-slow) ease, visibility var(--wsscd-transition-slow) ease;
	padding: var(--wsscd-spacing-xl);
}

.wsscd-completion-overlay.is-active {
	opacity: 1;
	visibility: visible;
}

body.wsscd-completion-active {
	overflow: hidden;
}

/* ===== MODAL CARD ===== */
.wsscd-completion-modal {
	background: linear-gradient(180deg, #f0f6fc 0%, #fff 35%);
	border: var(--wsscd-border-width) solid var(--wsscd-color-border);
	border-radius: var(--wsscd-radius-xxl);
	padding: 32px 28px 24px;
	box-shadow: var(--wsscd-shadow-xl);
	min-width: var(--wsscd-form-field-width-medium);
	max-width: calc(var(--wsscd-form-field-width-medium) + var(--wsscd-spacing-xxxl) * 2);
	width: 100%;
	text-align: center;
	transform: scale(0.96) translateY(var(--wsscd-spacing-base));
	opacity: 0;
	transition: transform var(--wsscd-transition-slower) var(--wsscd-ease-bounce),
		opacity var(--wsscd-transition-slow) ease;
	position: relative;
	overflow: hidden;
}

.wsscd-completion-overlay.is-active .wsscd-completion-modal {
	transform: scale(1) translateY(0);
	opacity: 1;
}

.wsscd-completion-overlay.is-error .wsscd-completion-modal {
	background: var(--wsscd-color-white);
}

.wsscd-completion-overlay.is-error .wsscd-completion-modal::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 30% 30%, var(--wsscd-color-danger-alpha-15) 0%, transparent 50%),
		radial-gradient(circle at 70% 70%, var(--wsscd-color-danger-alpha-15) 0%, transparent 50%);
	pointer-events: none;
	z-index: 0;
}

/* ===== CONTENT WRAPPER ===== */
.wsscd-completion-content {
	position: relative;
	z-index: var(--wsscd-z-base);
}

/* ===== CONFETTI ===== */
.wsscd-completion-confetti {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100%;
	pointer-events: none;
	z-index: 1;
	overflow: hidden;
}

.wsscd-completion-confetti-piece {
	position: absolute;
	opacity: 0;
}

@keyframes wsscd-confetti-fall-1 {
	0% {
		transform: translateY(0) rotate(0deg);
		opacity: 0;
	}
	10% {
		opacity: 0.7;
	}
	100% {
		transform: translateY(80px) rotate(120deg);
		opacity: 0;
	}
}

@keyframes wsscd-confetti-fall-2 {
	0% {
		transform: translateY(0) rotate(25deg);
		opacity: 0;
	}
	10% {
		opacity: 0.6;
	}
	100% {
		transform: translateY(70px) rotate(-90deg);
		opacity: 0;
	}
}

@keyframes wsscd-confetti-fall-3 {
	0% {
		transform: translateY(0) rotate(0deg);
		opacity: 0;
	}
	10% {
		opacity: 0.5;
	}
	100% {
		transform: translateY(90px) rotate(180deg);
		opacity: 0;
	}
}

@keyframes wsscd-title-fade-in {
	from {
		opacity: 0;
		transform: translateY(8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes wsscd-message-fade-in {
	from {
		opacity: 0;
		transform: translateY(6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes wsscd-actions-fade-in {
	from {
		opacity: 0;
		transform: translateY(4px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ===== ICON (Emoji / Error) ===== */
.wsscd-completion-icon-wrapper {
	position: relative;
	width: 48px;
	height: 48px;
	margin: 0 auto 8px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.wsscd-completion-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	opacity: 0;
	transition: opacity var(--wsscd-transition-slow) ease;
}

.wsscd-completion-icon--success {
	font-size: 40px;
	line-height: 1;
}

.wsscd-completion-icon--error {
	font-size: var(--wsscd-icon-display-lg);
	width: var(--wsscd-icon-display-lg);
	height: var(--wsscd-icon-display-lg);
	color: var(--wsscd-color-danger);
	filter: var(--wsscd-filter-drop-shadow-danger);
}

.wsscd-completion-overlay.is-success .wsscd-completion-icon--success {
	opacity: 1;
	animation: wsscd-checkmark-pop 0.6s var(--wsscd-ease-bounce) both;
}

.wsscd-completion-overlay.is-error .wsscd-completion-icon--error {
	opacity: 1;
	animation: wsscd-error-shake 0.6s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
}

/* ===== TITLE ===== */
.wsscd-completion-title {
	font-size: 20px;
	font-weight: 700;
	color: var(--wsscd-color-text);
	margin: 0 0 6px;
	line-height: var(--wsscd-line-height-tight);
	letter-spacing: -0.02em;
}

.wsscd-completion-overlay.is-success .wsscd-completion-title {
	animation: wsscd-title-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1) var(--wsscd-transition-base) both;
}

.wsscd-completion-overlay.is-error .wsscd-completion-title {
	color: var(--wsscd-color-danger);
	animation: wsscd-title-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1) var(--wsscd-transition-base) both;
}

/* ===== CAMPAIGN NAME ===== */
.wsscd-completion-name {
	font-size: 14px;
	color: var(--wsscd-color-text-muted);
	margin: 0 0 4px;
	line-height: var(--wsscd-line-height-relaxed);
}

.wsscd-completion-name strong {
	color: var(--wsscd-color-text);
	font-weight: 600;
}

.wsscd-completion-name:empty {
	display: none;
}

/* ===== MESSAGE ===== */
.wsscd-completion-message {
	font-size: 12px;
	line-height: var(--wsscd-line-height-relaxed);
	color: var(--wsscd-color-text-muted);
	margin: 0 0 20px;
	animation: wsscd-message-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1) var(--wsscd-transition-slow) both;
}

.wsscd-completion-message:empty {
	display: none;
}

.wsscd-completion-overlay.is-error .wsscd-completion-message {
	font-size: var(--wsscd-font-size-large);
	color: var(--wsscd-color-text);
	margin-bottom: var(--wsscd-padding-modal-header);
}

/* ===== STAT PILLS ===== */
.wsscd-completion-pills:empty {
	display: none;
}

.wsscd-completion-pills-inner {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-bottom: 20px;
	flex-wrap: wrap;
	animation: wsscd-message-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.35s both;
}

.wsscd-completion-pill {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 5px 12px;
	background: #f0f6fc;
	border: 1px solid #c5d9ed;
	border-radius: 20px;
	font-size: 12px;
	color: var(--wsscd-color-text);
}

.wsscd-completion-pill strong {
	color: var(--wsscd-color-primary);
	font-weight: 700;
}

/* ===== STOREFRONT PREVIEW ===== */
.wsscd-completion-storefront:empty {
	display: none;
}

.wsscd-completion-storefront-inner {
	background: #f9fafb;
	border: 1px solid #e2e4e7;
	border-radius: 10px;
	padding: 14px;
	margin-bottom: 20px;
	animation: wsscd-actions-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.4s both;
}

.wsscd-completion-storefront__header {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 10px;
}

.wsscd-completion-storefront__label {
	font-size: 11px;
	color: var(--wsscd-color-text-disabled);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 600;
}

.wsscd-completion-storefront__grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 10px;
}

/* ===== PRODUCT CARDS ===== */
.wsscd-completion-product {
	background: #fff;
	border: 1px solid #e8e8e8;
	border-radius: 6px;
	overflow: hidden;
	position: relative;
}

.wsscd-completion-badge {
	position: absolute;
	font-size: 8px;
	font-weight: 700;
	padding: 2px 5px;
	border-radius: 3px;
	letter-spacing: 0.3px;
	z-index: 2;
	line-height: 1.3;
}

.wsscd-completion-badge--top-right {
	top: 5px;
	right: 5px;
}

.wsscd-completion-badge--top-left {
	top: 5px;
	left: 5px;
}

.wsscd-completion-badge--bottom-right {
	bottom: 5px;
	right: 5px;
	top: auto;
}

.wsscd-completion-badge--bottom-left {
	bottom: 5px;
	left: 5px;
	top: auto;
}

.wsscd-completion-product__image {
	height: 56px;
	background: linear-gradient(135deg, #f5f5f5, #ebebeb);
	display: flex;
	align-items: center;
	justify-content: center;
}

.wsscd-completion-product__info {
	padding: 6px 8px;
}

.wsscd-completion-product__name {
	font-size: 10px;
	color: var(--wsscd-color-text);
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.wsscd-completion-product__prices {
	margin-top: 2px;
	display: flex;
	align-items: baseline;
	gap: 4px;
}

.wsscd-completion-product__price-new {
	font-size: 12px;
	font-weight: 700;
	color: var(--wsscd-color-primary);
}

.wsscd-completion-product__price-old {
	font-size: 9px;
	color: var(--wsscd-color-gray-400);
	text-decoration: line-through;
}

/* ===== ACTIONS ===== */
.wsscd-completion-actions {
	position: relative;
	z-index: var(--wsscd-z-base);
	display: flex;
	flex-direction: column;
	gap: 8px;
	animation: wsscd-actions-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.4s both;
}

.wsscd-completion-actions:empty {
	display: none;
}

.wsscd-completion-actions .wsscd-button {
	min-height: var(--wsscd-button-icon-size-large);
	padding: 11px 20px;
	border-radius: var(--wsscd-radius-lg);
	font-weight: var(--wsscd-font-weight-semibold);
	font-size: 14px;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--wsscd-gap-tight);
	width: 100%;
}

.wsscd-completion-actions__secondary {
	display: flex;
	gap: 8px;
}

.wsscd-completion-actions__secondary .wsscd-button {
	flex: 1;
	font-size: 13px;
	padding: 9px 16px;
}

/* Error state: horizontal buttons */
.wsscd-completion-overlay.is-error .wsscd-completion-actions {
	flex-direction: row;
	justify-content: center;
}

.wsscd-completion-overlay.is-error .wsscd-completion-actions .wsscd-button {
	width: auto;
	min-width: calc(var(--wsscd-spacing-xxxl) * 3);
}

/* Edit mode: single centered button */
.wsscd-completion-overlay.is-success:not(.is-create) .wsscd-completion-actions {
	flex-direction: row;
	justify-content: center;
}

.wsscd-completion-overlay.is-success:not(.is-create) .wsscd-completion-actions .wsscd-button {
	width: auto;
	min-width: calc(var(--wsscd-spacing-xxxl) * 3);
}

/* ===== SCREEN READER STATUS ===== */
.wsscd-completion-status {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ===== ERROR BURST ===== */
.wsscd-completion-overlay.is-error .wsscd-completion-modal::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: calc(var(--wsscd-spacing-xxxl) * 3);
	height: calc(var(--wsscd-spacing-xxxl) * 3);
	margin: calc(var(--wsscd-spacing-xxxl) * -1.5) 0 0 calc(var(--wsscd-spacing-xxxl) * -1.5);
	border-radius: var(--wsscd-radius-full);
	pointer-events: none;
	z-index: 0;
	background: radial-gradient(circle, var(--wsscd-color-danger-alpha-15) 0%, transparent 70%);
	animation: wsscd-error-pulse 0.6s ease-out;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 600px) {
	.wsscd-completion-overlay {
		padding: var(--wsscd-spacing-lg);
	}

	.wsscd-completion-modal {
		min-width: 0;
		max-width: 100%;
		padding: 28px 16px 20px;
	}

	.wsscd-completion-icon-wrapper {
		width: 40px;
		height: 40px;
	}

	.wsscd-completion-icon--success {
		font-size: 32px;
	}

	.wsscd-completion-title {
		font-size: 18px;
	}

	.wsscd-completion-storefront__grid {
		grid-template-columns: 1fr 1fr;
	}

	.wsscd-completion-storefront__grid .wsscd-completion-product:last-child {
		display: none;
	}

	.wsscd-completion-actions__secondary {
		flex-direction: column;
	}

	.wsscd-completion-actions .wsscd-button {
		min-width: 0;
	}
}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
	.wsscd-completion-overlay,
	.wsscd-completion-modal,
	.wsscd-completion-icon,
	.wsscd-completion-title,
	.wsscd-completion-message,
	.wsscd-completion-actions,
	.wsscd-completion-pills-inner,
	.wsscd-completion-storefront-inner,
	.wsscd-completion-confetti-piece {
		animation: none !important;
		transition-duration: var(--wsscd-transition-fast) !important;
	}

	.wsscd-completion-overlay.is-active .wsscd-completion-modal {
		transform: scale(1) translateY(0);
	}

	.wsscd-completion-overlay.is-success .wsscd-completion-icon--success,
	.wsscd-completion-overlay.is-error .wsscd-completion-icon--error {
		opacity: 1;
		transform: translate(-50%, -50%);
	}

	.wsscd-completion-confetti-piece {
		display: none !important;
	}

	.wsscd-completion-modal::after {
		display: none !important;
	}
}
