/**
 * Label styler styles for Elementor atomic form (e-form).
 * Works with atomic-form-label-style.js field/label pairing.
 */

:root {
	--cfl-atomic-icon-div-width: 40px;
}

form[data-e-type="e-form"].lsfef-atomic-form .lsfef-atomic-field-group,
.e-form-base.lsfef-atomic-form .lsfef-atomic-field-group {
	position: relative;
}

.e-form-base .lsfef-atomic-field-group {
	width: 100%;
}

body.ast-page-builder-template form[data-e-type="e-form"].lsfef-atomic-form .lsfef-atomic-field-group:where(
	.label-outline,
	.label-filled,
	.label-clean,
	.label-Style_Four
) input.elementor-field-textual {
	height: auto !important;
}

/* ---------- Outline (Style floating on border) ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline .elementor-field-label {
	position: absolute;
	transition: all 0.2s ease;
	pointer-events: none;
	left: calc(
		var(--lsfef-input-padding-left, 16px) + var(--lsfef-input-offset-left, 0px) / 2 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	font-size: var(--typography-font-size, var(--lsfef-site-field-font-size)) !important;
	line-height: var(--typography-font-size, var(--lsfef-site-field-font-size)) !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline input.elementor-field-textual ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline textarea.elementor-field-textual ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline select.elementor-field-textual ~ .elementor-field-label {
	top: calc(
		var(--lsfef-input-padding-top, 0px) +
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline .elementor-field:focus {
	border-color: var(--ls-border-color) !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline .elementor-field:focus ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline .elementor-field:not(:placeholder-shown) ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline select.elementor-field:focus ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline select.elementor-field:valid ~ .elementor-field-label {
	font-size: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
	line-height: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
	left: calc(
		var(--lsfef-input-padding-left, 16px) + var(--lsfef-input-offset-left, 0px) / 2 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	top: calc(
		-1 * var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2
	);
	padding: 0 2px !important;
	background-image: linear-gradient(
		360deg,
		var(
			--field-background-color,
			var(--lsfef-site-field-background-color, var(--e-form-field-background-color, #fff))
		)
			calc(50% + var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2),
		transparent 50%
	);
}

/* ---------- Clean ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean .elementor-field-label {
	position: absolute;
	left: calc(
		var(--lsfef-input-padding-left, 16px) + var(--lsfef-input-offset-left, 0px) / 2 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	transition: all 0.2s ease;
	pointer-events: none;
	font-size: var(--typography-font-size, var(--lsfef-site-field-font-size)) !important;
	padding: 0 !important;
	line-height: var(--typography-font-size, var(--lsfef-site-field-font-size)) !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean input.elementor-field-textual ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean textarea.elementor-field-textual ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean select.elementor-field-textual ~ .elementor-field-label {
	top: calc(
		var(--lsfef-input-padding-top, 0px) +
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean .elementor-field:focus {
	border-color: var(--ls-border-color) !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean .elementor-field:focus ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean .elementor-field:not(:placeholder-shown) ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean select.elementor-field:focus ~ .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean select.elementor-field:valid ~ .elementor-field-label {
	position: absolute;
	font-size: calc(var(--typography-font-size, var(--lsfef-site-field-font-size)) / 1.5) !important;
	line-height: calc(var(--typography-font-size, var(--lsfef-site-field-font-size)) / 1.5) !important;
	left: calc(
		var(--lsfef-input-padding-left, 16px) + var(--lsfef-input-offset-left, 0px) / 2 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	top: calc(
		(var(--lsfef-input-padding-top, 15px) + var(--lsfef-input-padding-bottom, 15px)) / 3 -
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) + 3px
	);
	padding: 0 !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean .elementor-field-textual:not(.elementor-field-type-tel .iti__tel-input) {
	padding-top: calc(
		(var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-padding-bottom, 10px)) -
			(var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-padding-bottom, 10px)) / 3
	) !important;
	padding-bottom: calc(
		(var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-padding-bottom, 10px)) / 3
	) !important;
}

/* ---------- Filled ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-filled .elementor-field-label {
	position: absolute;
	font-size: calc(var(--typography-font-size, var(--lsfef-site-field-font-size)) / 1.5) !important;
	line-height: calc(var(--typography-font-size, var(--lsfef-site-field-font-size)) / 1.5) !important;
	top: calc(
		(var(--lsfef-input-padding-top) + var(--lsfef-input-padding-bottom)) / 3 -
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top)) + 4px
	);
	left: calc(
		var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-offset-left, 1px) / 2 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	padding: 0 !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-filled .elementor-field:focus {
	border-color: var(--ls-border-color);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-filled .elementor-field-textual {
	padding-top: calc(
		(var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-padding-bottom, 10px)) -
			(var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-padding-bottom, 10px)) / 3
	) !important;
	padding-bottom: calc(
		(var(--lsfef-input-padding-left, 15px) + var(--lsfef-input-padding-bottom, 10px)) / 3
	) !important;
}

/* ---------- Style 1 (Style_Four) ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-Style_Four .elementor-field-label,
.e-form-base .lsfef-atomic-field-group.label-Style_Four .elementor-field-label {
	position: absolute;
	z-index: 1;
	pointer-events: none;
	font-size: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
	line-height: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
	left: calc(
		var(--lsfef-input-padding-left, 16px) + var(--lsfef-input-offset-left, 0px) / 2 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	top: calc(
		-1 * var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2
	);
	padding: 0 2px !important;
	background-image: linear-gradient(
		360deg,
		var(
			--field-background-color,
			var(--lsfef-site-field-background-color, var(--e-form-field-background-color, #fff))
		)
			calc(50% + var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2),
		transparent 50%
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-Style_Four .elementor-field:focus,
.e-form-base .lsfef-atomic-field-group.label-Style_Four .elementor-field:focus {
	border-color: var(--ls-border-color) !important;
}

.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-Style_Four .elementor-field-label {
	line-height: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1) !important;
}

/* ---------- Placeholder hiding ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline > input::placeholder,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean > input::-webkit-input-placeholder,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline > textarea::placeholder,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean > textarea::-webkit-input-placeholder {
	visibility: hidden;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.label-outline .elementor-field-textual::placeholder,
form[data-e-type="e-form"] .lsfef-atomic-field-group.label-clean .elementor-field-textual::placeholder {
	opacity: 0 !important;
	color: transparent !important;
}

/* ---------- Country field ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-outline .elementor-field-label {
	top: calc(var(--lsfef-input-padding-top, 0px) + var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3);
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-outline .iti.input-focus + .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-outline .iti:not(.input-no-val) + .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
	top: calc(
		-2 * var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 0.5
	);
	font-size: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
	background-image: linear-gradient(
		360deg,
		var(--field-background-color, var(--lsfef-site-field-background-color))
			calc(50% + var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2),
		transparent 50%
	);
}

body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-outline .iti:not(.input-no-val) + .elementor-field-label {
	top: calc(
		-2 * var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 4 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 0.5
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-clean .elementor-field-label {
	top: calc(var(--lsfef-input-padding-top, 0px) + var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3);
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-clean .iti.input-focus + .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-clean .iti:not(.input-no-val) + .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
	top: calc(
		(var(--lsfef-input-padding-top, 15px) + var(--lsfef-input-padding-bottom, 15px)) / 4 -
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) + 3px
	);
	font-size: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-Style_Four .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-country.label-filled .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 4 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
}

/* ---------- Tel field with country code ---------- */

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .elementor-field-label {
	top: calc(var(--lsfef-input-padding-top, 0px) + var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3);
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .iti.input-focus + .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .iti:not(.input-no-val) + .elementor-field-label,
body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .iti:not(.input-no-val) .elementor-field-label,
body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .iti.input-focus .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
	top: calc(
		(var(--lsfef-input-padding-top, 15px) + var(--lsfef-input-padding-bottom, 15px)) / 3 -
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) + 3px
	);
	font-size: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .iti:not(.input-focus) .iti__selected-dial-code {
	display: none;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-clean .iti.input-focus .iti__selected-dial-code {
	display: initial;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .elementor-field-label {
	top: calc(var(--lsfef-input-padding-top, 0px) + var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3);
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti.input-focus + .elementor-field-label,
form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti:not(.input-no-val) + .elementor-field-label,
body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti:not(.input-no-val) .elementor-field-label,
body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti.input-focus .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px)) + 3px
	);
	top: calc(
		-2 * var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 4 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2
	);
	font-size: calc(var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 1.5) !important;
	background-image: linear-gradient(
		360deg,
		var(--field-background-color, var(--lsfef-site-field-background-color))
			calc(50% + var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2),
		transparent 50%
	);
}

body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti:not(.input-no-val) .elementor-field-label,
body.elementor-editor-active form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti.input-focus .elementor-field-label {
	top: calc(
		-2 * var(--ls-label-font-size, var(--lsfef-site-label-spacing)) / 5 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px)) / 2
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti:not(.input-focus) .iti__selected-dial-code {
	display: none;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.country-code-enabled.elementor-field-type-tel.label-outline .iti.input-focus .iti__selected-dial-code {
	display: initial;
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-tel.label-Style_Four.country-code-enabled .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 20 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
}

form[data-e-type="e-form"] .lsfef-atomic-field-group.elementor-field-type-tel.label-filled.country-code-enabled .elementor-field-label {
	left: calc(
		var(--iti-selected-country-arrow-padding) + var(--lsfef-input-padding-left, 16px) / 4 +
			var(--field-border-left-width, var(--lsfef-field-border-left, 1px))
	);
	top: calc(
		(var(--lsfef-input-padding-top, 15px) + var(--lsfef-input-padding-bottom, 15px)) / 3 -
			var(--typography-font-size, var(--lsfef-site-field-font-size)) / 3 +
			var(--field-border-top-width, var(--lsfef-field-border-top, 1px))
	);
}
