/* ==========================================================================
   Constelaciones del Amor — estilos globales del front
   ========================================================================== */

:root {
	--cf-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

html {
	scroll-behavior: smooth;
}

body {
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

/* --- Animaciones sutiles de aparición ------------------------------------ */
.cf-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.9s var(--cf-ease), transform 0.9s var(--cf-ease);
	will-change: opacity, transform;
}

.cf-reveal.is-visible {
	opacity: 1;
	transform: none;
}

/* Variantes de dirección (se aplican con clases en patrones). */
.cf-reveal--left { transform: translateX(-32px); }
.cf-reveal--right { transform: translateX(32px); }
.cf-reveal--left.is-visible,
.cf-reveal--right.is-visible { transform: none; }

/* Retardos escalonados para grupos. */
.cf-reveal--d1 { transition-delay: 0.08s; }
.cf-reveal--d2 { transition-delay: 0.16s; }
.cf-reveal--d3 { transition-delay: 0.24s; }
.cf-reveal--d4 { transition-delay: 0.32s; }

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.cf-reveal {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
}

/* --- Cabecera y navegación ----------------------------------------------- */
.wp-block-navigation {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 0.82rem;
}

.wp-block-navigation a {
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	transition: color 0.3s var(--cf-ease);
}

.wp-block-navigation a:hover,
.wp-block-navigation .current-menu-item > a {
	color: var(--wp--preset--color--primary);
}

/* Submenús desplegables más suaves y femeninos. */
.wp-block-navigation .wp-block-navigation-submenu {
	position: relative;
}

.wp-block-navigation .wp-block-navigation__submenu-container {
	border: none;
	border-radius: 16px;
	box-shadow: var(--wp--preset--shadow--soft);
	background: var(--wp--preset--color--white);
	padding: 0.5rem 0;
	min-width: 220px;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity 0.3s var(--cf-ease), transform 0.3s var(--cf-ease);
	pointer-events: none;
}

.wp-block-navigation .wp-block-navigation-submenu:hover > .wp-block-navigation__submenu-container,
.wp-block-navigation .wp-block-navigation-submenu:focus-within > .wp-block-navigation__submenu-container,
.wp-block-navigation .wp-block-navigation__submenu-container.is-open {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.wp-block-navigation__submenu-container a {
	text-transform: none;
	letter-spacing: 0.02em;
	font-size: 0.95rem;
	padding: 0.55rem 1.25rem;
}

/* --- Navegación móvil (overlay cómodo) ----------------------------------- */
.wp-block-navigation__responsive-container.is-menu-open {
	background: var(--wp--preset--color--base);
	padding: clamp(1.5rem, 6vw, 4rem);
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	gap: 1.5rem;
}

.wp-block-navigation__responsive-container.is-menu-open a {
	font-size: 1.25rem;
}

.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close {
	color: var(--wp--preset--color--contrast);
}

/* --- Eyebrow / etiquetas decorativas (patrones) -------------------------- */
.cf-eyebrow {
	display: inline-block;
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.78rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--wp--preset--color--primary);
	margin-bottom: 0.75rem;
}

.cf-script {
	font-family: var(--wp--preset--font-family--display);
	font-style: italic;
	font-size: clamp(1.4rem, 2.4vw, 2rem);
	color: var(--wp--preset--color--primary);
}

/* Imágenes redondeadas suaves por defecto en patrones. */
.cf-rounded img { border-radius: 24px; }
.cf-circle img { border-radius: 999px; }

/* Botón secundario delicado (outline). */
.is-style-cf-outline > .wp-element-button,
.wp-block-button.is-style-cf-outline .wp-block-button__link {
	background: transparent;
	color: var(--wp--preset--color--primary);
	border: 1px solid var(--wp--preset--color--primary);
}

.is-style-cf-outline > .wp-element-button:hover,
.wp-block-button.is-style-cf-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

/* Mejora de foco accesible. */
:where(a, button, .wp-element-button):focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 3px;
	border-radius: 4px;
}
