/* ------------------------------------------------------------------
 * CraftyWorth Customization Engine — premium product page styling
 * Uses design system tokens: --p, --a, --line, --head, --body
 * ------------------------------------------------------------------ */

.cw-engine-wrap {
	position: relative;
	margin: 22px 0;
	padding: 24px 22px 20px;
	background:
		radial-gradient(120% 100% at 0% 0%, rgba(232, 101, 26, 0.06) 0%, transparent 55%),
		linear-gradient(180deg, #fffaf3 0%, #ffffff 100%);
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 18px;
	box-shadow: 0 4px 14px rgba(160, 41, 62, 0.05), 0 1px 2px rgba(160, 41, 62, 0.03);
	overflow: hidden;
}

.cw-engine-wrap::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--p, #A0293E) 0%, var(--a, #E8651A) 50%, var(--p, #A0293E) 100%);
	border-radius: 18px 18px 0 0;
}

.cw-engine-title {
	font-family: var(--head, 'Fraunces', serif);
	font-size: 22px;
	font-weight: 600;
	color: var(--p, #A0293E);
	margin: 0 0 4px;
	letter-spacing: -.01em;
	line-height: 1.2;
}

.cw-engine-wrap::before {
	content: 'Personalisation';
	display: inline-block;
	font-family: var(--body, sans-serif);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--a, #E8651A);
	margin-bottom: 6px;
}

.cw-engine-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px 22px;
	margin-top: 16px;
}

@media (max-width: 720px) {
	.cw-engine-grid { grid-template-columns: 1fr; gap: 14px; }
	.cw-engine-wrap { padding: 18px; }
}

.cw-engine-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	position: relative;
}

.cw-engine-field-image_upload,
.cw-engine-field-file_upload,
.cw-engine-field-textarea {
	grid-column: 1 / -1;
}

.cw-engine-label {
	font-family: var(--body, sans-serif);
	font-size: 13px;
	font-weight: 600;
	color: #2a1f17;
	letter-spacing: .01em;
}

.cw-engine-req {
	color: var(--a, #E8651A);
	font-weight: 700;
	margin-left: 2px;
}

.cw-engine-input {
	width: 100%;
	padding: 10px 12px;
	font-family: var(--body, sans-serif);
	font-size: 14px;
	color: #2a1f17;
	background: #fff;
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 10px;
	transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
	box-sizing: border-box;
	line-height: 1.4;
}

.cw-engine-input:hover {
	border-color: #d8c4b1;
}

.cw-engine-input:focus {
	outline: none;
	border-color: var(--p, #A0293E);
	box-shadow: 0 0 0 4px rgba(160, 41, 62, 0.14);
	animation: cw-engine-ring .35s ease-out;
}

@keyframes cw-engine-ring {
	0%   { box-shadow: 0 0 0 0 rgba(160, 41, 62, 0.30); }
	100% { box-shadow: 0 0 0 4px rgba(160, 41, 62, 0.14); }
}

textarea.cw-engine-input { resize: vertical; min-height: 92px; }

select.cw-engine-input {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23A0293E' d='M5 6 0 0h10z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 34px;
}

/* Upload zone — premium gradient border, animated on drag */
.cw-engine-upload {
	position: relative;
	border: 2px dashed var(--line, #EAD9CC);
	border-radius: 14px;
	background:
		linear-gradient(#fffdf9, #fffdf9) padding-box,
		linear-gradient(135deg, rgba(232, 101, 26, 0.0), rgba(160, 41, 62, 0.0)) border-box;
	padding: 26px 18px;
	text-align: center;
	cursor: pointer;
	transition: border-color .2s ease, background .2s ease, transform .15s ease, box-shadow .2s ease;
}

.cw-engine-upload:hover {
	border-color: var(--a, #E8651A);
	background: #fff6ec;
	box-shadow: 0 2px 10px rgba(232, 101, 26, 0.06);
}

.cw-engine-upload.is-drag {
	border-style: solid;
	border-color: var(--a, #E8651A);
	background: #fff1e0;
	transform: scale(1.005);
	box-shadow: 0 0 0 4px rgba(232, 101, 26, 0.12);
	animation: cw-engine-drag-pulse 1.4s ease-in-out infinite;
}

@keyframes cw-engine-drag-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(232, 101, 26, 0.12); }
	50%      { box-shadow: 0 0 0 8px rgba(232, 101, 26, 0.08); }
}

.cw-engine-upload .cw-engine-file {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

.cw-engine-upload-cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	pointer-events: none;
}

.cw-engine-upload-icon {
	font-size: 28px;
	line-height: 1;
	margin-bottom: 4px;
}

.cw-engine-upload-cta strong {
	font-size: 14px;
	color: #2a1f17;
	font-weight: 600;
}

.cw-engine-upload-cta small {
	font-size: 11px;
	color: #7a6a5a;
}

/* Preview thumbnails */
.cw-engine-preview-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin-top: 12px;
}

@media (max-width: 480px) {
	.cw-engine-preview-grid { grid-template-columns: repeat(2, 1fr); }
}

.cw-engine-preview-grid:empty { display: none; }

.cw-engine-thumb {
	position: relative;
	aspect-ratio: 1 / 1;
	background: #f4ede4 center / cover no-repeat;
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 6px;
}

.cw-engine-thumb-icon { font-size: 28px; }
.cw-engine-thumb-name {
	font-size: 10px;
	color: #5a4a3a;
	text-align: center;
	margin-top: 4px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 100%;
}

.cw-engine-thumb-x {
	position: absolute;
	top: 4px;
	right: 4px;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: rgba(0,0,0,.65);
	color: #fff;
	border: 0;
	font-size: 16px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
}

.cw-engine-thumb-x:hover { background: var(--p, #A0293E); }

/* Swatches */
.cw-engine-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	margin-top: 2px;
}

.cw-engine-swatch {
	position: relative;
	display: inline-flex;
	cursor: pointer;
}

.cw-engine-swatch input { position: absolute; opacity: 0; pointer-events: none; }

.cw-engine-swatch-dot {
	display: block;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	border: 2px solid #fff;
	box-shadow: 0 0 0 1px var(--line, #EAD9CC);
	transition: box-shadow .15s ease, transform .15s ease;
}

.cw-engine-swatch:hover .cw-engine-swatch-dot { transform: scale(1.05); }

.cw-engine-swatch.is-active .cw-engine-swatch-dot {
	box-shadow: 0 0 0 2px var(--p, #A0293E);
	transform: scale(1.08);
}

/* Radio button group */
.cw-engine-radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cw-engine-radio-btn {
	display: inline-flex;
	align-items: center;
	padding: 7px 14px;
	background: #fff;
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 999px;
	font-size: 13px;
	color: #2a1f17;
	cursor: pointer;
	transition: all .15s ease;
}

.cw-engine-radio-btn input { position: absolute; opacity: 0; pointer-events: none; }

.cw-engine-radio-btn:hover { border-color: var(--a, #E8651A); color: var(--a, #E8651A); }

.cw-engine-radio-btn.is-active {
	background: var(--p, #A0293E);
	border-color: var(--p, #A0293E);
	color: #fff;
	box-shadow: 0 2px 6px rgba(160, 41, 62, .18);
}

/* Helper, errors, char count */
.cw-engine-help {
	font-size: 11px;
	color: #7a6a5a;
	margin-top: 2px;
}

.cw-engine-error {
	font-size: 12px;
	color: #b91c1c;
	font-weight: 600;
	min-height: 1em;
	margin-top: 2px;
}

.cw-engine-field.has-error .cw-engine-input,
.cw-engine-field.has-error .cw-engine-upload {
	border-color: #b91c1c;
	box-shadow: 0 0 0 3px rgba(185, 28, 28, .10);
}

.cw-engine-char-count {
	display: inline-block;
	font-size: 11px;
	color: #7a6a5a;
	margin-top: 2px;
	align-self: flex-end;
}

.cw-engine-char-count.is-near  { color: var(--a, #E8651A); font-weight: 600; }
.cw-engine-char-count.is-limit { color: #b91c1c; font-weight: 700; }

/* ── Upload: loading, success fade, file count ─────────────────── */

.cw-engine-thumb {
	transition: transform .2s ease, box-shadow .2s ease, opacity .25s ease;
}
.cw-engine-thumb:hover { box-shadow: 0 4px 12px rgba(160, 41, 62, 0.10); }

.cw-engine-thumb--enter {
	animation: cw-engine-thumb-enter .35s ease-out both;
}

@keyframes cw-engine-thumb-enter {
	from { opacity: 0; transform: scale(.94); }
	to   { opacity: 1; transform: scale(1); }
}

.cw-engine-thumb--loading {
	background: linear-gradient(135deg, #fff6ec 0%, #fffdf9 100%);
	border-color: var(--a, #E8651A);
	color: var(--p, #A0293E);
	min-height: 96px;
	gap: 8px;
	font-size: 11px;
	font-weight: 600;
	cursor: default;
}

.cw-engine-spinner {
	width: 28px;
	height: 28px;
	border: 2.5px solid rgba(232, 101, 26, 0.18);
	border-top-color: var(--a, #E8651A);
	border-radius: 50%;
	animation: cw-engine-spin .85s linear infinite;
}

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

.cw-engine-thumb-meta {
	font-size: 10px;
	color: #6a5a4a;
	margin-top: 2px;
	text-align: center;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cw-engine-thumb--error {
	border-color: #b91c1c;
	background: #fef2f2;
	color: #b91c1c;
	min-height: 96px;
}
.cw-engine-thumb--error .cw-engine-thumb-icon { font-size: 22px; }

.cw-engine-upload-count {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 10px;
	font-size: 11px;
	font-weight: 600;
	color: #5a4a3a;
	background: #fff;
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 999px;
	padding: 4px 10px;
}
.cw-engine-upload-count::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #d1cec9;
}
.cw-engine-upload-count.is-full {
	color: #15803d;
	background: #f0fdf4;
	border-color: #bbf7d0;
}
.cw-engine-upload-count.is-full::before { background: #16a34a; }

/* ── Section heading inside engine wrap ─────────────────────────── */

.cw-engine-subtitle {
	font-size: 12.5px;
	color: #5a4a3a;
	margin: 0 0 12px;
	line-height: 1.5;
}

/* ── Customizable badge on summary (replaces inline-styled div) ── */

.cw-design-studio-badge {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 14px;
	padding: 12px 14px;
	border: 1px solid #ead7bd;
	border-radius: 12px;
	background: linear-gradient(180deg, #fffaf3 0%, #fff7ec 100%);
}

.cw-design-studio-badge__icon {
	flex: 0 0 auto;
	display: grid;
	place-items: center;
	width: 38px;
	height: 38px;
	border-radius: 10px;
	background: linear-gradient(135deg, var(--a, #E8651A) 0%, var(--p, #A0293E) 100%);
	color: #fff;
	box-shadow: 0 2px 6px rgba(232, 101, 26, 0.25);
}

.cw-design-studio-badge__body strong {
	display: block;
	font-size: 14px;
	font-weight: 700;
	color: #2a1f17;
	line-height: 1.25;
}
.cw-design-studio-badge__body p {
	margin: 3px 0 0;
	font-size: 12px;
	color: #7a4a12;
	line-height: 1.4;
}

/* ── How it works (collapsible) ─────────────────────────────────── */

.cw-how-it-works {
	margin: 0 0 16px;
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 12px;
	background: #fff;
	overflow: hidden;
}

.cw-how-it-works__summary {
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 14px;
	cursor: pointer;
	font-family: var(--body, sans-serif);
	font-weight: 600;
	font-size: 13px;
	color: #2a1f17;
	transition: background .15s ease;
}
.cw-how-it-works__summary::-webkit-details-marker { display: none; }
.cw-how-it-works__summary::marker { content: ''; }
.cw-how-it-works__summary:hover { background: #fffaf3; }

.cw-how-it-works__title { letter-spacing: .01em; }

.cw-how-it-works__chev {
	display: inline-flex;
	transition: transform .25s ease;
	color: var(--p, #A0293E);
}
.cw-how-it-works[open] .cw-how-it-works__chev { transform: rotate(180deg); }

.cw-how-it-works__steps {
	list-style: none;
	margin: 0;
	padding: 4px 14px 14px;
	display: grid;
	gap: 10px;
	border-top: 1px dashed var(--line, #EAD9CC);
}
.cw-how-it-works__steps li {
	display: flex;
	gap: 10px;
	align-items: flex-start;
}
.cw-how-it-works__num {
	flex: 0 0 auto;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--p, #A0293E);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	display: grid;
	place-items: center;
	margin-top: 1px;
}
.cw-how-it-works__steps strong {
	display: block;
	font-size: 13px;
	font-weight: 700;
	color: #2a1f17;
	line-height: 1.3;
}
.cw-how-it-works__steps span {
	display: block;
	font-size: 12px;
	color: #6a5a4a;
	margin-top: 1px;
	line-height: 1.45;
}

/* ── Trust row below CTA ────────────────────────────────────────── */

.cw-trust-row {
	list-style: none;
	margin: 12px 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	font-size: 12px;
	color: #5a4a3a;
}
.cw-trust-row li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-weight: 600;
}
.cw-trust-row svg { color: var(--p, #A0293E); flex: 0 0 auto; }

@media (max-width: 480px) {
	.cw-trust-row { gap: 10px; font-size: 11.5px; }
}

/* ── Proof timeline: icon variant ───────────────────────────────── */

.cw-proof-timeline--icons .cw-proof-timeline__item {
	position: relative;
}
.cw-proof-timeline__icon {
	display: grid;
	place-items: center;
	width: 44px;
	height: 44px;
	margin: 0 0 10px;
	border-radius: 12px;
	background: linear-gradient(135deg, #fff7ec 0%, #fffaf3 100%);
	border: 1px solid var(--line, #EAD9CC);
	color: var(--p, #A0293E);
}
.cw-proof-timeline--icons .cw-proof-timeline__item span:first-child:not(.cw-proof-timeline__icon) { display: none; }

/* ── Mobile sticky CTA ──────────────────────────────────────────── */

.cw-sticky-cta {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 9000;
	display: none;
	align-items: center;
	gap: 12px;
	padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
	background: rgba(255, 255, 255, 0.97);
	backdrop-filter: saturate(160%) blur(8px);
	-webkit-backdrop-filter: saturate(160%) blur(8px);
	border-top: 1px solid var(--line, #EAD9CC);
	box-shadow: 0 -4px 18px rgba(160, 41, 62, 0.08);
	transform: translateY(100%);
	transition: transform .28s ease;
}

.cw-sticky-cta.is-visible {
	display: flex;
	transform: translateY(0);
}

.cw-sticky-cta__price {
	flex: 1 1 auto;
	min-width: 0;
	font-family: var(--head, 'Fraunces', serif);
	font-size: 17px;
	font-weight: 700;
	color: var(--p, #A0293E);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.cw-sticky-cta__price .price { font-size: inherit; color: inherit; }
.cw-sticky-cta__price del { color: #9c8a7a; font-size: 0.78em; margin-right: 4px; opacity: .8; }
.cw-sticky-cta__price ins { text-decoration: none; }

.cw-sticky-cta__btn {
	flex: 0 0 auto;
	padding: 12px 22px;
	background: linear-gradient(135deg, var(--p, #A0293E) 0%, #8b1f33 100%);
	color: #fff;
	font-family: var(--body, sans-serif);
	font-size: 14px;
	font-weight: 700;
	border: 0;
	border-radius: 999px;
	cursor: pointer;
	letter-spacing: .02em;
	box-shadow: 0 4px 12px rgba(160, 41, 62, 0.28);
	transition: transform .12s ease, box-shadow .15s ease;
}
.cw-sticky-cta__btn:hover  { box-shadow: 0 6px 16px rgba(160, 41, 62, 0.36); }
.cw-sticky-cta__btn:active { transform: scale(.97); }

/* Only show sticky CTA on mobile */
@media (min-width: 769px) {
	.cw-sticky-cta { display: none !important; }
}

/* ------------------------------------------------------------------
 * P1 — Amazon-style personalization frontend
 * Personalize Header / Step Indicator / Summary / Buy Card / Upload v2
 * ------------------------------------------------------------------ */

/* ── Personalize Header (sits above customization form) ──────────── */
.cw-personalize-header {
	display: flex;
	align-items: center;
	gap: 12px;
	background: linear-gradient(135deg, var(--off, #FEF7F0), #fff);
	border: 1px solid var(--line, #EAD9CC);
	border-left: 3px solid var(--a, #E8651A);
	border-radius: 10px;
	padding: 12px 16px;
	margin-bottom: 16px;
}
.cw-personalize-header__icon {
	font-size: 20px;
	color: var(--a, #E8651A);
	flex-shrink: 0;
	line-height: 1;
}
.cw-personalize-header__text strong {
	display: block;
	font-size: 14px;
	font-weight: 700;
	color: var(--ink, #1A1208);
	line-height: 1.25;
}
.cw-personalize-header__text span {
	font-size: 12px;
	color: var(--ink-3, #7A6458);
}
.cw-personalize-header__step {
	margin-left: auto;
	font-size: 12px;
	font-weight: 600;
	color: var(--ink-3, #7A6458);
	white-space: nowrap;
	transition: color .25s ease;
}
@media (max-width: 520px) {
	.cw-personalize-header { padding: 10px 12px; gap: 10px; }
	.cw-personalize-header__step { display: none; }
}

/* ── Buy Card (premium surface around add-to-cart + trust row) ──── */
.cw-buy-card {
	position: relative;
	padding: 16px 18px 14px;
	margin: 14px 0 14px;
	background: #fff;
	border: 1px solid var(--line, #EAD9CC);
	border-radius: 16px;
	box-shadow: 0 4px 18px rgba(160, 41, 62, 0.06), 0 1px 2px rgba(160, 41, 62, 0.03);
}
.cw-buy-card .cw-product-summary__cart { margin: 0; }
.cw-buy-card .cw-trust-row { margin-top: 14px; }
@media (max-width: 520px) {
	.cw-buy-card { padding: 14px; border-radius: 14px; }
}

/* ── Personalization Summary (live-fills as user types) ─────────── */
.cw-summary {
	background: #f0fdf4;
	border: 1px solid #86efac;
	border-radius: 10px;
	padding: 12px 14px;
	margin-bottom: 12px;
	animation: cw-summary-in .25s ease-out;
}
@keyframes cw-summary-in {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}
.cw-summary__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
	font-size: 12px;
	font-weight: 700;
	color: #166534;
	letter-spacing: .02em;
}
.cw-summary__head > span::before {
	content: '\2726';
	margin-right: 6px;
	color: #16a34a;
}
.cw-summary__head button {
	background: none;
	border: none;
	color: var(--p, #A0293E);
	font-size: 11px;
	font-weight: 700;
	cursor: pointer;
	padding: 0;
	font-family: inherit;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.cw-summary__head button:hover { text-decoration: underline; }
.cw-summary__items { display: flex; flex-direction: column; }
.cw-summary__item {
	display: flex;
	gap: 8px;
	font-size: 12px;
	padding: 4px 0;
	border-bottom: 1px solid rgba(0,0,0,.05);
	align-items: baseline;
}
.cw-summary__item:last-child { border-bottom: none; }
.cw-summary__label {
	color: #64748b;
	flex-shrink: 0;
	min-width: 100px;
	font-weight: 500;
}
.cw-summary__value {
	font-weight: 600;
	color: #1a1208;
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* ── Upload zone v2 — taller, centered, icon ─────────────────────── */
.cw-engine-upload {
	min-height: 140px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 20px 16px;
}
.cw-engine-upload .cw-engine-upload-cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	pointer-events: none;
}
.cw-engine-upload .cw-engine-upload-cta::before {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	margin: 0 auto 8px;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A0293E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpolyline points='21 15 16 10 5 21'/%3E%3C/svg%3E") center/contain no-repeat;
	opacity: .65;
	transition: opacity .2s ease, transform .2s ease;
}
.cw-engine-upload:hover .cw-engine-upload-cta::before {
	opacity: 1;
	transform: scale(1.06);
}
/* Hide the legacy emoji icon if present in markup */
.cw-engine-upload .cw-engine-upload-icon { display: none; }
.cw-engine-upload .cw-engine-upload-cta strong {
	font-size: 15px;
	font-weight: 700;
	color: var(--ink, #1A1208);
}
.cw-engine-upload .cw-engine-upload-cta small {
	font-size: 11.5px;
	color: var(--ink-3, #7A6458);
}
/* When files are present, collapse the empty-state visual */
.cw-engine-upload.has-files {
	min-height: 0;
	padding: 14px;
	text-align: left;
	align-items: stretch;
	justify-content: flex-start;
}
.cw-engine-upload.has-files .cw-engine-upload-cta {
	display: none;
}
.cw-engine-upload.has-files .cw-engine-preview-grid {
	margin-top: 0;
}
/* Animated dashed border on hover */
.cw-engine-upload {
	background-image: none;
}
.cw-engine-upload:hover {
	background-image:
		repeating-linear-gradient(135deg, rgba(232, 101, 26, 0.04) 0 8px, transparent 8px 16px);
}

/* Thumbnail grid v2 — 80x80 rounded */
.cw-engine-preview-grid {
	grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
	gap: 10px;
}
.cw-engine-thumb {
	border-radius: 10px;
	min-height: 80px;
}

/* ── Sticky Buy Panel — desktop ──────────────────────────────────── */
@media (min-width: 900px) {
	.cw-product-summary {
		position: sticky;
		top: 90px;
		align-self: start;
		max-height: calc(100vh - 100px);
		overflow-y: auto;
		overflow-x: hidden;
		scrollbar-width: thin;
		scrollbar-color: var(--line, #EAD9CC) transparent;
		padding-right: 4px;
	}
	.cw-product-summary::-webkit-scrollbar { width: 6px; }
	.cw-product-summary::-webkit-scrollbar-track { background: transparent; }
	.cw-product-summary::-webkit-scrollbar-thumb {
		background: var(--line, #EAD9CC);
		border-radius: 3px;
	}
	.cw-product-summary::-webkit-scrollbar-thumb:hover {
		background: var(--p, #A0293E);
	}
}

/* ── Engine Mobile ── */
@media (max-width:768px){
  .cw-engine-wrap{margin:0;padding:14px;border-radius:10px;}
  .cw-engine-title{font-size:14px;margin-bottom:12px;}
  .cw-engine-grid{grid-template-columns:1fr !important;gap:14px;}
  .cw-engine-field{width:100%;}
  .cw-engine-input,.cw-engine-field input,.cw-engine-field select,.cw-engine-field textarea{font-size:16px !important;width:100% !important;box-sizing:border-box;}
  .cw-engine-upload{min-height:110px;padding:14px;}
  .cw-engine-preview-grid{grid-template-columns:repeat(3,1fr);gap:6px;}
  .cw-engine-thumb{height:68px;}
  .cw-engine-radio-group{flex-wrap:wrap;gap:6px;}
  .cw-engine-radio-btn{flex:1;min-width:calc(50% - 6px);text-align:center;justify-content:center;padding:8px 6px;font-size:12px;}
  .cw-personalize-header{flex-wrap:wrap;padding:10px 12px;gap:6px;}
  .cw-personalize-header__step{width:100%;font-size:11px;margin-left:0;display:block !important;}
  .cw-buy-card{padding:14px !important;}
  .cw-summary{padding:10px 12px;}
}
@media (max-width:420px){
  .cw-engine-preview-grid{grid-template-columns:repeat(2,1fr);}
  .cw-engine-radio-btn{min-width:calc(33% - 4px);font-size:11px;padding:7px 4px;}
}
