/*
 * FTCC Forms — fully scoped to .ftcc-form so Elementor and other themes
 * cannot override form controls or layout. Typography and colors are locked.
 */

.ftcc-form {
	--ftcc-primary: #04849c;
	--ftcc-primary-hover: #036a7e;
	--ftcc-primary-contrast: #ffffff;
	--ftcc-primary-soft: rgba(4, 132, 156, 0.08);
	--ftcc-primary-ring: rgba(4, 132, 156, 0.25);
	--ftcc-black: #111111;
	--ftcc-white: #ffffff;
	--ftcc-text: #111111;
	--ftcc-muted: #6b7280;
	--ftcc-border: #e5e7eb;
	--ftcc-border-strong: #d1d5db;
	--ftcc-surface: #ffffff;
	--ftcc-surface-alt: #f9fafb;
	--ftcc-error: #b91c1c;
	--ftcc-error-bg: #fef2f2;
	--ftcc-success: #047857;
	--ftcc-radius: 10px;
	--ftcc-radius-sm: 6px;
	--ftcc-shadow: 0 1px 2px rgba(0,0,0,.04), 0 6px 20px rgba(0,0,0,.06);

	all: initial;
	display: block;
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
	color: var(--ftcc-text) !important;
	font-size: 16px !important;
	line-height: 1.5 !important;
	text-align: left !important;
	box-sizing: border-box !important;
	max-width: 760px;
	margin: 0 auto;
}

.ftcc-form *,
.ftcc-form *::before,
.ftcc-form *::after {
	box-sizing: border-box !important;
	font-family: inherit !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

.ftcc-form h1,
.ftcc-form h2,
.ftcc-form h3,
.ftcc-form h4,
.ftcc-form p,
.ftcc-form label,
.ftcc-form span,
.ftcc-form strong,
.ftcc-form em,
.ftcc-form small,
.ftcc-form dt,
.ftcc-form dd,
.ftcc-form ul,
.ftcc-form ol,
.ftcc-form li,
.ftcc-form fieldset,
.ftcc-form legend,
.ftcc-form button,
.ftcc-form input,
.ftcc-form select,
.ftcc-form textarea {
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
	color: inherit;
	font: inherit;
	text-decoration: none;
	list-style: none;
}

.ftcc-form .ftcc-form-root {
	background: var(--ftcc-surface) !important;
	border: 1px solid var(--ftcc-border) !important;
	border-radius: var(--ftcc-radius) !important;
	box-shadow: var(--ftcc-shadow) !important;
	padding: 32px !important;
}
@media (max-width: 640px) {
	.ftcc-form .ftcc-form-root { padding: 20px !important; }
}

/* Loading spinner (shown before JS hydrates) */
.ftcc-form .ftcc-loading {
	display: flex;
	justify-content: center;
	padding: 40px 0;
}
.ftcc-form .ftcc-spinner {
	width: 28px;
	height: 28px;
	border: 3px solid var(--ftcc-border);
	border-top-color: var(--ftcc-primary);
	border-radius: 50%;
	animation: ftcc-spin 0.8s linear infinite;
}
@keyframes ftcc-spin { to { transform: rotate(360deg); } }

/* Header */
.ftcc-form .ftcc-header { margin-bottom: 20px; }
.ftcc-form .ftcc-title {
	font-size: 24px !important;
	font-weight: 700 !important;
	color: var(--ftcc-black) !important;
	margin: 0 0 6px 0 !important;
	line-height: 1.25 !important;
}
.ftcc-form .ftcc-description {
	color: var(--ftcc-muted) !important;
	margin: 0 !important;
}

/* Step indicator */
.ftcc-form .ftcc-steps {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 24px 0;
	overflow-x: auto;
	padding-bottom: 4px;
}
.ftcc-form .ftcc-step-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px;
	border-radius: 999px;
	border: 1px solid var(--ftcc-border);
	background: var(--ftcc-white);
	color: var(--ftcc-muted);
	font-size: 13px;
	font-weight: 600;
	white-space: nowrap;
	flex-shrink: 0;
}
.ftcc-form .ftcc-step-pill .num {
	width: 22px; height: 22px;
	border-radius: 999px;
	background: var(--ftcc-border);
	color: var(--ftcc-muted);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
}
.ftcc-form .ftcc-step-pill.is-active {
	background: var(--ftcc-primary);
	border-color: var(--ftcc-primary);
	color: var(--ftcc-primary-contrast);
}
.ftcc-form .ftcc-step-pill.is-active .num {
	background: var(--ftcc-white);
	color: var(--ftcc-primary);
}
.ftcc-form .ftcc-step-pill.is-done {
	border-color: var(--ftcc-primary);
	color: var(--ftcc-primary);
	background: var(--ftcc-primary-soft);
}
.ftcc-form .ftcc-step-pill.is-done .num {
	background: var(--ftcc-primary);
	color: var(--ftcc-white);
}
.ftcc-form .ftcc-step-pill .num .ftcc-check {
	font-size: 13px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
}

/* Field styling */
.ftcc-form .ftcc-field { margin-bottom: 16px; }
.ftcc-form .ftcc-field-label {
	display: block !important;
	font-weight: 600 !important;
	color: var(--ftcc-black) !important;
	margin-bottom: 6px !important;
	font-size: 14px !important;
}
.ftcc-form .ftcc-required { color: var(--ftcc-error); margin-left: 2px; }
.ftcc-form .ftcc-help {
	color: var(--ftcc-muted) !important;
	font-size: 13px !important;
	margin-top: 4px !important;
}

.ftcc-form input[type="text"],
.ftcc-form input[type="email"],
.ftcc-form input[type="tel"],
.ftcc-form input[type="number"],
.ftcc-form input[type="date"],
.ftcc-form select,
.ftcc-form textarea {
	width: 100% !important;
	height: 44px !important;
	padding: 10px 12px !important;
	border: 1px solid var(--ftcc-border-strong) !important;
	border-radius: 8px !important;
	background: var(--ftcc-white) !important;
	color: var(--ftcc-black) !important;
	font-size: 15px !important;
	line-height: 1.4 !important;
	outline: none !important;
	transition: border-color .15s, box-shadow .15s !important;
	appearance: auto !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	box-shadow: none !important;
}
.ftcc-form textarea {
	height: auto !important;
	min-height: 96px !important;
	resize: vertical !important;
}
.ftcc-form select {
	appearance: none !important;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'><path d='M5.23 7.21a.75.75 0 011.06.02L10 11.148l3.71-3.918a.75.75 0 111.08 1.04l-4.24 4.48a.75.75 0 01-1.08 0L5.21 8.27a.75.75 0 01.02-1.06z'/></svg>") !important;
	background-repeat: no-repeat !important;
	background-position: right 10px center !important;
	background-size: 18px !important;
	padding-right: 38px !important;
}

.ftcc-form input:focus,
.ftcc-form select:focus,
.ftcc-form textarea:focus {
	border-color: var(--ftcc-primary) !important;
	box-shadow: 0 0 0 3px var(--ftcc-primary-ring) !important;
}

.ftcc-form .has-error input,
.ftcc-form .has-error select,
.ftcc-form .has-error textarea {
	border-color: var(--ftcc-error) !important;
	box-shadow: 0 0 0 3px rgba(185, 28, 28, .15) !important;
}
.ftcc-form .ftcc-error {
	color: var(--ftcc-error) !important;
	font-size: 13px !important;
	margin-top: 4px !important;
}

/* Checkboxes / radios — custom visual box so Elementor can't hide or restyle them */
.ftcc-form .ftcc-check-group { display: flex; flex-direction: column; gap: 8px; }
.ftcc-form .ftcc-check-option {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 10px 12px !important;
	border: 1px solid var(--ftcc-border) !important;
	border-radius: 8px !important;
	cursor: pointer !important;
	background: var(--ftcc-white) !important;
	background-color: var(--ftcc-white) !important;
	background-image: none !important;
	color: var(--ftcc-black) !important;
	font-weight: 500 !important;
	transition: border-color .15s, background-color .15s !important;
	margin: 0 !important;
	line-height: 1.4 !important;
	position: relative !important;
}
.ftcc-form .ftcc-check-option:hover {
	border-color: var(--ftcc-primary) !important;
	background: var(--ftcc-primary-soft) !important;
	background-color: var(--ftcc-primary-soft) !important;
}
.ftcc-form .ftcc-check-option input[type="checkbox"],
.ftcc-form .ftcc-check-option input[type="radio"] {
	position: absolute !important;
	opacity: 0 !important;
	width: 1px !important;
	height: 1px !important;
	pointer-events: none !important;
	margin: 0 !important;
}
.ftcc-form .ftcc-check-box {
	flex: 0 0 auto !important;
	width: 20px !important;
	height: 20px !important;
	border: 1.5px solid var(--ftcc-border-strong) !important;
	border-radius: 4px !important;
	background: var(--ftcc-white) !important;
	background-color: var(--ftcc-white) !important;
	background-image: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: var(--ftcc-white) !important;
	font-size: 13px !important;
	line-height: 1 !important;
	transition: background-color .15s, border-color .15s !important;
}
.ftcc-form .ftcc-check-option input[type="radio"] ~ .ftcc-check-box {
	border-radius: 50% !important;
}
.ftcc-form .ftcc-check-option input:checked ~ .ftcc-check-box {
	background: var(--ftcc-primary) !important;
	background-color: var(--ftcc-primary) !important;
	border-color: var(--ftcc-primary) !important;
}
.ftcc-form .ftcc-check-option input[type="radio"]:checked ~ .ftcc-check-box::after {
	content: '';
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--ftcc-white);
}
.ftcc-form .ftcc-check-option input[type="checkbox"]:checked ~ .ftcc-check-box .ftcc-check {
	display: inline-block !important;
}
.ftcc-form .ftcc-check-option .ftcc-check { display: none !important; }
.ftcc-form .ftcc-check-option input:focus-visible ~ .ftcc-check-box {
	box-shadow: 0 0 0 3px var(--ftcc-primary-ring) !important;
	border-color: var(--ftcc-primary) !important;
}
.ftcc-form .ftcc-check-option-text {
	flex: 1 1 auto !important;
	color: var(--ftcc-black) !important;
	font-size: 15px !important;
}

/* Grid */
.ftcc-form .ftcc-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .ftcc-form .ftcc-grid-2 { grid-template-columns: 1fr; gap: 12px; } }

/* Repeater */
.ftcc-form .ftcc-repeater { display: flex; flex-direction: column; gap: 12px; }
.ftcc-form .ftcc-repeater-row {
	position: relative;
	border: 1px solid var(--ftcc-border);
	border-radius: var(--ftcc-radius);
	background: var(--ftcc-surface-alt);
	padding: 18px 18px 14px 18px;
}
.ftcc-form .ftcc-repeater-row-num {
	position: absolute;
	top: -10px;
	left: 14px;
	background: var(--ftcc-primary);
	color: var(--ftcc-white);
	font-size: 12px;
	font-weight: 700;
	padding: 2px 10px;
	border-radius: 999px;
}
.ftcc-form .ftcc-repeater-remove {
	position: absolute !important;
	top: 8px !important;
	right: 8px !important;
	width: 30px !important;
	height: 30px !important;
	border-radius: 999px !important;
	border: 1px solid var(--ftcc-border) !important;
	background: var(--ftcc-white) !important;
	color: var(--ftcc-muted) !important;
	cursor: pointer !important;
	font-size: 16px !important;
	line-height: 1 !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
}
.ftcc-form .ftcc-repeater-remove:hover {
	border-color: var(--ftcc-error) !important;
	color: var(--ftcc-error) !important;
}
.ftcc-form .ftcc-repeater-add {
	display: block !important;
	width: 100% !important;
	min-height: 48px !important;
	padding: 12px 16px !important;
	margin-top: 12px !important;
	border: 1.5px dashed var(--ftcc-primary) !important;
	border-radius: var(--ftcc-radius) !important;
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	box-shadow: none !important;
	color: var(--ftcc-primary) !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	line-height: 1.2 !important;
	text-align: center !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	cursor: pointer !important;
	transition: background-color .15s !important;
}
.ftcc-form .ftcc-repeater-add:hover,
.ftcc-form .ftcc-repeater-add:focus {
	background: var(--ftcc-primary-soft) !important;
	background-color: var(--ftcc-primary-soft) !important;
	background-image: none !important;
	color: var(--ftcc-primary) !important;
}

/* Signature */
.ftcc-form .ftcc-sig-wrap {
	border: 1px solid var(--ftcc-border-strong);
	border-radius: 8px;
	padding: 12px;
	background: var(--ftcc-white);
	position: relative;
}
.ftcc-form .ftcc-sig-canvas {
	display: block;
	width: 100%;
	height: 180px;
	background: var(--ftcc-white);
	border-radius: 6px;
	touch-action: none;
	cursor: crosshair;
}
.ftcc-form .ftcc-sig-clear {
	position: absolute !important;
	top: 8px !important;
	right: 10px !important;
	background: transparent !important;
	border: 0 !important;
	color: var(--ftcc-muted) !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	cursor: pointer !important;
}
.ftcc-form .ftcc-sig-clear:hover { color: var(--ftcc-primary) !important; }

/* Review */
.ftcc-form .ftcc-review {
	border: 1px solid var(--ftcc-border);
	border-radius: var(--ftcc-radius);
	overflow: hidden;
}
.ftcc-form .ftcc-review-row {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 16px;
	padding: 12px 16px;
	border-bottom: 1px solid var(--ftcc-border);
}
.ftcc-form .ftcc-review-row:last-child { border-bottom: 0; }
.ftcc-form .ftcc-review-row .k { color: var(--ftcc-muted); font-weight: 600; }
.ftcc-form .ftcc-review-row .v { color: var(--ftcc-black); white-space: pre-wrap; word-break: break-word; }
@media (max-width: 560px) {
	.ftcc-form .ftcc-review-row { grid-template-columns: 1fr; gap: 2px; }
}
.ftcc-form .ftcc-total {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 14px 16px;
	background: var(--ftcc-primary-soft);
	border: 1px solid var(--ftcc-primary);
	border-radius: var(--ftcc-radius);
	margin: 16px 0;
	color: var(--ftcc-black);
	font-weight: 700;
}
.ftcc-form .ftcc-total .amount { color: var(--ftcc-primary); font-size: 22px; }

/* Payment element container */
.ftcc-form .ftcc-payment {
	margin-top: 10px;
	padding: 12px;
	border: 1px solid var(--ftcc-border);
	border-radius: var(--ftcc-radius);
	background: var(--ftcc-white);
	min-height: 100px;
}

/* Buttons */
.ftcc-form .ftcc-actions {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	margin-top: 24px;
}
.ftcc-form .ftcc-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 44px !important;
	padding: 10px 22px !important;
	border-radius: 8px !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	transition: background .15s, color .15s, border-color .15s !important;
	border: 1px solid transparent !important;
	text-align: center !important;
	text-decoration: none !important;
}
.ftcc-form .ftcc-btn-primary {
	background: var(--ftcc-primary) !important;
	color: var(--ftcc-primary-contrast) !important;
	border-color: var(--ftcc-primary) !important;
}
.ftcc-form .ftcc-btn-primary:hover:not(:disabled) {
	background: var(--ftcc-primary-hover) !important;
	border-color: var(--ftcc-primary-hover) !important;
}
.ftcc-form .ftcc-btn-ghost {
	background: var(--ftcc-white) !important;
	color: var(--ftcc-black) !important;
	border-color: var(--ftcc-border-strong) !important;
}
.ftcc-form .ftcc-btn-ghost:hover:not(:disabled) { border-color: var(--ftcc-black) !important; }
.ftcc-form .ftcc-btn:disabled,
.ftcc-form .ftcc-btn[aria-disabled="true"] {
	opacity: .5 !important;
	cursor: not-allowed !important;
}
.ftcc-form .ftcc-btn .spinner {
	width: 16px;
	height: 16px;
	border: 2px solid rgba(255,255,255,.5);
	border-top-color: #fff;
	border-radius: 50%;
	animation: ftcc-spin .7s linear infinite;
	margin-right: 8px;
}

.ftcc-form .ftcc-btn-primary.is-loading { pointer-events: none; opacity: .85; }

/* Banner */
.ftcc-form .ftcc-error-banner {
	background: var(--ftcc-error-bg);
	color: var(--ftcc-error);
	border: 1px solid #fecaca;
	padding: 10px 14px;
	border-radius: 8px;
	margin-bottom: 16px;
	font-size: 14px;
}

/* Success */
.ftcc-form .ftcc-success {
	text-align: center;
	padding: 20px 10px;
}
.ftcc-form .ftcc-success-icon {
	width: 64px;
	height: 64px;
	margin: 0 auto 18px;
	background: var(--ftcc-primary-soft) !important;
	background-color: var(--ftcc-primary-soft) !important;
	color: var(--ftcc-primary) !important;
	border-radius: 999px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.ftcc-form .ftcc-success-icon .ftcc-check {
	font-size: 36px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	color: var(--ftcc-primary) !important;
}
.ftcc-form .ftcc-success h2 {
	font-size: 22px !important;
	font-weight: 700 !important;
	color: var(--ftcc-black) !important;
	margin-bottom: 8px !important;
}
.ftcc-form .ftcc-success p { color: var(--ftcc-muted) !important; }

/* Screen-reader only */
.ftcc-form .ftcc-sr-only {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	margin: -1px !important;
	padding: 0 !important;
	overflow: hidden !important;
	clip: rect(0,0,0,0) !important;
	border: 0 !important;
}
