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

:root {
	--cf-ease: cubic-bezier(0.16, 1, 0.3, 1);
	--sage: #96926D;
	--cream: #EDE1C9;
	--olive: #4D4930;
	--terracotta: #965132;
}

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;
}

/* Ocultar header en la página de inicio (tiene hero con nav propia) */
.home .wp-block-template-part[data-slug="header"] {
	display: none !important;
}

/* Eliminar franja superior en página de inicio */
.home main > .wp-block-group.has-global-padding {
	padding-top: 0 !important;
}

/* --- Hero a sangre completa: recuperar el ancho que le quita el padding ---
   El hero (alignfull) vive dentro de .entry-content, que tiene
   has-global-padding (root padding lateral = clamp(1.5rem, 5vw, 4rem), el
   mismo valor definido en theme.json). Ese padding dejaba el hero corto y
   creaba franja blanca a la derecha (visible sobre todo en móvil).
   Definimos el valor del padding en una variable propia para no depender de
   --wp--style--root--padding-* y compensamos con margen negativo + ancho.
   Solo afecta a .cf-hero; no toca ninguna clase .cf-hero__*. */
.cf-hero {
	--cf-rootpad: clamp(1.5rem, 5vw, 4rem); /* idéntico al rootPadding de theme.json */
	margin-left: calc(-1 * var(--cf-rootpad)) !important;
	margin-right: calc(-1 * var(--cf-rootpad)) !important;
	width: calc(100% + (var(--cf-rootpad) * 2)) !important;
	max-width: none !important;
}

@media (max-width: 600px) {
	.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
		max-width: 100%;
	}
}

/* ==========================================================================
   Contact Form 7 — estilo acorde a la paleta del tema
   Pegar al final de assets/css/app.css
   Usa las variables del tema, así respeta la paleta y tipografías actuales.
   ========================================================================== */

/* Contenedor del formulario */
.wpcf7 {
	font-family: var(--wp--preset--font-family--body, sans-serif);
	color: var(--wp--preset--color--primary, #4D4930);
	max-width: min(74%, 1280px);   /* mismo ancho que tu contentSize */
	margin-left: 0;
	margin-right: auto;            /* alineado a la izquierda dentro del contenido */
}

@media (max-width: 600px) {
	.wpcf7 {
		max-width: 100%;
	}
}
/* Botón de enviar alineado a la derecha */
.wpcf7-form p:has(input[type="submit"]),
.wpcf7-form p:has(button[type="submit"]) {
	text-align: right;
}

/* Cada bloque etiqueta + campo */
.wpcf7-form p {
	margin: 0 0 1.25rem;
}

/* Etiquetas de los campos */
.wpcf7-form label {
	display: block;
	font-size: 0.9rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	margin-bottom: 0.4rem;
	color: var(--wp--preset--color--primary, #4D4930);
}

/* Campos de texto, email, teléfono, textarea y select */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="date"],
.wpcf7-form textarea,
.wpcf7-form select {
	width: 100%;
	box-sizing: border-box;
	font-family: inherit;
	font-size: 1rem;
	color: var(--wp--preset--color--primary, #4D4930);
	background: var(--wp--preset--color--white, #fff);
	border: 1px solid var(--wp--preset--color--base-2, #DCC9A8);
	border-radius: 12px;
	padding: 0.85rem 1.1rem;
	transition: border-color 0.25s, box-shadow 0.25s;
}

/* Placeholder más suave */
.wpcf7-form ::placeholder {
	color: color-mix(in srgb, var(--wp--preset--color--contrast, #96926D) 80%, transparent);
	opacity: 1;
}

/* Estado de foco: borde terracota + halo sutil */
.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
	outline: none;
	border-color: var(--wp--preset--color--accent, #965132);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--wp--preset--color--accent, #965132) 18%, transparent);
}

/* Textarea: altura cómoda */
.wpcf7-form textarea {
	min-height: 140px;
	resize: vertical;
}

/* Checkboxes y radios */
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item,
.wpcf7-form .wpcf7-radio .wpcf7-list-item {
	display: block;
	margin: 0.3rem 0;
}
.wpcf7-form .wpcf7-list-item-label {
	font-weight: 400;
	margin-left: 0.4rem;
}

/* Botón de envío */
.wpcf7-form input[type="submit"],
.wpcf7-form button[type="submit"] {
	font-family: var(--wp--preset--font-family--body, sans-serif);
	font-size: 0.95rem;
	font-weight: 500;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--white, #fff);
	background: var(--wp--preset--color--accent, #965132);
	border: 1px solid var(--wp--preset--color--accent, #965132);
	border-radius: 999px;
	padding: 0.9em 2.4em;
	cursor: pointer;
	transition: background 0.3s, color 0.3s, border-color 0.3s;
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-form button[type="submit"]:hover {
	background: transparent;
	color: var(--wp--preset--color--accent, #965132);
}

/* Spinner de carga */
.wpcf7-spinner {
	margin: 0.5rem auto;
}

/* Mensajes de validación y respuesta */
.wpcf7 form .wpcf7-response-output {
	margin: 1.25rem 0 0;
	padding: 0.85rem 1.1rem;
	border-radius: 10px;
	font-size: 0.9rem;
	border-width: 1px;
	border-style: solid;
}

/* Mensaje OK (enviado) */
.wpcf7 form.sent .wpcf7-response-output {
	background: color-mix(in srgb, var(--wp--preset--color--contrast-2, #B5B28F) 25%, var(--wp--preset--color--white, #fff));
	border-color: var(--wp--preset--color--contrast, #96926D);
	color: var(--wp--preset--color--primary, #4D4930);
}

/* Mensaje de error general */
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output {
	background: color-mix(in srgb, var(--wp--preset--color--accent, #965132) 12%, var(--wp--preset--color--white, #fff));
	border-color: var(--wp--preset--color--accent, #965132);
	color: var(--wp--preset--color--accent, #965132);
}

/* Mensaje de error bajo un campo concreto */
.wpcf7-form .wpcf7-not-valid-tip {
	color: var(--wp--preset--color--accent, #965132);
	font-size: 0.8rem;
	margin-top: 0.3rem;
}

/* Campo inválido: borde terracota */
.wpcf7-form .wpcf7-not-valid {
	border-color: var(--wp--preset--color--accent, #965132) !important;
}

/* Dos campos lado a lado (si usas markup con .cf7-row) */
.wpcf7-form .cf7-row {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}
.wpcf7-form .cf7-row > * {
	flex: 1;
	min-width: 200px;
}
