/* ==========================================================================
   Unified Product Extras Modal — gift card + custom name
   ========================================================================== */

.stw-product-extras-modal.st-popup {
	z-index: var(--z-overlay, 1000);
}

.stw-product-extras-modal .st-popup__dialog {
	inline-size: min(640px, 100%);
	min-block-size: auto;
	grid-template-columns: 1fr;
}

.stw-product-extras-modal__content {
	gap: clamp(14px, 2vw, 20px);
	padding-block: clamp(22px, 3.2vw, 36px);
	padding-inline: clamp(22px, 3.2vw, 36px);
}

.stw-product-extras-modal__title,
.stw-product-extras-modal__section-title {
	margin: 0;
	font-family: var(--font-heading, inherit);
	font-size: clamp(1.35rem, 2.6vw, 1.9rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-heading, var(--luxe-ink));
}

.stw-product-extras-modal.is-paired .stw-product-extras-modal__title {
	display: none;
}

.stw-product-extras-modal:not(.is-paired) .stw-product-extras-modal__section-title {
	display: none;
}

.stw-product-extras-modal__sections {
	display: flex;
	flex-direction: column;
	gap: clamp(16px, 2.4vw, 24px);
}

.stw-product-extras-modal.is-paired .stw-product-extras-modal__sections {
	gap: clamp(20px, 3vw, 28px);
}

.stw-product-extras-modal__section {
	display: none;
	flex-direction: column;
	gap: 12px;
	margin: 0;
}

.stw-product-extras-modal__section.is-active {
	display: flex;
}

.stw-product-extras-modal__section--custom-name.is-active {
	gap: clamp(14px, 2vw, 18px);
}

.stw-product-extras-modal__section--custom-name.is-active .stw-product-extras-modal__section-title::after,
.stw-product-extras-modal:not(.is-paired) .stw-product-extras-modal__title::after {
	content: " *";
	color: var(--color-error, #c62828);
}

.stw-product-extras-modal__step {
	margin: 0;
	font-size: 0.86rem;
	font-weight: 600;
	color: var(--st-popup-text-muted, var(--color-text-muted, var(--luxe-muted)));
}

.stw-product-extras-modal__step--inline {
	margin-block-start: -4px;
}

.stw-product-extras-modal__field {
	display: grid;
	gap: 10px;
}

.stw-product-extras-modal__input {
	inline-size: 100%;
	padding-block: 0.75rem;
	padding-inline: 0.9rem;
	border: 1px solid color-mix(in srgb, var(--luxe-gold, #c9a96e) 25%, var(--color-border, #dcdcde));
	border-radius: var(--radius-corner, 10px);
	background: var(--luxe-cream, #fff);
	font: inherit;
	color: var(--color-text, var(--luxe-ink));
}

.stw-product-extras-modal__input:focus {
	outline: 2px solid color-mix(in srgb, var(--luxe-gold, #c9a96e) 45%, transparent);
	outline-offset: 2px;
	border-color: var(--luxe-gold, #c9a96e);
}

.stw-product-extras-modal__input.is-invalid {
	border-color: var(--color-error, #c62828);
}

.stw-product-extras-modal__input.is-invalid:focus {
	outline-color: color-mix(in srgb, var(--color-error, #c62828) 45%, transparent);
	border-color: var(--color-error, #c62828);
}

.stw-product-extras-modal__error {
	margin: 0;
	font-size: 0.84rem;
	font-weight: 500;
	color: var(--color-error, #c62828);
}

.stw-product-extras-modal__footer {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: 8px;
	margin-block-start: 4px;
}

.stw-product-extras-modal__footer-nav {
	display: flex;
	flex: 0 0 auto;
	align-items: stretch;
	flex-wrap: nowrap;
	gap: 8px;
}

.stw-product-extras-modal__footer-primary {
	display: flex;
	flex: 1 1 auto;
	align-items: stretch;
	flex-wrap: nowrap;
	gap: 8px;
	min-inline-size: 0;
}

.stw-product-extras-modal__btn {
	margin: 0;
	font-family: inherit;
	font-weight: 600;
	cursor: pointer;
	transition:
		border-color var(--st-popup-transition-fast, var(--transition-fast)),
		background var(--st-popup-transition-fast, var(--transition-fast)),
		color var(--st-popup-transition-fast, var(--transition-fast)),
		transform var(--st-popup-transition-fast, var(--transition-fast)),
		box-shadow var(--st-popup-transition-fast, var(--transition-fast));
}

.stw-product-extras-modal__btn--ghost {
	padding-block: 0.65rem;
	padding-inline: 1.1rem;
	min-block-size: 52px;
	border: 1px solid color-mix(in srgb, var(--luxe-gold, #c9a96e) 25%, var(--st-popup-border, var(--color-border)));
	border-radius: var(--st-popup-radius-button, var(--radius-button));
	background: var(--st-popup-surface, var(--luxe-cream, #fff));
	color: var(--st-popup-text, var(--color-text, var(--luxe-ink)));
}

.stw-product-extras-modal__btn--ghost:hover {
	border-color: var(--st-popup-primary, var(--color-primary));
	color: var(--st-popup-primary, var(--color-primary));
}

.stw-product-extras-modal__btn--ghost:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--st-popup-primary, var(--color-primary)) 45%, transparent);
	outline-offset: 2px;
}

.stw-product-extras-modal__btn--primary {
	flex: 1 1 auto;
	min-inline-size: 0;
	inline-size: auto;
	min-block-size: 52px;
}

.stw-product-extras-modal__footer .st-popup__submit {
	inline-size: auto;
	flex: 1 1 auto;
	min-inline-size: 0;
}

.stw-product-extras-modal .stw-gift-card-editor__surface {
	border-color: color-mix(in srgb, var(--luxe-gold, #c9a96e) 22%, var(--color-border, #dcdcde));
	background: var(--luxe-cream, #fff);
	color: var(--color-text, var(--luxe-ink));
}

.stw-product-extras-modal .stw-gift-card-editor__empty {
	color: var(--color-text-muted, var(--luxe-muted));
}
