/**
 * Core Forms — Smart Forms Styles
 * Multi-step, progress, inline validation, scheduling.
 */

/* Progress Bar */
.cf-progress {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 24px;
	padding: 0 4px;
}

.cf-progress__bar {
	flex: 1;
	height: 6px;
	background: #3858e9;
	border-radius: 3px;
	transition: width 0.3s ease;
}

.cf-progress__text {
	font-size: 13px;
	color: #757575;
	white-space: nowrap;
}

/* Step Indicators */
.cf-steps {
	display: flex;
	gap: 4px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}

.cf-step {
	padding: 6px 16px;
	font-size: 13px;
	border: 1px solid #ddd;
	border-radius: 20px;
	background: #f8f8f8;
	color: #757575;
	cursor: default;
	transition: all 0.2s ease;
	user-select: none;
}

.cf-step.is-active {
	background: #3858e9;
	border-color: #3858e9;
	color: #fff;
	font-weight: 500;
}

.cf-step.is-completed {
	background: #e8edff;
	border-color: #3858e9;
	color: #3858e9;
	cursor: pointer;
}

/* Step Panels */
.cf-step-panel {
	animation: cfFadeIn 0.2s ease;
}

.cf-step-panel.cf-conversational {
	max-width: 600px;
	margin: 0 auto;
}

/* Step Navigation */
.cf-step-nav {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	margin-top: 24px;
	padding-top: 16px;
	border-top: 1px solid #eee;
}

.cf-step-prev,
.cf-step-next {
	padding: 10px 24px;
	font-size: 14px;
	border: 1px solid #ddd;
	border-radius: 4px;
	background: #fff;
	cursor: pointer;
	transition: all 0.15s ease;
}

.cf-step-prev:hover,
.cf-step-next:hover {
	border-color: #3858e9;
	color: #3858e9;
}

.cf-step-next {
	margin-left: auto;
	background: #3858e9;
	border-color: #3858e9;
	color: #fff;
}

.cf-step-next:hover {
	background: #2d47c0;
	color: #fff;
}

/* Inline Validation */
.cf-invalid {
	border-color: #cc1818 !important;
	box-shadow: 0 0 0 1px #cc1818;
}

.cf-field-error {
	display: block;
	margin-top: 4px;
	font-size: 12px;
	color: #cc1818;
	line-height: 1.4;
}

/* Form Closed */
.cf-form-closed {
	padding: 24px;
	text-align: center;
	background: #f8f8f8;
	border: 1px solid #ddd;
	border-radius: 4px;
	color: #757575;
}

/* Animations */
@keyframes cfFadeIn {
	from {
		opacity: 0;
		transform: translateY(8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Calculation fields */
input[data-calculation] {
	background: #f8f8f8;
	cursor: default;
}

/* Draft save indicator */
.cf-draft-saved {
	display: inline-block;
	padding: 4px 12px;
	font-size: 12px;
	color: #388e3c;
	background: #e8f5e9;
	border-radius: 12px;
	margin-top: 8px;
	animation: cfFadeIn 0.3s ease;
}
