/**
 * CW Fluent Form — Elementor widget skin (scoped to .elementor-widget-cw-fluent-form).
 * Fields use design tokens; submit matches CW Nova CTA (cw-hero-homepage.css).
 *
 * Last modified: 2026-03-31 — horizontal gutter + safe-area (Contact page mobile).
 */

.elementor-widget-cw-fluent-form .cw-fluent-form-widget {
	box-sizing: border-box;
}

@media (max-width: 1366px) {
	.elementor-widget-cw-fluent-form .cw-fluent-form-widget {
		padding-inline-start: max(var(--cw-gutter-inline, clamp(1rem, 5vw, 1.5rem)), env(safe-area-inset-left, 0px));
		padding-inline-end: max(var(--cw-gutter-inline, clamp(1rem, 5vw, 1.5rem)), env(safe-area-inset-right, 0px));
	}
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget.fluentform-widget-wrapper .fluentform,
.elementor-widget-cw-fluent-form .cw-fluent-form-widget.fluentform-widget-wrapper {
	font-family: var(--cw-font-body, "Inter", system-ui, sans-serif);
	color: var(--cw-text, #dce0ea);
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-group {
	margin-bottom: 1.25rem;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-input--label label {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: var(--cw-letter-spacing-label, 0.08em);
	text-transform: uppercase;
	color: var(--cw-text-muted, #8090a8) !important;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-input--label.ff-el-is-required.asterisk-right label:after,
.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-input--label.ff-el-is-required.asterisk-left label:before {
	color: var(--cw-accent-primary, #dc2626);
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-form-control,
.elementor-widget-cw-fluent-form .cw-fluent-form-widget input.ff-el-form-control,
.elementor-widget-cw-fluent-form .cw-fluent-form-widget textarea.ff-el-form-control,
.elementor-widget-cw-fluent-form .cw-fluent-form-widget select.ff-el-form-control {
	width: 100%;
	max-width: 100%;
	padding: 0.75rem 1rem !important;
	font-family: inherit !important;
	font-size: 1rem !important;
	line-height: var(--cw-line-height-body, 1.6) !important;
	color: var(--cw-text, #dce0ea) !important;
	background-color: var(--cw-surface-2, #1c1c1c) !important;
	border: 1px solid var(--cw-border, rgba(255, 255, 255, 0.07)) !important;
	border-radius: 0.5rem !important;
	box-shadow: none !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-form-control::placeholder {
	color: var(--cw-text-dim, #555);
	opacity: 1;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget textarea.ff-el-form-control {
	min-height: 8rem;
	resize: vertical;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-form-control:hover {
	border-color: rgba(255, 255, 255, 0.12) !important;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-form-control:focus {
	outline: none !important;
	border-color: var(--cw-accent-secondary, #00b7fa) !important;
	box-shadow: 0 0 0 1px var(--cw-accent-secondary, #00b7fa) !important;
	background-color: var(--cw-surface-3, #242424) !important;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-form-control:focus-visible {
	outline: 2px solid var(--cw-accent-secondary, #00b7fa);
	outline-offset: 2px;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-is-error .ff-el-form-control {
	border-color: var(--cw-accent-primary, #dc2626) !important;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff-el-is-error .text-danger,
.elementor-widget-cw-fluent-form .cw-fluent-form-widget .error.text-danger {
	color: var(--cw-accent-primary, #dc2626);
	font-size: 0.875rem;
	margin-top: 0.35rem;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget .ff_submit_btn_wrapper {
	margin-top: 0.5rem;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style) {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	min-height: 40px;
	padding: 0.75rem 1.5rem !important;
	width: 100%;
	font-family: var(--cw-font-heading, "Barlow", system-ui, sans-serif) !important;
	font-size: 0.875rem !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	text-decoration: none;
	color: #fff !important;
	cursor: pointer;
	border: none !important;
	border-radius: 999px !important;
	box-sizing: border-box;
	background: linear-gradient(
		135deg,
		var(--cw-accent-primary, #dc2626) 0%,
		var(--cw-accent-secondary, #00b7fa) 100%
	) !important;
	box-shadow: 0 10px 25px rgba(220, 38, 38, 0.3);
	transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

@supports (color: color-mix(in srgb, white 50%, black)) {
	.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style) {
		box-shadow: 0 10px 25px color-mix(in srgb, var(--cw-accent-primary, #dc2626) 30%, transparent);
	}
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style)::after {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 50%;
	height: 100%;
	background: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.3), transparent);
	transform: skewX(-20deg);
	transition: left 0.5s ease;
	pointer-events: none;
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style):hover {
	transform: translateY(-2px);
	color: #fff !important;
	background: linear-gradient(
		135deg,
		var(--cw-accent-primary, #dc2626) 0%,
		var(--cw-accent-secondary, #00b7fa) 100%
	) !important;
}

@supports (color: color-mix(in srgb, white 50%, black)) {
	.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style):hover {
		box-shadow: 0 15px 30px color-mix(in srgb, var(--cw-accent-secondary, #00b7fa) 40%, transparent);
	}
}

.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style):hover::after {
	left: 150%;
}

@media (min-width: 640px) {
	.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style) {
		width: auto;
	}
}

@media (prefers-reduced-motion: reduce) {
	.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style) {
		transition: none;
	}

	.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style):hover {
		transform: none;
	}

	.elementor-widget-cw-fluent-form .cw-fluent-form-widget form.frm-fluent-form button.ff-btn.ff-btn-submit:not(.ff_btn_no_style)::after {
		display: none;
	}
}

.elementor-widget-cw-fluent-form .cw-fluent-form-editor-msg {
	margin: 0;
	padding: 1rem;
	color: var(--cw-text-muted, #8090a8);
	font-size: 0.875rem;
}
