/* Directwoo — futuristic storefront form. */

.directwoo-form-wrap {
	--directwoo-glow: color-mix(in srgb, var(--directwoo-button, #18181b) 45%, transparent);
	position: relative;
	background: var(--directwoo-bg, #fff);
	color: var(--directwoo-text, #262626);
	border: 1px solid var(--directwoo-field-border, #e5e7eb);
	border-radius: calc(var(--directwoo-radius, 0.75rem) + 4px);
	padding: 26px 24px;
	margin: 24px 0;
	max-width: 100%;
	width: 100%;
	box-sizing: border-box;
	font-family: var(--directwoo-font, Inter, sans-serif);
	box-shadow: 0 10px 40px -12px rgba(17, 12, 4, 0.18), 0 2px 6px rgba(17, 12, 4, 0.05);
	overflow: hidden;
	isolation: isolate;
}

/* Animated gradient top accent bar */
.directwoo-form-wrap::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, var(--directwoo-button, #18181b), var(--directwoo-offer, #18181b), var(--directwoo-button, #18181b));
	background-size: 200% 100%;
	animation: directwoo-sheen 4s linear infinite;
	z-index: 2;
}
@keyframes directwoo-sheen { to { background-position: 200% 0; } }

.directwoo-rtl { direction: rtl; text-align: right; }

.directwoo-form-wrap .directwoo-form-title {
	margin: 0 0 20px !important;
	padding: 0 !important;
	font-family: var(--directwoo-font, inherit) !important;
	font-size: 21px !important;
	font-weight: 800 !important;
	letter-spacing: -0.01em !important;
	text-align: center !important;
	color: var(--directwoo-text, #18181b) !important;
	background: none !important;
	-webkit-text-fill-color: var(--directwoo-text, #18181b) !important;
	text-transform: none !important;
	line-height: 1.3 !important;
}

/* ---------- Offers (quantity upsell) ---------- */
.directwoo-offers {
	--directwoo-off-accent: var(--directwoo-offer, #1e3a8a);
	--directwoo-off-bg: #eff6ff;
	--directwoo-off-border: #d1d5db;
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 22px;
}
/* Classic & Modern = stacked full-width rows; Vertical = cards side by side. */
.directwoo-offers-vertical { flex-direction: row; align-items: stretch; gap: 8px; }

.directwoo-offer {
	position: relative;
	display: flex;
	align-items: center;
	gap: 10px;
	border: 1.5px solid var(--directwoo-off-unsel-border, var(--directwoo-off-border, #d1d5db));
	border-radius: var(--directwoo-off-radius, 12px);
	padding: 10px 13px;
	cursor: pointer;
	background: var(--directwoo-off-unsel-bg, #fff);
}
.directwoo-offer:hover { border-color: var(--directwoo-off-accent); }
.directwoo-offer input { position: absolute; opacity: 0; pointer-events: none; }
.directwoo-offer:has(input:checked) {
	border-color: var(--directwoo-off-accent);
	background: var(--directwoo-off-bg, #eff6ff);
	box-shadow: inset 0 0 0 1px var(--directwoo-off-accent);
}
.directwoo-offer-radio {
	flex: 0 0 auto;
	width: 20px; height: 20px;
	border-radius: 50%;
	border: 2px solid var(--directwoo-off-unsel-border, #cbd5e1);
	position: relative;
}
.directwoo-offer:has(input:checked) .directwoo-offer-radio { border-color: var(--directwoo-off-accent); }
.directwoo-offer:has(input:checked) .directwoo-offer-radio::after {
	content: ""; position: absolute; inset: 3px; border-radius: 50%; background: var(--directwoo-off-accent);
}
.directwoo-offer-img { flex: 0 0 auto; }
.directwoo-offer-img img { width: 46px; height: 46px; object-fit: contain; border-radius: 8px; }
.directwoo-offer-title { font-weight: 800; font-size: var(--directwoo-off-title-size, 15px); color: var(--directwoo-text, #18181b); }
.directwoo-offer-badge {
	background: var(--directwoo-off-badge-bg, var(--directwoo-off-accent));
	color: var(--directwoo-off-badge-color, #fff);
	font-size: var(--directwoo-off-badge-size, 11px);
	font-weight: 700;
	padding: 3px 9px;
	border-radius: 6px;
	white-space: nowrap;
}
.directwoo-offer-prices { display: flex; flex-direction: column; gap: 2px; }
.directwoo-offer-price { font-weight: 800; font-size: var(--directwoo-off-price-size, 16px); color: var(--directwoo-text, #18181b); font-variant-numeric: tabular-nums; }
.directwoo-offer-compare { font-size: 13px; color: var(--directwoo-muted, #9ca3af); text-decoration: line-through; font-variant-numeric: tabular-nums; }
.directwoo-offer-pop {
	position: absolute;
	top: 0; inset-inline-start: 0; inset-inline-end: 0;
	background: var(--directwoo-off-accent);
	color: #fff;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: .02em;
	padding: 3px 6px;
	text-align: center;
	text-transform: uppercase;
	border-radius: calc(var(--directwoo-off-radius, 12px) - 2px) calc(var(--directwoo-off-radius, 12px) - 2px) 0 0;
}
.directwoo-offer-popular { border-color: var(--directwoo-off-accent); }

/* --- Classic & Modern: stacked full-width rows (radio · (img) · title+badge · prices) --- */
.directwoo-offers-classic .directwoo-offer-title,
.directwoo-offers-modern .directwoo-offer-title { flex: 1; }
.directwoo-offers-classic .directwoo-offer-prices,
.directwoo-offers-modern .directwoo-offer-prices { align-items: flex-end; }
.directwoo-offers-modern .directwoo-offer-img { display: none; } /* Modern = no image */
/* "Most popular" as a top-corner tag on the rows. */
.directwoo-offers-classic .directwoo-offer-popular,
.directwoo-offers-modern .directwoo-offer-popular { padding-top: 22px; }
.directwoo-offers-classic .directwoo-offer-pop,
.directwoo-offers-modern .directwoo-offer-pop { inset-inline-start: auto; width: auto; border-radius: 0 0 0 8px; }

/* --- Vertical: cards side by side, centred (image top · title · prices) --- */
.directwoo-offers-vertical .directwoo-offer {
	flex: 1 1 0;
	min-width: 0;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 8px;
	padding: 14px 8px 12px;
}
.directwoo-offers-vertical .directwoo-offer.directwoo-offer-popular { padding-top: 24px; }
.directwoo-offers-vertical .directwoo-offer-img img { width: 60px; height: 60px; }
.directwoo-offers-vertical .directwoo-offer-prices { align-items: center; }
.directwoo-offers-vertical .directwoo-offer-badge { width: 100%; box-sizing: border-box; }

/* Vertical cards stack on narrow phones so they don't get crushed. */
@media (max-width: 560px) {
	.directwoo-offers-vertical { flex-direction: column; }
	.directwoo-offers-vertical .directwoo-offer { flex-direction: row; text-align: start; }
	.directwoo-offers-vertical .directwoo-offer-title { flex: 1; }
	.directwoo-offers-vertical .directwoo-offer-prices { align-items: flex-end; }
	.directwoo-offers-vertical .directwoo-offer-badge { width: auto; }
}

/* ---------- Per-unit variation pickers embedded in the offer cards ---------- */
.directwoo-offer { flex-wrap: wrap; }
.directwoo-offer-attrs {
	flex: 0 0 100%;
	width: 100%;
	display: none;
	flex-direction: column;
	gap: 10px;
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px dashed var(--directwoo-off-border, #d1d5db);
	text-align: start;
}
.directwoo-offer:has(input:checked) .directwoo-offer-attrs { display: flex; }
.directwoo-unit { display: flex; align-items: flex-end; gap: 10px; }
.directwoo-unit-num {
	flex: 0 0 auto;
	align-self: center;
	min-width: 30px;
	height: 30px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 7px;
	border-radius: 7px;
	background: var(--directwoo-off-accent, #2563eb);
	color: #fff;
	font-weight: 800;
	font-size: 12px;
	font-variant-numeric: tabular-nums;
}
.directwoo-unit-fields { display: flex; gap: 10px; flex: 1; min-width: 0; }
.directwoo-uf { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 0; }
.directwoo-uf-label { font-size: 12px; font-weight: 700; color: var(--directwoo-text, #18181b); }
.directwoo-uattr {
	width: 100%;
	height: 42px;
	padding: 0 10px;
	border: 1.5px solid var(--directwoo-field-border, #e4e4e7);
	border-radius: var(--directwoo-input-radius, 10px);
	background: var(--directwoo-field-bg, #fff);
	color: var(--directwoo-text, #18181b);
	font-size: 14px;
	cursor: pointer;
}
.directwoo-uattr.directwoo-invalid { border-color: #ef4444; }
/* Phone: keep the pickers on one row (3 across), just tighter. */
@media (max-width: 480px) {
	.directwoo-unit { gap: 7px; }
	.directwoo-unit-fields { gap: 6px; }
	.directwoo-unit-num { min-width: 26px; height: 26px; }
	.directwoo-uattr { height: 38px; padding: 0 6px; font-size: 13px; }
	.directwoo-uf-label { font-size: 11px; }
}

/* ---------- Fields ---------- */
.directwoo-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; }
.directwoo-field.directwoo-full { grid-column: 1 / -1; }
.directwoo-field.directwoo-half { grid-column: span 1; }
.directwoo-field label {
	display: block;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var(--directwoo-muted, #6b7280);
	margin-bottom: 5px;
}
.directwoo-req { color: var(--destructive, #ef4444); }

.directwoo-input-wrap { position: relative; display: flex; align-items: center; }
.directwoo-icon {
	position: absolute;
	inset-inline-start: 14px;
	display: flex;
	pointer-events: none;
	color: var(--directwoo-muted, #9ca3af);
	transition: color .18s, transform .18s;
}
.directwoo-icon svg { width: 18px; height: 18px; }

/* High specificity + !important so themes (Astra, etc.) cannot override our fields. */
.directwoo-form-wrap .directwoo-field input,
.directwoo-form-wrap .directwoo-field select,
.directwoo-form-wrap .directwoo-field textarea {
	width: 100%;
	box-sizing: border-box;
	padding: 12px 14px 12px 44px;
	border: 1.5px solid var(--directwoo-field-border, #e5e7eb) !important;
	border-radius: var(--directwoo-input-radius, 12px) !important;
	background: var(--directwoo-field-bg, #f9fafb) !important;
	background-color: var(--directwoo-field-bg, #f9fafb) !important;
	color: var(--directwoo-text, #262626);
	font-family: inherit;
	font-size: 15px;
	line-height: 1.4;
	transition: border-color .18s, box-shadow .18s, background .18s;
	appearance: none;
	-webkit-appearance: none;
}
.directwoo-rtl .directwoo-field input,
.directwoo-rtl .directwoo-field select,
.directwoo-rtl .directwoo-field textarea { padding: 14px 44px 14px 14px; }

/* Phone number reads LTR but aligns to the same side as other fields */
.directwoo-field input[type="tel"] { direction: ltr; text-align: left; }
.directwoo-rtl .directwoo-field input[type="tel"] { text-align: right; }

.directwoo-field textarea { min-height: 90px; resize: vertical; }

.directwoo-form-wrap .directwoo-field input:focus,
.directwoo-form-wrap .directwoo-field select:focus,
.directwoo-form-wrap .directwoo-field textarea:focus {
	outline: none;
	border-color: var(--directwoo-button, #18181b) !important;
	background: var(--directwoo-bg, #fff) !important;
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--directwoo-button, #18181b) 20%, transparent) !important;
}
.directwoo-input-wrap:focus-within .directwoo-icon { color: var(--directwoo-button, #18181b); transform: scale(1.08); }
.directwoo-invalid { border-color: var(--destructive, #ef4444) !important; }

/* Clickable attribute pills (text) */
.directwoo-attr-field .directwoo-swatches { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 2px; }
.directwoo-attr-field .directwoo-swatch {
	min-width: 36px;
	height: 36px;
	padding: 0 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1.5px solid var(--directwoo-field-border, #e4e4e7);
	border-radius: 8px;
	background: #fff;
	color: var(--directwoo-text, #18181b);
	font-weight: 600;
	font-size: 13px;
	cursor: pointer;
	transition: border-color .15s, box-shadow .15s, transform .08s;
}
.directwoo-attr-field .directwoo-swatch:hover { border-color: var(--directwoo-text, #18181b); }
.directwoo-attr-field .directwoo-swatch:active { transform: scale(.95); }
.directwoo-attr-field .directwoo-swatch.is-active {
	border-color: var(--directwoo-text, #18181b);
	box-shadow: 0 0 0 1.5px var(--directwoo-text, #18181b);
}

/* Colour swatches: a filled colour chip, rounded like the size pills (name = tooltip / aria-label). */
.directwoo-attr-field .directwoo-swatch-color {
	width: 40px;
	min-width: 20px;
	height: 30px;
	padding: 0;
	border: 0;
	border-radius: 7px;
	background: var(--directwoo-sw, #ccc) !important;
	box-shadow: inset 0 0 0 1.5px rgba(0, 0, 0, .15);
	font-size: 0;
	overflow: hidden;
}
/* Keep the real colour on hover (the theme tries to repaint buttons white/grey) — only a slight zoom. */
.directwoo-attr-field .directwoo-swatch-color:hover {
	background: var(--directwoo-sw, #ccc) !important;
	background-color: var(--directwoo-sw, #ccc) !important;
	transform: scale(1.08);
}
.directwoo-attr-field .directwoo-swatch-color.is-active {
	box-shadow: inset 0 0 0 1.5px rgba(0, 0, 0, .15), 0 0 0 2px var(--directwoo-bg, #fff), 0 0 0 4px var(--directwoo-text, #18181b);
}

/* Image swatches: the thumbnail only (name = tooltip / aria-label). */
.directwoo-attr-field .directwoo-swatch-image {
	width: auto;
	min-width: 0;
	height: auto;
	padding: 3px;
	border-radius: 10px;
	overflow: hidden;
}
.directwoo-attr-field .directwoo-swatch-image img {
	width: 48px;
	height: 48px;
	object-fit: cover;
	border-radius: 7px;
	display: block;
}

/* Honeypot */
.directwoo-hp { position: absolute !important; left: -9999px !important; height: 0; width: 0; opacity: 0; }

/* ---------- Submit ---------- */
.directwoo-submit {
	position: relative;
	width: 100%;
	margin-top: 14px;
	padding: 15px;
	border: 0;
	border-radius: var(--directwoo-radius, 0.75rem);
	background: linear-gradient(135deg, var(--directwoo-button, #18181b), color-mix(in srgb, var(--directwoo-button, #18181b) 60%, #18181b));
	color: var(--directwoo-button-text, #1a1206);
	font-size: 16px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .04em;
	cursor: pointer;
	overflow: hidden;
	box-shadow: 0 10px 30px -10px var(--directwoo-glow);
	transition: transform .08s, box-shadow .2s, filter .2s;
}
.directwoo-submit::after {
	content: "";
	position: absolute;
	top: 0;
	left: -120%;
	width: 60%;
	height: 100%;
	background: linear-gradient(120deg, transparent, rgba(255,255,255,.55), transparent);
	transform: skewX(-20deg);
	transition: left .6s ease;
}
.directwoo-submit:hover { box-shadow: 0 14px 38px -10px var(--directwoo-glow); filter: brightness(1.04); }
.directwoo-submit:hover::after { left: 130%; }
.directwoo-submit:active { transform: translateY(1px); }
.directwoo-submit[disabled] { opacity: .65; cursor: progress; }

/* Force button look over the theme (WoodMart, Astra, etc.) — same on every theme. */
.directwoo-form-wrap button.directwoo-submit {
	background: linear-gradient(135deg, var(--directwoo-button, #18181b), color-mix(in srgb, var(--directwoo-button, #18181b) 75%, #000)) !important;
	color: var(--directwoo-button-text, #fff) !important;
	border: 0 !important;
	border-radius: var(--directwoo-radius, 0.5rem) !important;
	font-family: var(--directwoo-font, inherit) !important;
	font-size: 16px !important;
	font-weight: 800 !important;
	letter-spacing: .04em !important;
	text-transform: uppercase !important;
	text-shadow: none !important;
	height: auto !important;
	line-height: 1.2 !important;
	width: 100% !important;
}
.directwoo-form-wrap .directwoo-add-cart {
	background: transparent !important;
	color: var(--directwoo-button, #18181b) !important;
	border: 1.5px solid var(--directwoo-button, #18181b) !important;
	border-radius: 999px !important;
	font-family: var(--directwoo-font, inherit) !important;
	font-weight: 800 !important;
	font-size: 14px !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	cursor: pointer;
	height: 40px !important;
	width: auto !important;
	white-space: nowrap !important;
}
.directwoo-form-wrap .directwoo-whatsapp {
	background: #25d366 !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: var(--directwoo-radius, 0.5rem) !important;
	font-family: var(--directwoo-font, inherit) !important;
	font-weight: 700 !important;
}
/* Force consistent typography for the whole form regardless of theme. */
.directwoo-form-wrap .directwoo-field label,
.directwoo-form-wrap .directwoo-field input,
.directwoo-form-wrap .directwoo-field select,
.directwoo-form-wrap .directwoo-field textarea,
.directwoo-form-wrap .directwoo-swatch { font-family: var(--directwoo-font, inherit) !important; }

/* WhatsApp order button */
.directwoo-whatsapp {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	margin-top: 10px;
	padding: 13px;
	border-radius: var(--directwoo-radius, 0.5rem);
	background: #25d366;
	color: #fff !important;
	font-size: 15px;
	font-weight: 700;
	text-decoration: none;
	box-shadow: 0 6px 18px -8px rgba(37, 211, 102, .7);
	transition: filter .15s, transform .08s;
}
.directwoo-whatsapp:hover { filter: brightness(1.05); color: #fff; }
.directwoo-whatsapp:active { transform: translateY(1px); }

.directwoo-message { margin-top: 0; font-size: 14px; min-height: 0; font-weight: 600; }
.directwoo-message:not(:empty) { margin-top: 12px; }
.directwoo-message.directwoo-error { color: var(--destructive, #ef4444); }
.directwoo-message.directwoo-success { color: #18181b; }

/* Order summary (collapsible) */
.directwoo-summary {
	margin-top: 16px;
	border: 1px solid var(--directwoo-field-border, #e5e7eb);
	border-radius: var(--directwoo-input-radius, 12px);
	background: var(--directwoo-field-bg, #f9fafb);
	font-size: 14px;
	overflow: hidden;
}
.directwoo-summary-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	padding: 13px 16px;
	cursor: pointer;
	font-weight: 700;
	color: var(--directwoo-text, #374151);
	list-style: none;
	user-select: none;
}
.directwoo-summary-head::-webkit-details-marker { display: none; }
.directwoo-summary-title { display: inline-flex; align-items: center; gap: 8px; }
.directwoo-summary-chevron { transition: transform .2s; color: var(--directwoo-muted, #9ca3af); }
.directwoo-summary[open] .directwoo-summary-chevron { transform: rotate(180deg); }
.directwoo-summary-head .directwoo-sum-total { font-variant-numeric: tabular-nums; color: var(--directwoo-offer, #18181b); }
.directwoo-summary-body { padding: 0 16px 14px; }
.directwoo-sum-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; color: var(--directwoo-text, #374151); }
.directwoo-sum-row span:last-child { font-variant-numeric: tabular-nums; }
.directwoo-sum-total-row {
	margin-top: 6px;
	padding-top: 10px;
	border-top: 1px dashed var(--directwoo-field-border, #e5e7eb);
	font-weight: 800;
	font-size: 16px;
}
.directwoo-sum-total-row .directwoo-sum-total { color: var(--directwoo-offer, #18181b); }
.directwoo-summary .amount, .directwoo-summary bdi { font-variant-numeric: tabular-nums; }

/* ---------- OU divider + cart row ---------- */
.directwoo-or {
	display: flex;
	align-items: center;
	gap: 14px;
	margin: 14px 0 12px;
	color: var(--directwoo-muted, #9ca3af);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .15em;
}
.directwoo-or::before, .directwoo-or::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--directwoo-field-border, #e5e7eb), transparent);
}
.directwoo-cart-row { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
.directwoo-qty {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	border: 1.5px solid var(--directwoo-field-border, #e5e7eb);
	border-radius: 999px;
	overflow: hidden;
	background: var(--directwoo-field-bg, #f9fafb);
}
.directwoo-qty button {
	width: 30px; height: 32px;
	border: 0; background: transparent;
	font-size: 16px; font-weight: 700; cursor: pointer;
	color: var(--directwoo-text, #374151);
	transition: background .15s, transform .08s;
}
.directwoo-qty button:active { transform: scale(.92); }
.directwoo-qty button:hover { background: color-mix(in srgb, var(--directwoo-button, #18181b) 18%, transparent); }
.directwoo-qty input {
	width: 32px; height: 32px; text-align: center;
	border: 0; background: transparent;
	font-size: 15px; font-weight: 700; color: var(--directwoo-text, #262626);
	-moz-appearance: textfield;
}
.directwoo-qty input::-webkit-outer-spin-button,
.directwoo-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.directwoo-add-cart {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 40px;
	min-width: 0;
	white-space: nowrap;
	border-radius: 999px;
	border: 1.5px solid var(--directwoo-button, #18181b);
	background: transparent;
	color: var(--directwoo-button, #18181b);
	font-weight: 800;
	font-size: 14px;
	text-transform: none;
	letter-spacing: 0;
	text-decoration: none;
	transition: background .18s, color .18s, transform .08s;
}
.directwoo-add-cart:hover {
	background: color-mix(in srgb, var(--directwoo-button, #18181b) 12%, transparent);
	color: var(--directwoo-offer, #18181b);
}
.directwoo-add-cart:active { transform: translateY(1px); }

/* Lock our button backgrounds on hover so the theme's `:hover { background-color }` can't recolour them. */
.directwoo-form-wrap button.directwoo-submit:hover,
.directwoo-form-wrap .directwoo-coupon-apply:hover { filter: brightness(1.05); }
.directwoo-form-wrap .directwoo-whatsapp:hover { background-color: #25d366 !important; }
.directwoo-form-wrap .directwoo-add-cart:hover { background-color: color-mix(in srgb, var(--directwoo-button, #2563eb) 12%, transparent) !important; }
.directwoo-form-wrap .directwoo-qty button:hover { background-color: color-mix(in srgb, var(--directwoo-button, #2563eb) 16%, transparent) !important; }
.directwoo-sticky .directwoo-sticky-btn:hover { filter: brightness(1.05); }

/* ---------- Free-shipping badge ---------- */
.directwoo-free-ship {
	display: flex;
	align-items: center;
	gap: 6px;
	width: fit-content;
	max-width: 100%;
	margin: -6px auto 16px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(22, 163, 74, .1);
	color: #16a34a;
	font-size: 13px;
	font-weight: 700;
}
.directwoo-free-ship svg { flex: 0 0 auto; }

/* ---------- Coupon field ---------- */
.directwoo-coupon { margin-top: 12px; }

/* ---------- Action buttons (Order + WhatsApp) ---------- */
/* Order button + quantity selector on one row; WhatsApp full-width below it. */
.directwoo-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.directwoo-actions .directwoo-submit, .directwoo-actions .directwoo-whatsapp { margin-top: 0; }
.directwoo-order-row { display: flex; align-items: stretch; gap: 10px; }
.directwoo-order-row .directwoo-submit { flex: 1 1 0; min-width: 0; }
.directwoo-order-qty { flex: 0 0 auto; }
/* The beside-button stepper stretches to the order button's height. */
.directwoo-order-qty.directwoo-qty { align-self: stretch; }
.directwoo-order-qty.directwoo-qty button { height: 100%; }
.directwoo-order-qty.directwoo-qty input { height: 100%; }

/* ---------- Coupon ---------- */
.directwoo-coupon-row { display: flex; gap: 8px; align-items: stretch; }
.directwoo-coupon-row .directwoo-input-wrap { flex: 1 1 auto; }
.directwoo-coupon-apply {
	flex: 0 0 auto;
	padding: 0 18px;
	border: 0;
	border-radius: var(--directwoo-input-radius, 12px);
	font-family: var(--directwoo-font, inherit);
	font-weight: 800;
	font-size: 14px;
	cursor: pointer;
	white-space: nowrap;
}
.directwoo-coupon-apply[disabled] { opacity: .6; cursor: progress; }
.directwoo-coupon-msg { margin-top: 6px; font-size: 12px; font-weight: 600; }
.directwoo-coupon-msg.directwoo-error { color: var(--destructive, #ef4444); }
.directwoo-coupon-msg.directwoo-success { color: #16a34a; }
.directwoo-sum-discount { color: #16a34a; font-variant-numeric: tabular-nums; }

/* ---------- Mobile sticky order bar ---------- */
.directwoo-sticky { display: none; }

/* ---------- Inline field errors (Forms §8) ---------- */
.directwoo-field-error {
	display: flex;
	align-items: center;
	gap: 5px;
	margin-top: 4px;
	font-size: 12px;
	font-weight: 600;
	color: var(--destructive, #ef4444);
}
.directwoo-field-error::before {
	content: "";
	width: 14px; height: 14px;
	flex: 0 0 auto;
	background: var(--destructive, #ef4444);
	-webkit-mask: center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2a10 10 0 100 20 10 10 0 000-20zm-1 5h2v6h-2zm0 8h2v2h-2z'/%3E%3C/svg%3E");
	mask: center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2a10 10 0 100 20 10 10 0 000-20zm-1 5h2v6h-2zm0 8h2v2h-2z'/%3E%3C/svg%3E");
}

/* ---------- Submit press feedback + spinner (Touch §2, Anim §7) ---------- */
.directwoo-submit { display: flex; align-items: center; justify-content: center; gap: 10px; }
.directwoo-submit:active { transform: scale(.99) translateY(1px); }
.directwoo-spinner {
	display: none;
	width: 18px; height: 18px;
	border: 2.5px solid rgba(255, 255, 255, .45);
	border-top-color: #fff;
	border-radius: 50%;
	animation: directwoo-spin .7s linear infinite;
}
.directwoo-submit.is-loading .directwoo-spinner { display: inline-block; }
@keyframes directwoo-spin { to { transform: rotate(360deg); } }

/* Tabular figures for quantity & numbers (Typography §6) */
.directwoo-qty input, .directwoo-offer-qty, .directwoo-offer-total { font-variant-numeric: tabular-nums; }

/* Keyboard focus visibility (Accessibility §1) */
.directwoo-submit:focus-visible,
.directwoo-add-cart:focus-visible,
.directwoo-qty button:focus-visible,
.directwoo-offer:focus-within {
	outline: 3px solid color-mix(in srgb, var(--directwoo-button, #18181b) 45%, transparent);
	outline-offset: 2px;
}

/* Tablet: small quantity stepper, large "Add to cart" that fills the row. */
@media (max-width: 768px) {
	.directwoo-cart-row { gap: 8px; }
	/* Forced (!important + high specificity) so the theme cannot widen the stepper. */
	.directwoo-form-wrap .directwoo-qty button { width: 28px !important; min-width: 28px !important; height: 32px !important; padding: 0 !important; font-size: 15px; }
	.directwoo-form-wrap .directwoo-qty input { width: 34px !important; min-width: 34px !important; height: 32px !important; padding: 0 !important; font-size: 16px; } /* 16px avoids iOS zoom */
	.directwoo-add-cart { flex: 1; height: 44px; font-size: 15px; }
	.directwoo-form-wrap .directwoo-add-cart { height: 44px !important; font-size: 15px !important; }

	/* Mobile sticky order bar. */
	.directwoo-sticky {
		display: flex;
		position: fixed;
		left: 0; right: 0; bottom: 0;
		z-index: 9990;
		align-items: center;
		gap: 12px;
		padding: 9px 14px;
		background: var(--directwoo-bg, #fff);
		border-top: 1px solid var(--directwoo-field-border, #e5e7eb);
		box-shadow: 0 -6px 20px -8px rgba(0, 0, 0, .25);
	}
	.directwoo-sticky-total { font-weight: 800; font-size: 17px; color: var(--directwoo-text, #18181b); font-variant-numeric: tabular-nums; white-space: nowrap; }
	.directwoo-sticky-btn { flex: 1; height: 46px; font-weight: 800; font-size: 15px; text-transform: uppercase; cursor: pointer; }
	.single-product { padding-bottom: 76px; }
}

@media (max-width: 480px) {
	/* Keep the two-column layout on mobile (half fields stay half). */
	.directwoo-fields { gap: 8px 10px; }
	.directwoo-form-wrap { padding: 18px 14px; }
	.directwoo-form-wrap .directwoo-field input,
	.directwoo-form-wrap .directwoo-field select { font-size: 16px; } /* avoid iOS zoom */
	/* Narrowest phones: quantity stepper as small as possible, button stays big. */
	.directwoo-cart-row { gap: 6px; }
	.directwoo-form-wrap .directwoo-qty button { width: 28px !important; min-width: 28px !important; height: 32px !important; padding: 0 !important; font-size: 15px; }
	.directwoo-form-wrap .directwoo-qty input { width: 34px !important; min-width: 34px !important; height: 32px !important; padding: 0 !important; font-size: 16px; }
	.directwoo-add-cart { height: 46px; }
	.directwoo-form-wrap .directwoo-add-cart { height: 46px !important; }
}

/* Respect reduced-motion (Accessibility §1 / Animation §7) */
@media (prefers-reduced-motion: reduce) {
	.directwoo-form-wrap::before { animation: none; }
	.directwoo-spinner { animation-duration: 1.4s; }
	.directwoo-offer, .directwoo-submit, .directwoo-add-cart, .directwoo-qty button, .directwoo-icon { transition: none; }
	.directwoo-submit::after { display: none; }
}

/* ---- Post-purchase 1-Click Upsell modal ---- */
.directwoo-ups-overlay {
	position: fixed;
	inset: 0;
	z-index: 100000;
	background: rgba(0, 0, 0, .55);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}
.directwoo-ups-modal { width: 420px; max-width: 100%; }
.directwoo-ups-card {
	padding: 22px;
	text-align: center;
	box-shadow: 0 24px 60px -18px rgba(0, 0, 0, .6);
}
.directwoo-ups-header { font-weight: 800; font-size: 19px; margin-bottom: 8px; }
.directwoo-ups-timer { font-size: 14px; margin-bottom: 12px; }
.directwoo-ups-media img { max-width: 100%; max-height: 200px; border-radius: 10px; margin: 4px auto 12px; display: block; }
.directwoo-ups-title { font-weight: 600; font-size: 16px; margin-bottom: 10px; }
.directwoo-ups-badge { display: inline-block; padding: 3px 14px; border-radius: 999px; font-weight: 700; margin-bottom: 10px; }
.directwoo-ups-prices { font-size: 22px; font-weight: 800; margin-bottom: 14px; }
.directwoo-ups-was { text-decoration: line-through; opacity: .5; font-weight: 500; font-size: 16px; margin-inline-end: 8px; }
.directwoo-ups-variant { text-align: start; margin-bottom: 10px; }
.directwoo-ups-variant label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.directwoo-ups-variant select { width: 100%; padding: 10px; border: 1px solid #d1d5db; border-radius: 8px; }
.directwoo-ups-qty { display: flex; align-items: center; justify-content: center; gap: 8px; margin-bottom: 12px; }
.directwoo-ups-qty button { width: 38px; height: 38px; border: 1px solid #d1d5db; background: #fff; border-radius: 8px; font-size: 18px; cursor: pointer; }
.directwoo-ups-qinput { width: 60px; height: 38px; text-align: center; border: 1px solid #d1d5db; border-radius: 8px; }
.directwoo-ups-accept, .directwoo-ups-reject { display: block; width: 100%; border: 0; padding: 13px; margin-top: 10px; cursor: pointer; font-weight: 700; }
.directwoo-ups-accept[disabled] { opacity: .6; cursor: default; }
.directwoo-ups-msg { color: #dc2626; font-size: 13px; font-weight: 600; margin-top: 10px; }

/* ---- In-form cross-sell add-ons ---- */
.directwoo-xsell { margin: 14px 0; }
.directwoo-xsell-title { font-weight: 700; font-size: 15px; margin-bottom: 8px; }
.directwoo-xsell-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; margin-bottom: 8px; cursor: pointer; }
.directwoo-xsell-item input { width: 18px; height: 18px; flex: 0 0 auto; }
.directwoo-xsell-img img { width: 46px; height: 46px; object-fit: cover; border-radius: 8px; display: block; }
.directwoo-xsell-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.directwoo-xsell-name { font-weight: 600; }
.directwoo-xsell-price { font-weight: 700; }
.directwoo-xsell-was { text-decoration: line-through; opacity: .55; font-weight: 500; margin-inline-end: 6px; }
