
/* ==========================================================================
   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;
}
