/*!
 * WorPro Newsletter — Public subscribe form.
 * Theme-neutral, low specificity, easy to override.
 *
 * Every visual property derives from a custom property so themes/operators
 * can override site-wide with a single rule:
 *   .worpro-nl-form { --worpro-nl-form-primary: #ff6b35; }
 * Per-instance overrides come from the inline style="--worpro-nl-form-primary: …"
 * emitted by FormRenderer when the shortcode/block/widget passes `accent`.
 */
.worpro-nl-form {
	/* Brand color (button + focus ring). Default replaced inline by FormRenderer. */
	--worpro-nl-form-primary: #0f9b89;
	--worpro-nl-form-primary-text: #fff;
	--worpro-nl-form-text: inherit;
	--worpro-nl-form-muted: rgba(0, 0, 0, 0.55);
	--worpro-nl-form-input-bg: rgba(255, 255, 255, 0.9);
	--worpro-nl-form-input-border: rgba(0, 0, 0, 0.18);
	--worpro-nl-form-input-text: inherit;
	--worpro-nl-form-radius: 6px;
	--worpro-nl-form-success-bg: #e7f6ec;
	--worpro-nl-form-success-text: #1a7f37;
	--worpro-nl-form-error-bg: #fce8ea;
	--worpro-nl-form-error-text: #b32d2e;

	max-width: 520px;
	margin: 16px 0;
	font-family: inherit;
	color: var(--worpro-nl-form-text);
}

.worpro-nl-form__row {
	margin: 0 0 12px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.worpro-nl-form__row label {
	font-size: 14px;
	font-weight: 600;
	color: var(--worpro-nl-form-text);
}
.worpro-nl-form__row input[type="email"],
.worpro-nl-form__row input[type="text"] {
	width: 100%;
	box-sizing: border-box;
	padding: 12px 14px;
	border: 1px solid var(--worpro-nl-form-input-border);
	border-radius: var(--worpro-nl-form-radius);
	font-size: 16px; /* >= 16px so iOS doesn't auto-zoom on focus */
	background: var(--worpro-nl-form-input-bg);
	color: var(--worpro-nl-form-input-text);
	transition: border-color 120ms ease, box-shadow 120ms ease;
}
.worpro-nl-form__row input:focus {
	outline: none;
	border-color: var(--worpro-nl-form-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--worpro-nl-form-primary) 25%, transparent);
}
.worpro-nl-form__row input::placeholder { opacity: 0.55; }

.worpro-nl-form__consent label {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: 400;
	font-size: 13px;
	color: var(--worpro-nl-form-muted);
}
.worpro-nl-form__consent input[type="checkbox"] {
	flex: 0 0 auto;
	margin-top: 2px;
	accent-color: var(--worpro-nl-form-primary);
}

.worpro-nl-form__submit { margin-top: 8px; }
.worpro-nl-form__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 44px; /* WCAG touch target */
	background: var(--worpro-nl-form-primary);
	color: var(--worpro-nl-form-primary-text);
	border: 0;
	border-radius: var(--worpro-nl-form-radius);
	padding: 12px 24px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: filter 120ms ease, transform 60ms ease;
}
.worpro-nl-form__button:hover,
.worpro-nl-form__button:focus { filter: brightness(0.92); outline: none; }
.worpro-nl-form__button:focus-visible {
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--worpro-nl-form-primary) 40%, transparent);
}
.worpro-nl-form__button:active { transform: translateY(1px); }
.worpro-nl-form__button[disabled] { opacity: 0.6; cursor: progress; filter: none; }

.worpro-nl-form__message {
	margin-top: 12px;
	padding: 10px 14px;
	border-radius: var(--worpro-nl-form-radius);
	font-size: 14px;
	line-height: 1.5;
}
.worpro-nl-form__message--success { background: var(--worpro-nl-form-success-bg); color: var(--worpro-nl-form-success-text); }
.worpro-nl-form__message--error   { background: var(--worpro-nl-form-error-bg);   color: var(--worpro-nl-form-error-text); }

.worpro-nl-form .required { color: var(--worpro-nl-form-error-text); margin-left: 2px; }

/* Wide screens — allow theme containers to dictate width rather than capping at 520px. */
@media (min-width: 900px) {
	.worpro-nl-form { max-width: none; }
	.alignwide .worpro-nl-form,
	.alignfull .worpro-nl-form { max-width: none; }
}

/* Dark mode auto-tuning. Operators can opt out by adding
   class="worpro-nl-form" style="--worpro-nl-form-input-bg:#fff" via theme. */
@media (prefers-color-scheme: dark) {
	.worpro-nl-form {
		--worpro-nl-form-muted: rgba(255, 255, 255, 0.7);
		--worpro-nl-form-input-bg: rgba(255, 255, 255, 0.06);
		--worpro-nl-form-input-border: rgba(255, 255, 255, 0.22);
		--worpro-nl-form-success-bg: rgba(46, 160, 67, 0.18);
		--worpro-nl-form-success-text: #4ade80;
		--worpro-nl-form-error-bg: rgba(220, 38, 38, 0.18);
		--worpro-nl-form-error-text: #fca5a5;
	}
}

/* Inline layout — email field + button on one row (button right), consent below.
   For full-width bars (e.g. footers). Opt in via [worpro_nl_form layout="inline"]
   or Settings → Email design → Subscribe form layout. */
.worpro-nl-form--inline {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 12px;
}
.worpro-nl-form--inline .worpro-nl-form__row { margin: 0; }
.worpro-nl-form--inline .worpro-nl-form__row:not(.worpro-nl-form__consent):not(.worpro-nl-form__submit) {
	flex: 1 1 240px;
	order: 1;
}
.worpro-nl-form--inline .worpro-nl-form__submit { flex: 0 0 auto; order: 2; }
.worpro-nl-form--inline .worpro-nl-form__submit .worpro-nl-form__button { width: auto; }
.worpro-nl-form--inline .worpro-nl-form__consent { flex: 1 1 100%; order: 3; }
.worpro-nl-form--inline .worpro-nl-form__message { flex: 1 1 100%; order: 4; }

/* No field labels — hide email/name labels visually (kept for screen readers).
   Use when one field + placeholder is self-explanatory. Consent label stays. */
.worpro-nl-form--no-labels .worpro-nl-form__row:not(.worpro-nl-form__consent):not(.worpro-nl-form__submit) > label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
