/**
 * Floreciente Button — block styles (front + editor).
 *
 * Single source of truth for every op-btn variant, size, and section-context
 * override. Loaded automatically via block.json style registration.
 */

/* ─── Base ─── */

.op-btn {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 6px;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--base);
	font-weight: 500;
	gap: 12px;
	justify-content: center;
	letter-spacing: 0.4px;
	line-height: var(--op-btn-lh, 1.5);
	outline: none;
	padding: 1rem 1.75rem;
	text-decoration: none;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		opacity 0.2s ease;
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.op-btn__text {
	display: inline-block;
}

.op-btn:hover {
	opacity: 0.85;
}

.op-btn:active {
	opacity: 0.75;
}

.op-btn:focus-visible {
	outline: 2px solid var(--op-color-dusk);
	outline-offset: 2px;
}

.op-btn__arrow {
	flex-shrink: 0;
	transition: transform 0.2s ease;
}

.op-btn:hover .op-btn__arrow {
	transform: translateX(3px);
}

.op-btn:active .op-btn__arrow,
.op-btn:focus-visible .op-btn__arrow {
	transform: translateX(8px);
}

.op-btn:hover .op-btn__arrow--back {
	transform: translateX(-3px);
}

.op-btn:active .op-btn__arrow--back,
.op-btn:focus-visible .op-btn__arrow--back {
	transform: translateX(-8px);
}

/* ─── Variant: Primary ─── */

.op-btn--primary {
	background-color: var(--op-color-dusk);
	color: var(--op-color-parchment);
}

.op-btn--primary:hover {
	background-color: var(--op-color-dusk-dark);
	color: var(--op-color-parchment);
	opacity: 1;
}

/* ─── Variant: Outline ─── */

.op-btn--outline {
	background-color: transparent;
	border-color: rgba(var(--op-rgb-deep-ink), 0.15);
	color: var(--op-color-deep-ink);
}

.op-btn--outline:hover {
	background-color: var(--op-color-deep-ink);
	color: var(--op-color-parchment);
	opacity: 1;
}

/* ─── Variant: Light ─── */

.op-btn--light {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.op-btn--light:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
	opacity: 1;
}

/* ─── Variant: Ghost ─── */

.op-btn--ghost {
	background: transparent;
	border-color: rgba(var(--op-rgb-deep-ink), 0.2);
	color: var(--op-color-deep-ink);
}

.op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-deep-ink), 0.06);
	border-color: rgba(var(--op-rgb-deep-ink), 0.35);
	color: var(--op-color-deep-ink);
	opacity: 1;
}

.op-btn--ghost:focus-visible {
	outline: 2px solid rgba(var(--op-rgb-dusk), 0.5);
	outline-offset: 2px;
}

/* ─── Variant: Header ─── */

.op-btn--header {
	background-color: var(--op-color-dusk);
	color: var(--op-color-parchment);
	font-size: var(--wp--preset--font-size--normal);
	gap: 8px;
	letter-spacing: 0.02em;
	padding: 10px 24px;
}

.op-btn--header:hover {
	background-color: var(--op-color-dusk-dark);
	box-shadow: 0 4px 12px rgba(var(--op-rgb-deep-ink), 0.2);
	color: var(--op-color-parchment);
	opacity: 1;
}

/* ─── Sizes ─── */

.op-btn--lg {
	font-size: var(--wp--preset--font-size--base);
	padding: 1rem 2.5rem;
}

.op-btn--sm {
	font-size: var(--wp--preset--font-size--normal);
	gap: var(--wp--preset--spacing--xs);
	padding: 12px 24px;
}

@media (max-width: 600px) {
	.op-btn--header {
		font-size: var(--wp--preset--font-size--sm);
		padding: 8px 18px;
	}
}

/* ═══════════════════════════════════════════════════════════════════════
   Section-style context overrides
   ───────────────────────────────────────────────────────────────────────
   Every button variant must be legible on every parent style background.

   Light backgrounds : parchment, rose, gold, moon
   Dark backgrounds  : dusk, footer-dark
   Accent backgrounds : terracotta

   Default (no is-style-*) assumes a parchment canvas.
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── Parchment (#f0e8dc) ─── */

.is-style-parchment .op-btn--outline {
	background-color: var(--op-color-parchment);
}

.is-style-parchment .op-btn--outline:hover {
	background-color: var(--op-color-deep-ink);
	color: var(--op-color-parchment);
}

.is-style-parchment .op-btn--light {
	background-color: var(--op-color-white);
}

.is-style-parchment .op-btn--ghost {
	background-color: var(--op-color-parchment);
	border-color: rgba(var(--op-rgb-deep-ink), 0.2);
	color: var(--op-color-deep-ink);
}

.is-style-parchment .op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-deep-ink), 0.06);
	border-color: rgba(var(--op-rgb-deep-ink), 0.35);
	color: var(--op-color-deep-ink);
}

/* ─── Rose (#d4a5a5) ─── */

.is-style-rose .op-btn--outline {
	background-color: var(--op-color-dusty-rose);
	border-color: rgba(var(--op-rgb-deep-ink), 0.18);
	color: var(--op-color-deep-ink);
}

.is-style-rose .op-btn--outline:hover {
	background-color: var(--op-color-deep-ink);
	color: var(--op-color-parchment);
}

.is-style-rose .op-btn--light {
	background-color: var(--op-color-white);
}

.is-style-rose .op-btn--ghost {
	background-color: var(--op-color-dusty-rose);
	border-color: rgba(var(--op-rgb-deep-ink), 0.2);
	color: var(--op-color-deep-ink);
}

.is-style-rose .op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-deep-ink), 0.06);
	border-color: rgba(var(--op-rgb-deep-ink), 0.35);
	color: var(--op-color-deep-ink);
}

/* ─── Gold (#d4bc8f) ─── */

.is-style-gold .op-btn--outline {
	background-color: var(--op-color-faded-gold);
	border-color: rgba(var(--op-rgb-deep-ink), 0.18);
	color: var(--op-color-deep-ink);
}

.is-style-gold .op-btn--outline:hover {
	background-color: var(--op-color-deep-ink);
	color: var(--op-color-parchment);
}

.is-style-gold .op-btn--light {
	background-color: var(--op-color-white);
}

.is-style-gold .op-btn--ghost {
	background-color: var(--op-color-faded-gold);
	border-color: rgba(var(--op-rgb-deep-ink), 0.2);
	color: var(--op-color-deep-ink);
}

.is-style-gold .op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-deep-ink), 0.06);
	border-color: rgba(var(--op-rgb-deep-ink), 0.35);
	color: var(--op-color-deep-ink);
}

/* ─── Moon (#bfc8d4) ─── */

.is-style-moon .op-btn--outline {
	background-color: var(--op-color-moon-glow);
	border-color: rgba(var(--op-rgb-deep-ink), 0.15);
	color: var(--op-color-deep-ink);
}

.is-style-moon .op-btn--outline:hover {
	background-color: var(--op-color-deep-ink);
	color: var(--op-color-parchment);
}

.is-style-moon .op-btn--light {
	background-color: var(--op-color-white);
}

.is-style-moon .op-btn--ghost {
	background-color: var(--op-color-moon-glow);
	border-color: rgba(var(--op-rgb-deep-ink), 0.18);
	color: var(--op-color-deep-ink);
}

.is-style-moon .op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-deep-ink), 0.06);
	border-color: rgba(var(--op-rgb-deep-ink), 0.35);
	color: var(--op-color-deep-ink);
}

/* ─── Dusk (#3a3a4a) ─── */

.is-style-dusk .op-btn--primary:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

.is-style-dusk .op-btn--outline {
	background-color: var(--op-color-deep-ink);
	border-color: rgba(var(--op-rgb-parchment), 0.2);
	color: var(--op-color-parchment);
}

.is-style-dusk .op-btn--outline:hover {
	background-color: var(--op-color-parchment);
	border-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-dusk .op-btn--light {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-dusk .op-btn--light:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

.is-style-dusk .op-btn--ghost {
	background-color: var(--op-color-deep-ink);
	border-color: rgba(var(--op-rgb-parchment), 0.15);
	color: rgba(var(--op-rgb-parchment), 0.7);
}

.is-style-dusk .op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-parchment), 0.04);
	border-color: rgba(var(--op-rgb-parchment), 0.3);
	color: var(--op-color-parchment);
}

.is-style-dusk .op-btn--ghost:focus-visible {
	outline-color: rgba(var(--op-rgb-faded-gold), 0.5);
}

.is-style-dusk .op-btn--header {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-dusk .op-btn--header:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

/* ─── Terracotta (#c4836f) ─── */

.is-style-terracotta .op-btn--primary {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--primary:hover,
.is-style-terracotta .op-btn--primary:active,
.is-style-terracotta .op-btn--primary:focus-visible {
	background-color: var(--op-color-faded-gold);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--outline {
	background-color: var(--op-color-terracotta);
	border-color: rgba(var(--op-rgb-parchment), 0.2);
	color: var(--op-color-parchment);
}

.is-style-terracotta .op-btn--outline:hover {
	background-color: var(--op-color-parchment);
	border-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--light {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--light:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--ghost {
	background-color: var(--op-color-terracotta);
	border-color: rgba(var(--op-rgb-parchment), 0.2);
	color: rgba(var(--op-rgb-parchment), 0.8);
}

.is-style-terracotta .op-btn--ghost:hover {
	background-color: rgba(var(--op-rgb-parchment), 0.08);
	border-color: rgba(var(--op-rgb-parchment), 0.35);
	color: var(--op-color-parchment);
}

.is-style-terracotta .op-btn--header {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--header:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

/* ═══════════════════════════════════════════════════════════════════════
   WP Core Button Bridge
   ───────────────────────────────────────────────────────────────────────
   Patterns may use native wp:button blocks with .op-btn classes on the
   outer wrapper (.wp-block-button). These rules ensure the inner <a>
   (.wp-block-button__link) inherits the button design system.
   ═══════════════════════════════════════════════════════════════════════ */

.op-btn.wp-block-button {
	background: transparent;
	border: none;
	border-radius: 0;
	color: inherit;
	display: inline-block;
	gap: 0;
	letter-spacing: inherit;
	padding: 0;
	transition: none;
}

.op-btn.wp-block-button .wp-block-button__link {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 6px;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--normal);
	font-weight: 500;
	gap: 12px;
	justify-content: center;
	letter-spacing: 0.4px;
	line-height: var(--op-btn-lh, 1.5);
	outline: none;
	padding: 1rem 1.75rem;
	text-decoration: none;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		opacity 0.2s ease;
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.op-btn.wp-block-button .wp-block-button__link:hover {
	opacity: 0.85;
}

.op-btn.wp-block-button .wp-block-button__link:active,
.op-btn.wp-block-button .wp-block-button__link:focus-visible {
	opacity: 0.75;
}

.op-btn.wp-block-button .wp-block-button__link:focus-visible {
	outline: 2px solid var(--op-color-dusk);
	outline-offset: 2px;
}

/* Bridge: primary */
.op-btn--primary.wp-block-button .wp-block-button__link {
	background-color: var(--op-color-dusk);
	color: var(--op-color-parchment);
}

.op-btn--primary.wp-block-button .wp-block-button__link:hover {
	background-color: var(--op-color-dusk-dark);
	color: var(--op-color-parchment);
	opacity: 1;
}

/* Bridge: outline */
.op-btn--outline.wp-block-button .wp-block-button__link {
	background-color: transparent;
	border-color: rgba(var(--op-rgb-deep-ink), 0.15);
	color: var(--op-color-deep-ink);
}

.op-btn--outline.wp-block-button .wp-block-button__link:hover {
	background-color: var(--op-color-deep-ink);
	color: var(--op-color-parchment);
	opacity: 1;
}

/* Bridge: light */
.op-btn--light.wp-block-button .wp-block-button__link {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.op-btn--light.wp-block-button .wp-block-button__link:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
	opacity: 1;
}

/* Bridge: ghost */
.op-btn--ghost.wp-block-button .wp-block-button__link {
	background: transparent;
	border-color: rgba(var(--op-rgb-deep-ink), 0.2);
	color: var(--op-color-deep-ink);
}

.op-btn--ghost.wp-block-button .wp-block-button__link:hover {
	background-color: rgba(var(--op-rgb-deep-ink), 0.06);
	border-color: rgba(var(--op-rgb-deep-ink), 0.35);
	color: var(--op-color-deep-ink);
	opacity: 1;
}

/* Bridge: sizes */
.op-btn--lg.wp-block-button .wp-block-button__link {
	font-size: var(--wp--preset--font-size--base);
	padding: 1rem 2.5rem;
}

.op-btn--sm.wp-block-button .wp-block-button__link {
	font-size: 0.9375rem;
	gap: var(--wp--preset--spacing--xs);
	padding: 12px 24px;
}

/* Bridge: section-variant overrides */
.is-style-dusk .op-btn--primary.wp-block-button .wp-block-button__link:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

.is-style-dusk .op-btn--ghost.wp-block-button .wp-block-button__link {
	border-color: rgba(var(--op-rgb-parchment), 0.15);
	color: rgba(var(--op-rgb-parchment), 0.7);
}

.is-style-dusk .op-btn--ghost.wp-block-button .wp-block-button__link:hover {
	background-color: rgba(var(--op-rgb-parchment), 0.04);
	border-color: rgba(var(--op-rgb-parchment), 0.3);
	color: var(--op-color-parchment);
}

.is-style-terracotta .op-btn--primary.wp-block-button .wp-block-button__link {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--primary.wp-block-button .wp-block-button__link:hover {
	background-color: var(--op-color-white);
	color: var(--op-color-deep-ink);
}

.is-style-terracotta .op-btn--ghost.wp-block-button .wp-block-button__link {
	border-color: rgba(var(--op-rgb-parchment), 0.2);
	color: rgba(var(--op-rgb-parchment), 0.8);
}

.is-style-terracotta .op-btn--ghost.wp-block-button .wp-block-button__link:hover {
	background-color: rgba(var(--op-rgb-parchment), 0.08);
	border-color: rgba(var(--op-rgb-parchment), 0.35);
	color: var(--op-color-parchment);
}

