/**
 * WPForms — capa visual global NNCC (theme).
 *
 * Paleta global: assets/css/nncc-tokens.css (--nncc-yellow, etc.).
 * WPForms Modern inyecta variables en `#wpforms-{id}`; el submit se corrige con
 * `wpforms_frontend_css_vars_pre_print_filter` en inc/wpforms-theme.php.
 * Esta hoja: campos, placeholders, mensajes y refuerzo de estados.
 */

/* Alias solo para formularios (evita acoplar selectores a tokens globales) */
:root {
	--nncc-wpforms-yellow: var(--nncc-yellow, #ffcc00);
	--nncc-wpforms-black: var(--nncc-black, #000000);
	--nncc-wpforms-white: var(--nncc-white, #ffffff);
	--nncc-wpforms-text: #1f1f1f;
	--nncc-wpforms-muted: #4a4d4a;
	--nncc-wpforms-border: rgba(0, 0, 0, 0.12);
	--nncc-wpforms-radius: 10px;
	--nncc-wpforms-radius-input: 10px;
	--nncc-wpforms-focus-ring: 0 0 0 2px #fff, 0 0 0 4px rgba(255, 204, 0, 0.45);
	--nncc-wpforms-error: #b91c1c;
	--nncc-wpforms-success-bg: rgba(0, 0, 0, 0.04);
	--nncc-wpforms-success-border: rgba(0, 0, 0, 0.12);
}

body.page {
	--nncc-wpforms-text: var(--nncc-inner-text, #1f1f1f);
	--nncc-wpforms-muted: var(--nncc-inner-text-muted, #4a4d4a);
	--nncc-wpforms-border: var(--nncc-inner-border, rgba(0, 0, 0, 0.08));
}

/* -------------------------------------------------------------------------
   Contenedor
------------------------------------------------------------------------- */
.wpforms-container {
	margin-bottom: 0;
	color: var(--nncc-wpforms-text);
}

.wpforms-container .wpforms-title,
.wpforms-container .wpforms-description {
	color: var(--nncc-wpforms-text);
}

/* -------------------------------------------------------------------------
   Labels y descripciones de campo
------------------------------------------------------------------------- */
.wpforms-container .wpforms-field-label,
.wpforms-container .wpforms-field-label-inline,
.wpforms-container .wpforms-field-sublabel {
	color: var(--nncc-wpforms-text);
	font-weight: 600;
}

.wpforms-container .wpforms-field-description,
.wpforms-container .wpforms-field .wpforms-field-description {
	color: var(--nncc-wpforms-muted);
	font-size: 0.9em;
}

/* -------------------------------------------------------------------------
   Inputs, textarea, select
------------------------------------------------------------------------- */
.wpforms-container input[type="text"],
.wpforms-container input[type="email"],
.wpforms-container input[type="tel"],
.wpforms-container input[type="number"],
.wpforms-container input[type="url"],
.wpforms-container input[type="search"],
.wpforms-container input[type="password"],
.wpforms-container input[type="date"],
.wpforms-container select,
.wpforms-container textarea {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: 2.65rem;
	padding: 0.65rem 0.85rem;
	border-radius: var(--nncc-wpforms-radius-input);
	border: 1px solid var(--nncc-wpforms-border);
	background: var(--nncc-wpforms-white);
	color: var(--nncc-wpforms-text);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.wpforms-container textarea {
	min-height: 6.5rem;
	resize: vertical;
}

.wpforms-container input::placeholder,
.wpforms-container textarea::placeholder {
	color: var(--nncc-wpforms-muted);
	opacity: 1;
}

.wpforms-container input:focus,
.wpforms-container select:focus,
.wpforms-container textarea:focus {
	outline: none;
	border-color: rgba(0, 0, 0, 0.38);
	box-shadow: var(--nncc-wpforms-focus-ring);
}

.wpforms-container input:focus-visible,
.wpforms-container select:focus-visible,
.wpforms-container textarea:focus-visible {
	border-color: rgba(0, 0, 0, 0.5);
	box-shadow: 0 0 0 2px #fff, 0 0 0 4px rgba(255, 204, 0, 0.55);
}

/* Checkbox / radio / consent: tamaño y acento NNCC */
.wpforms-container input[type="checkbox"],
.wpforms-container input[type="radio"] {
	min-height: auto;
	width: auto;
	max-width: none;
	padding: 0;
	vertical-align: middle;
}

.wpforms-container input[type="checkbox"] {
	width: 1.125rem;
	height: 1.125rem;
	accent-color: var(--nncc-wpforms-black);
}

.wpforms-container input[type="radio"] {
	accent-color: var(--nncc-wpforms-black);
}

.wpforms-container .wpforms-field-checkbox ul,
.wpforms-container .wpforms-field-radio ul {
	margin: 0.35rem 0 0;
	padding: 0;
	list-style: none;
}

.wpforms-container .wpforms-field-checkbox li,
.wpforms-container .wpforms-field-radio li {
	margin-bottom: 0.5rem;
}

.wpforms-container .wpforms-field {
	max-width: 100%;
}

/* Espaciado base entre campos (Modern / Classic) */
.wpforms-container .wpforms-field:not(.wpforms-field-html):not(:last-child) {
	margin-bottom: 1rem;
}

.wpforms-container .wpforms-field-layout .wpforms-field {
	margin-bottom: 0.75rem;
}

/* -------------------------------------------------------------------------
   Errores y validación (mensajes)
------------------------------------------------------------------------- */
.wpforms-container .wpforms-error-container,
.wpforms-container .wpforms-error-noscript {
	color: var(--nncc-wpforms-error);
	font-weight: 700;
}

.wpforms-container label.wpforms-error,
.wpforms-container em.wpforms-error {
	color: var(--nncc-wpforms-error);
	font-style: normal;
}

.wpforms-container .wpforms-field input.wpforms-error,
.wpforms-container .wpforms-field textarea.wpforms-error,
.wpforms-container .wpforms-field select.wpforms-error,
.wpforms-container .wpforms-field input.user-invalid,
.wpforms-container .wpforms-field textarea.user-invalid,
.wpforms-container .wpforms-field select.user-invalid {
	border-color: var(--nncc-wpforms-error);
}

/* Confirmación / éxito */
.wpforms-confirmation-container-full,
.wpforms-container .wpforms-confirmation-container {
	background: var(--nncc-wpforms-success-bg);
	border: 1px solid var(--nncc-wpforms-success-border);
	border-radius: var(--nncc-wpforms-radius);
	color: var(--nncc-wpforms-text);
	padding: 1rem 1.15rem;
}

/* -------------------------------------------------------------------------
   Botón enviar — sistema NNCC (amarillo/negro → hover negro/amarillo)
------------------------------------------------------------------------- */
.wpforms-container .wpforms-submit-container {
	margin-top: 0.5rem;
}

.wpforms-container .wpforms-submit,
.wpforms-container button[type="submit"].wpforms-submit,
.wpforms-container button[type="submit"],
.wpforms-container input[type="submit"] {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 2.75rem;
	border-radius: var(--nncc-btn-radius, 999px) !important;
	padding: var(--nncc-btn-padding-y, 0.75rem) var(--nncc-btn-padding-x, 1.35rem) !important;
	font-weight: var(--nncc-btn-font-weight, 800) !important;
	font-size: 0.9375rem !important;
	line-height: 1.2 !important;
	letter-spacing: 0.03em !important;
	text-transform: uppercase !important;
	background: var(--nncc-wpforms-yellow) !important;
	color: var(--nncc-wpforms-black) !important;
	border: none !important;
	cursor: pointer;
	box-shadow: none !important;
	transition: var(--nncc-btn-transition, background-color 0.2s ease, color 0.2s ease) !important;
}

.wpforms-container .wpforms-submit:hover,
.wpforms-container button[type="submit"].wpforms-submit:hover,
.wpforms-container button[type="submit"]:hover,
.wpforms-container input[type="submit"]:hover {
	background: var(--nncc-wpforms-black) !important;
	color: var(--nncc-wpforms-yellow) !important;
}

.wpforms-container .wpforms-submit:focus,
.wpforms-container button[type="submit"].wpforms-submit:focus,
.wpforms-container button[type="submit"]:focus,
.wpforms-container input[type="submit"]:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(255, 204, 0, 0.45) !important;
}

.wpforms-container .wpforms-submit:disabled,
.wpforms-container button[type="submit"]:disabled,
.wpforms-container input[type="submit"]:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

/* -------------------------------------------------------------------------
   Variantes por contexto (wrappers del theme; opcional)
   — .nncc-home-form, .nncc-contact-form, .nncc-assistance-form, etc.
------------------------------------------------------------------------- */

.nncc-charlas-cta .wpforms-container .wpforms-submit-container {
	text-align: center;
}

/* -------------------------------------------------------------------------
   Responsive: botón a ancho completo en móvil (opcional global)
------------------------------------------------------------------------- */
@media (max-width: 767.98px) {
	.wpforms-container .wpforms-submit,
	.wpforms-container button[type="submit"].wpforms-submit,
	.wpforms-container button[type="submit"],
	.wpforms-container input[type="submit"] {
		width: 100%;
		box-sizing: border-box;
	}
}
