/* ============================================================
 * OREM Dedicatoria — Checkout Block
 * ------------------------------------------------------------
 * Visual language matches the OREM Shoptimizer child theme.
 * Brand color (#b85c7f) sourced from
 *   shoptimizer-child-theme/style.css:380 (place-order button bg).
 * Everything is namespaced under `.orem-dedicatoria-block` to
 * avoid bleeding into the rest of the WC Blocks checkout.
 * ============================================================ */

.orem-dedicatoria-block {
	--orem-rose:        #b85c7f;
	--orem-rose-deep:   #c46683;
	--orem-rose-tint:   #fbf2f5;
	--orem-rose-soft:   #f6e6ec;
	--orem-ink:         #1c1c1c;
	--orem-ink-soft:    #5d5d5d;
	--orem-line:        #ececec;
	--orem-line-strong: #d9d9d9;
	--orem-bg:          #ffffff;
	--orem-radius:      14px;
	--orem-radius-sm:   8px;
	--orem-shadow:      0 1px 2px rgba(0, 0, 0, 0.04),
	                    0 8px 24px rgba(184, 92, 127, 0.06);
	--orem-shadow-lift: 0 1px 2px rgba(0, 0, 0, 0.05),
	                    0 12px 32px rgba(184, 92, 127, 0.12);
	--orem-ease:        cubic-bezier(0.16, 1, 0.3, 1);

	/* Extra top margin separates the card from the shipping methods
	 * block above. Without it the dedicatoria reads as "yet another
	 * shipping option" since the WC Blocks checkout stacks all the
	 * field-blocks with the same vertical rhythm. */
	margin: 32px 0 24px;
	/* Always-on rose tint + rose border, so the card has its own
	 * identity even when the user hasn't toggled it. This is the
	 * "premium opt-in" treatment — distinct from the neutral white
	 * shipping cards that share the same column. */
	border: 1.5px solid var(--orem-rose-soft);
	border-radius: var(--orem-radius);
	background: linear-gradient(180deg, #fdf8fa 0%, #fff 100%);
	box-shadow: var(--orem-shadow);
	overflow: hidden;
	position: relative;
	transition: border-color 0.35s var(--orem-ease),
	            box-shadow 0.35s var(--orem-ease),
	            background-color 0.35s var(--orem-ease);
}

/* Decorative rose accent strip on the left edge — gives the card
 * a "tag/ribbon" feel that visually separates it from the neutral
 * sibling cards (shipping, payment). */
.orem-dedicatoria-block::before {
	content: "";
	position: absolute;
	top: 14px;
	bottom: 14px;
	left: 0;
	width: 3px;
	background: var(--orem-rose);
	border-radius: 0 3px 3px 0;
	opacity: 0.65;
	transition: opacity 0.35s var(--orem-ease);
}

.orem-dedicatoria-block.is-added {
	border-color: var(--orem-rose);
	background: linear-gradient(180deg, var(--orem-rose-tint) 0%, #fff 65%);
	box-shadow: var(--orem-shadow-lift);
}

.orem-dedicatoria-block.is-added::before,
.orem-dedicatoria-block.is-composing::before {
	opacity: 1;
}

/* Pulse the border briefly when the cart mutation is in-flight,
 * so the user has a sense the system is "thinking". */
.orem-dedicatoria-block.is-busy {
	border-color: var(--orem-rose-deep);
}

/* ---------- Header --------------------------------------- */

.orem-dedicatoria-block__header {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 18px 20px;
}

/* The compose-mode header is the toggle for the form below it.
 * Visually mirrors the order-summary accordion pattern so the
 * affordance is consistent across the checkout. */
.orem-dedicatoria-block__header.is-clickable {
	cursor: pointer;
	user-select: none;
	outline: none;
	transition: background-color 0.18s var(--orem-ease);
}

.orem-dedicatoria-block__header.is-clickable:hover {
	background: color-mix(in srgb, var(--orem-rose) 6%, transparent);
}

.orem-dedicatoria-block__header.is-clickable:focus-visible {
	box-shadow: inset 0 0 0 3px color-mix(in srgb, var(--orem-rose) 30%, transparent);
}

/* Chevron icon at the right edge — rotates when expanded. */
.orem-dedicatoria-block__chevron {
	flex-shrink: 0;
	color: var(--orem-rose);
	transition: transform 0.3s var(--orem-ease);
}

.orem-dedicatoria-block__header[aria-expanded="true"] .orem-dedicatoria-block__chevron {
	transform: rotate(180deg);
}

.orem-dedicatoria-block__header-main {
	display: flex;
	align-items: center;
	gap: 14px;
	flex: 1 1 auto;
	min-width: 0;
}

/* Brand-rose gift icon. Larger + filled background on the new
 * "compose-first" UX since there's no checkbox here anymore — the
 * icon doubles as the visual anchor for the card. */
.orem-dedicatoria-block__icon-wrap {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: var(--orem-rose-soft);
	color: var(--orem-rose);
	transition: background-color 0.3s var(--orem-ease),
	            color 0.3s var(--orem-ease),
	            transform 0.3s var(--orem-ease);
}

.orem-dedicatoria-block.is-added .orem-dedicatoria-block__icon-wrap {
	background: var(--orem-rose);
	color: #fff;
	transform: scale(1.05);
}

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

.orem-dedicatoria-block__title-group {
	display: flex;
	flex-direction: column;
	gap: 3px;
	min-width: 0;
}

.orem-dedicatoria-block__title {
	font-size: 15px;
	font-weight: 500;
	color: var(--orem-ink);
	line-height: 1.3;
}

.orem-dedicatoria-block__subtitle {
	font-size: 12.5px;
	color: var(--orem-ink-soft);
	line-height: 1.4;
}

.orem-dedicatoria-block__price {
	flex-shrink: 0;
	display: flex;
	align-items: baseline;
	gap: 6px;
	white-space: nowrap;
}

.orem-dedicatoria-block__price-amount {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
}

.orem-dedicatoria-block__price-strike {
	color: var(--orem-ink-soft);
	font-size: 12px;
	text-decoration: line-through;
}

.orem-dedicatoria-block__price-current {
	color: var(--orem-ink);
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
}

.orem-dedicatoria-block.is-added .orem-dedicatoria-block__price-current,
.orem-dedicatoria-block__price-amount.is-free .orem-dedicatoria-block__price-current,
.orem-dedicatoria-block__price-amount.is-sale .orem-dedicatoria-block__price-current {
	color: var(--orem-rose);
}

/* ---------- Animated content ------------------------------- */

/* The compose form renders only when isFormOpen is true (mounted/
 * unmounted by React) so we don't need a height animation here —
 * a simple fade-in works. */
.orem-dedicatoria-block__content {
	padding: 4px 20px 22px;
	animation: orem-fade-in 0.35s var(--orem-ease);
}

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

.orem-dedicatoria-block__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 220px);
	gap: 22px;
	padding-top: 14px;
	border-top: 1px solid var(--orem-rose-soft);
}

@media (max-width: 640px) {
	.orem-dedicatoria-block__layout {
		grid-template-columns: 1fr;
		gap: 14px;
		padding-top: 12px;
	}

	/* Tighter overall card on mobile — checkout column is narrow so
	 * we trim padding everywhere instead of dominating the viewport. */
	.orem-dedicatoria-block {
		margin: 20px 0 16px;
		border-radius: 12px;
	}

	.orem-dedicatoria-block__header {
		gap: 12px;
		padding: 14px 14px;
	}

	.orem-dedicatoria-block__icon-wrap {
		width: 32px;
		height: 32px;
	}

	.orem-dedicatoria-block__title {
		font-size: 14.5px;
	}

	.orem-dedicatoria-block__subtitle {
		font-size: 12px;
		/* Allow it to wrap to 2 lines comfortably on small screens. */
		line-height: 1.4;
	}

	.orem-dedicatoria-block__content {
		padding: 2px 14px 18px;
	}

	.orem-dedicatoria-block__summary {
		padding: 2px 14px 16px;
	}

	/* Stack the summary rows vertically — the 80px label column
	 * eats too much width on a narrow phone. */
	.orem-dedicatoria-block__summary-row {
		grid-template-columns: 1fr;
		gap: 4px;
		padding: 12px 0;
	}

	.orem-dedicatoria-block__summary-label {
		font-size: 11px;
	}

	.orem-dedicatoria-block__summary-value {
		font-size: 14.5px;
	}

	/* Image preview shrinks but keeps a fixed max-height so it
	 * doesn't gobble vertical space. */
	.orem-dedicatoria-block__preview img {
		max-height: 200px;
		object-fit: cover;
	}

	/* Stack the action row on phones so the CTA isn't squashed. */
	.orem-dedicatoria-block__actions {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
	}

	.orem-dedicatoria-block__cta,
	.orem-dedicatoria-block__secondary-btn {
		width: 100%;
	}

	.orem-dedicatoria-block__link-btn {
		text-align: center;
		justify-content: center;
		padding: 6px 0;
	}
}

.orem-dedicatoria-block__fields {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.orem-dedicatoria-block__field-head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 10px;
	margin-bottom: 6px;
}

.orem-dedicatoria-block__field label {
	font-size: 13px;
	font-weight: 500;
	color: var(--orem-ink);
}

.orem-dedicatoria-block__required {
	color: var(--orem-rose);
	margin-left: 2px;
}

.orem-dedicatoria-block__optional {
	color: var(--orem-ink-soft);
	font-weight: 400;
	margin-left: 4px;
	font-size: 12px;
}

.orem-dedicatoria-block__count {
	font-size: 11.5px;
	color: var(--orem-ink-soft);
	font-variant-numeric: tabular-nums;
	transition: color 0.2s var(--orem-ease);
}

.orem-dedicatoria-block__count.is-near-limit {
	color: var(--orem-rose);
	font-weight: 500;
}

.orem-dedicatoria-block__field textarea,
.orem-dedicatoria-block__field input[type="text"] {
	width: 100%;
	padding: 11px 13px;
	border: 1px solid var(--orem-line-strong);
	border-radius: var(--orem-radius-sm);
	background: #fff;
	font: inherit;
	color: var(--orem-ink);
	line-height: 1.5;
	transition: border-color 0.18s var(--orem-ease),
	            box-shadow 0.18s var(--orem-ease);
}

.orem-dedicatoria-block__field textarea::placeholder,
.orem-dedicatoria-block__field input::placeholder {
	color: #b2b2b2;
}

.orem-dedicatoria-block__field textarea:focus,
.orem-dedicatoria-block__field input[type="text"]:focus {
	outline: none;
	border-color: var(--orem-rose);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--orem-rose) 18%, transparent);
}

.orem-dedicatoria-block__field textarea {
	resize: vertical;
	min-height: 104px;
}

.orem-dedicatoria-block__field.has-error textarea,
.orem-dedicatoria-block__field.has-error input[type="text"] {
	border-color: var(--orem-rose-deep);
}

.orem-dedicatoria-block__error {
	margin: 6px 0 0;
	color: var(--orem-rose-deep);
	font-size: 12px;
}

/* ---------- Image preview ---------------------------------- */

.orem-dedicatoria-block__preview {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 0;
}

.orem-dedicatoria-block__preview img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--orem-radius-sm);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
	background: #fff;
}

.orem-dedicatoria-block__preview-caption {
	font-size: 11.5px;
	color: var(--orem-ink-soft);
	text-align: center;
	font-style: italic;
}

/* ---------- Action buttons + summary --------------------- */

.orem-dedicatoria-block__actions {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 4px;
	flex-wrap: wrap;
}

/* Primary CTA — brand rose pill, white text. Mirrors the
 * "Realizar el pedido" button so the visual language is coherent
 * across the checkout. */
/* NOTE: `background` and `color` carry !important because
 * Shoptimizer's combined button stylesheet (delivered through
 * WP Rocket) wins specificity against any external selector
 * without the flag, downgrading the white-on-rose CTA to the
 * theme's default dark-on-default-bg combo. Verified live. */
.orem-dedicatoria-block__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 44px;
	padding: 10px 22px;
	border: 0;
	border-radius: 999px;
	background: var(--orem-rose) !important;
	color: #fff !important;
	font: inherit;
	font-weight: 500;
	letter-spacing: 0.2px;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(184, 92, 127, 0.28);
	transition: background-color 0.2s var(--orem-ease),
	            box-shadow 0.2s var(--orem-ease),
	            transform 0.15s var(--orem-ease);
}

/* Hover INVERTS to off-white + 3px rose ring — same convention
 * the child theme uses for .single_add_to_cart_button:hover and
 * the place-order button (shoptimizer-child-theme/style.css:385-390).
 * The brand uses this "fill → outline" flip everywhere for primary
 * actions so we follow the same language. */
.orem-dedicatoria-block__cta:hover:not(:disabled) {
	background: #F9FDFD !important;
	color: #000 !important;
	box-shadow: 0 0 0 3px var(--orem-rose-deep);
	transform: translateY(-1px);
}

.orem-dedicatoria-block__cta:active:not(:disabled) {
	transform: translateY(0);
	box-shadow: 0 0 0 3px var(--orem-rose-deep),
	            0 2px 6px rgba(184, 92, 127, 0.18);
}

.orem-dedicatoria-block__cta:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--orem-rose) 35%, transparent);
	outline-offset: 2px;
}

.orem-dedicatoria-block__cta:disabled,
.orem-dedicatoria-block__cta.is-disabled {
	background: var(--orem-line-strong);
	color: #fff;
	cursor: not-allowed;
	box-shadow: none;
	opacity: 0.85;
}

.orem-dedicatoria-block__cta.is-loading {
	color: rgba(255, 255, 255, 0.85);
	cursor: progress;
}

.orem-dedicatoria-block__btn-spinner {
	display: inline-block;
	width: 14px;
	height: 14px;
	border: 2px solid rgba(255, 255, 255, 0.4);
	border-top-color: #fff;
	border-radius: 50%;
	animation: orem-spin 0.7s linear infinite;
}

/* Secondary outlined button — "Editar" in the added state. */
.orem-dedicatoria-block__secondary-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 8px 18px;
	border: 1.5px solid var(--orem-rose);
	border-radius: 999px;
	background: transparent;
	color: var(--orem-rose);
	font: inherit;
	font-weight: 500;
	cursor: pointer;
	transition: background-color 0.2s var(--orem-ease),
	            color 0.2s var(--orem-ease);
}

.orem-dedicatoria-block__secondary-btn:hover:not(:disabled) {
	background: var(--orem-rose);
	color: #fff;
}

.orem-dedicatoria-block__secondary-btn:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--orem-rose) 35%, transparent);
	outline-offset: 2px;
}

/* Tertiary inline link — "Cancelar" and "Quitar del pedido". */
.orem-dedicatoria-block__link-btn {
	display: inline-flex;
	align-items: center;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--orem-ink-soft);
	font: inherit;
	font-size: 13px;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-color: color-mix(in srgb, var(--orem-ink-soft) 40%, transparent);
	transition: color 0.2s var(--orem-ease);
}

.orem-dedicatoria-block__link-btn:hover:not(:disabled) {
	color: var(--orem-rose-deep);
}

.orem-dedicatoria-block__link-btn:disabled {
	opacity: 0.55;
	cursor: default;
}

/* ---- Added-state summary card ---- */

.orem-dedicatoria-block__summary {
	padding: 4px 20px 20px;
	animation: orem-fade-in 0.35s var(--orem-ease);
}

.orem-dedicatoria-block__summary-row {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 12px;
	padding: 10px 0;
	border-top: 1px solid var(--orem-rose-soft);
}

.orem-dedicatoria-block__summary-row:first-child {
	border-top: 0;
}

.orem-dedicatoria-block__summary-label {
	font-size: 12px;
	font-weight: 500;
	color: var(--orem-ink-soft);
	text-transform: uppercase;
	letter-spacing: 0.6px;
	padding-top: 3px;
}

.orem-dedicatoria-block__summary-value {
	margin: 0;
	color: var(--orem-ink);
	font-size: 14px;
	line-height: 1.55;
	word-break: break-word;
	font-style: normal;
}

.orem-dedicatoria-block__summary .orem-dedicatoria-block__actions {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--orem-rose-soft);
}

/* ---------- Accessibility helpers ------------------------- */

.orem-dedicatoria-block__sr {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Reduce motion preferences */
@media (prefers-reduced-motion: reduce) {
	.orem-dedicatoria-block,
	.orem-dedicatoria-block__content,
	.orem-dedicatoria-block__checkbox-wrap input[type="checkbox"],
	.orem-dedicatoria-block__checkbox-wrap input[type="checkbox"]:checked::after,
	.orem-dedicatoria-block__field textarea,
	.orem-dedicatoria-block__field input[type="text"] {
		transition-duration: 0.001s !important;
		animation-duration: 0.001s !important;
	}
}
