/**
 * Wizard step picker for Promotional Visuals.
 *
 * Sits on the Discounts step. BEM with the wsscd- prefix.
 */

.wsscd-visual-picker {
	margin: 24px 0;
	padding: 20px;
	background: #fff;
	border: 1px solid var(--wsscd-color-border, #dcdcde);
	border-radius: 6px;
}

.wsscd-visual-picker__header {
	margin-bottom: 16px;
}

.wsscd-visual-picker__title {
	margin: 0 0 4px;
	font-size: 16px;
	font-weight: 600;
}

.wsscd-visual-picker__subtitle {
	margin: 0;
	color: var(--wsscd-color-text-muted, #50575e);
	font-size: 13px;
}

.wsscd-visual-picker__subtitle a {
	color: var(--wsscd-color-primary, #2271b1);
}

/* ----------------------------------------------------- Tiles */

.wsscd-visual-picker__tiles {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.wsscd-visual-picker__tile {
	display: flex;
	flex-direction: column;
	background: var(--wsscd-color-bg-subtle, #f6f7f7);
	border: 1px solid var(--wsscd-color-border, #dcdcde);
	border-radius: 6px;
	overflow: hidden;
	transition: border-color 150ms ease;
}

.wsscd-visual-picker__tile--assigned {
	border-color: var(--wsscd-color-primary, #2271b1);
	background: #fff;
}

.wsscd-visual-picker__tile-header {
	padding: 12px 14px 8px;
}

.wsscd-visual-picker__tile-label {
	margin: 0 0 2px;
	font-size: 13px;
	font-weight: 600;
}

.wsscd-visual-picker__tile-hint {
	margin: 0;
	color: var(--wsscd-color-text-muted, #50575e);
	font-size: 11px;
	line-height: 1.4;
}

.wsscd-visual-picker__tile-preview {
	position: relative;
	flex: 1 1 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 80px;
	padding: 12px;
	background: #fff;
	border-top: 1px solid var(--wsscd-color-border, #f0f0f1);
	border-bottom: 1px solid var(--wsscd-color-border, #f0f0f1);
	overflow: hidden;
}

/* Neutralize image_badge's storefront position:absolute so it sits centered
   in the tile instead of escaping to a positioned ancestor. */
.wsscd-visual-picker__tile-preview .wsscd-visual {
	position: relative !important;
	inset: auto !important;
}

.wsscd-visual-picker__tile--assigned .wsscd-visual-picker__tile-preview {
	background: var(--wsscd-color-bg-subtle, #f6f7f7);
}

.wsscd-visual-picker__empty {
	color: var(--wsscd-color-text-muted, #50575e);
	font-size: 12px;
	font-style: italic;
}

.wsscd-visual-picker__tile-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 10px 14px;
}

.wsscd-visual-picker__assigned-name {
	flex: 1 1 auto;
	min-width: 0;
	font-size: 12px;
	color: var(--wsscd-color-text, #1d2327);
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
}

.wsscd-visual-picker__actions {
	display: flex;
	gap: 4px;
	align-items: center;
}

.wsscd-visual-picker__clear {
	color: var(--wsscd-color-danger, #b32d2e) !important;
	font-size: 11px;
}

.wsscd-visual-picker__surface-note {
	display: flex;
	align-items: flex-start;
	gap: var(--wsscd-spacing-sm);
	margin: 14px 0 0;
	padding: var(--wsscd-padding-compact);
	background: var(--wsscd-color-info-alpha-15);
	border: var(--wsscd-border-width) solid var(--wsscd-color-info-alpha-30);
	border-left: var(--wsscd-border-width-accent) solid var(--wsscd-color-info);
	border-radius: var(--wsscd-radius-md);
}

.wsscd-visual-picker__surface-note-icon {
	flex-shrink: 0;
	display: inline-flex;
	margin-top: 1px;
	color: var(--wsscd-color-info-dark);
}

.wsscd-visual-picker__surface-note-text {
	flex: 1 1 auto;
	color: var(--wsscd-color-text);
	font-size: var(--wsscd-font-size-small);
	line-height: var(--wsscd-line-height-base);
}

/* -------------------------------------------------- Modal */

.wsscd-visual-picker-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
}

.wsscd-visual-picker-modal[hidden] {
	display: none;
}

.wsscd-visual-picker-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
}

.wsscd-visual-picker-modal__panel {
	position: relative;
	display: flex;
	flex-direction: column;
	width: min(720px, 92vw);
	max-height: 80vh;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.30);
	overflow: hidden;
}

.wsscd-visual-picker-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 18px;
	border-bottom: 1px solid var(--wsscd-color-border, #dcdcde);
}

.wsscd-visual-picker-modal__title {
	margin: 0;
	font-size: 16px;
	font-weight: 600;
}

.wsscd-visual-picker-modal__target {
	margin-left: 6px;
	color: var(--wsscd-color-text-muted, #50575e);
	font-weight: 400;
	font-size: 13px;
}

.wsscd-visual-picker-modal__close {
	width: 32px;
	height: 32px;
	background: transparent;
	border: none;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	color: var(--wsscd-color-text-muted, #50575e);
}

.wsscd-visual-picker-modal__filters {
	padding: 12px 18px;
	border-bottom: 1px solid var(--wsscd-color-border, #f0f0f1);
}

.wsscd-visual-picker-modal__filters input {
	width: 100%;
	height: 34px;
	padding: 0 10px;
}

.wsscd-visual-picker-modal__grid {
	flex: 1 1 auto;
	overflow-y: auto;
	padding: 16px 18px;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 12px;
}

.wsscd-visual-picker-modal__loading {
	grid-column: 1 / -1;
	margin: 0;
	padding: 30px 0;
	text-align: center;
	color: var(--wsscd-color-text-muted, #50575e);
	font-style: italic;
}

.wsscd-visual-picker-modal__empty {
	grid-column: 1 / -1;
	padding: 40px 20px;
	background: var(--wsscd-color-bg-subtle, #f6f7f7);
	border: 1px dashed var(--wsscd-color-border, #c3c4c7);
	border-radius: 6px;
	text-align: center;
	color: var(--wsscd-color-text-muted, #50575e);
}

.wsscd-visual-picker-modal__option {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 10px;
	background: var(--wsscd-color-bg-subtle, #f6f7f7);
	border: 2px solid transparent;
	border-radius: 6px;
	cursor: pointer;
	transition: border-color 150ms ease;
}

.wsscd-visual-picker-modal__option:hover {
	border-color: var(--wsscd-color-border, #c3c4c7);
}

.wsscd-visual-picker-modal__option--selected,
.wsscd-visual-picker-modal__option--selected:hover {
	border-color: var(--wsscd-color-primary, #2271b1);
	background: #fff;
}

.wsscd-visual-picker-modal__option--last-used {
	position: relative;
}

.wsscd-visual-picker-modal__option--last-used::before {
	/* Label comes from the data attribute the JS sets from a localized string,
	   so the badge translates (CSS content strings can't run through __()). */
	content: attr(data-last-used-label);
	position: absolute;
	top: 6px;
	right: 6px;
	padding: 1px 6px;
	background: var(--wsscd-color-primary, #2271b1);
	color: #fff;
	border-radius: 999px;
	font-size: 9px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.wsscd-visual-picker-modal__option-preview {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 60px;
	padding: 8px;
	background: #fff;
	border-radius: 4px;
	overflow: hidden;
}

/* Neutralize image_badge's storefront position:absolute so the rendered
   preview sits centered in the option cell instead of escaping to the
   modal panel (the nearest positioned ancestor). Mirrors the tile fix. */
.wsscd-visual-picker-modal__option-preview .wsscd-visual {
	position: relative !important;
	inset: auto !important;
}

.wsscd-visual-picker-modal__option-name {
	font-size: 12px;
	font-weight: 500;
	text-align: center;
}

.wsscd-visual-picker-modal__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 18px;
	border-top: 1px solid var(--wsscd-color-border, #dcdcde);
	background: var(--wsscd-color-bg-subtle, #f6f7f7);
}

.wsscd-visual-picker-modal__selection {
	flex: 1 1 auto;
	color: var(--wsscd-color-text-muted, #50575e);
	font-size: 13px;
}

.wsscd-visual-picker-modal__actions {
	display: flex;
	gap: 8px;
}
