/* ==========================================================================
   sd-multistep — Multi-Step CF7 Form
   Standalone plugin, theme-agnostic.
   ========================================================================== */

:root {
  --sd-primary: #3b7a8a;
  --sd-accent: #e38b3f;
  --sd-text-on-primary: #ffffff;
  --sd-text-on-accent: #ffffff;
  --sd-border-radius: 8px;
  --sd-button-radius: 24px;
  --sd-border: #d9e0e3;
}

.sd-multistep {
	/* Accent color chain */
	--sd-accent-hover: var(--sd-primary);
	--sd-line-bg: rgba(255, 255, 255, 0.12);
	--sd-circle-border: rgba(255, 255, 255, 0.2);
	--sd-circle-text: rgba(255, 255, 255, 0.35);
	--sd-error: #ef4444;
	--sd-btn-radius: var(--sd-button-radius);

	/* Inherit font from host theme body */
	font-family: inherit;
}

/* ==========================================================================
   Tight field spacing
   ========================================================================== */

.sd-multistep fieldset.sd-step p {
	margin-top: 0 !important;
	margin-bottom: 10px !important;
}

.sd-multistep fieldset.sd-step > br,
.sd-multistep fieldset.sd-step > p > br,
.sd-multistep fieldset.sd-step > p:empty {
	display: none !important;
}

/* Hide the paragraph wrapping the hidden CF7 submit button */
.sd-multistep fieldset.sd-step > p:has(input[type="submit"]),
.sd-multistep fieldset.sd-step > p:has(.wpcf7-submit) {
	display: none !important;
	margin: 0 !important;
}

.sd-multistep fieldset.sd-step .wpcf7-form-control-wrap {
	display: block;
	margin-bottom: 0;
}

/* Hide back button — single forward flow */
.sd-multistep .sd-btn-back {
	display: none !important;
}

/* ==========================================================================
   Standalone input styling
   ========================================================================== */

.sd-multistep input[type="text"],
.sd-multistep input[type="email"],
.sd-multistep input[type="tel"],
.sd-multistep input[type="number"],
.sd-multistep input[type="url"],
.sd-multistep input[type="search"],
.sd-multistep input[type="date"],
.sd-multistep textarea,
.sd-multistep select {
	display: block !important;
	width: 100% !important;
	box-sizing: border-box !important;
	padding: 14px 16px !important;
	height: auto !important;
	min-height: 0 !important;
	line-height: 1.4 !important;
	font-size: 15px !important;
	font-family: inherit !important;
	background: rgba(255, 255, 255, 0.08) !important;
	border: 1.5px solid rgba(255, 255, 255, 0.18) !important;
	border-radius: var(--sd-border-radius) !important;
	outline: none !important;
	box-shadow: none !important;
	margin: 0 !important;
	transition: border-color 0.15s ease, background 0.15s ease !important;
	-webkit-appearance: none !important;
	appearance: none !important;
}

.sd-multistep input[type="text"]:focus,
.sd-multistep input[type="email"]:focus,
.sd-multistep input[type="tel"]:focus,
.sd-multistep input[type="number"]:focus,
.sd-multistep input[type="url"]:focus,
.sd-multistep textarea:focus,
.sd-multistep select:focus {
	border-color: var(--sd-primary) !important;
	background: rgba(255, 255, 255, 0.12) !important;
}

.sd-multistep input::placeholder,
.sd-multistep textarea::placeholder {
	color: rgba(255, 255, 255, 0.4) !important;
	opacity: 1 !important;
}

.sd-multistep textarea {
	min-height: 80px !important;
	resize: vertical !important;
}

/* ==========================================================================
   Progress indicator
   ========================================================================== */

.sd-multistep .sd-progress {
	margin-bottom: 20px !important;
	padding: 0 4px !important;
}

.sd-multistep .sd-progress-inner {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	width: 100% !important;
}

.sd-multistep .sd-step-circle {
	width: 36px !important;
	height: 36px !important;
	min-width: 36px !important;
	min-height: 36px !important;
	border-radius: 50% !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	flex-shrink: 0 !important;
	transition: all 0.3s ease;
	border: 2px solid var(--sd-circle-border) !important;
	background: transparent !important;
	color: var(--sd-circle-text) !important;
	padding: 0 !important;
	margin: 0 !important;
	line-height: 1 !important;
	box-shadow: none;
}

.sd-multistep .sd-step-circle.active {
	background: var(--sd-primary) !important;
	border-color: var(--sd-primary) !important;
	color: var(--sd-text-on-primary) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
}

.sd-multistep .sd-step-circle.completed {
	background: transparent !important;
	border-color: var(--sd-primary) !important;
	color: var(--sd-primary) !important;
}

.sd-multistep .sd-step-line {
	flex: 1 1 auto !important;
	height: 2px !important;
	min-height: 2px !important;
	background: var(--sd-line-bg) !important;
	position: relative !important;
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

.sd-multistep .sd-step-line-fill {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	height: 100% !important;
	width: 0%;
	background: var(--sd-primary) !important;
	transition: width 0.4s ease;
}

/* ==========================================================================
   Fieldset show / hide
   ========================================================================== */

.sd-multistep fieldset.sd-step {
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	min-width: 0 !important;
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	overflow: hidden !important;
	opacity: 0 !important;
}

.sd-multistep fieldset.sd-step.active {
	display: block !important;
	visibility: visible !important;
	height: auto !important;
	overflow: visible !important;
	opacity: 1 !important;
	max-height: none !important;
	animation: sdSlideIn 0.3s ease;
}

/* Ensure inputs/paragraphs inside active steps are never hidden by theme CSS. */
.sd-multistep fieldset.sd-step.active p,
.sd-multistep fieldset.sd-step.active span,
.sd-multistep fieldset.sd-step.active .wpcf7-form-control-wrap {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	height: auto !important;
	overflow: visible !important;
}

.sd-multistep fieldset.sd-step.active input,
.sd-multistep fieldset.sd-step.active textarea,
.sd-multistep fieldset.sd-step.active select {
	visibility: visible !important;
	opacity: 1 !important;
}

@keyframes sdSlideIn {
	from {
		opacity: 0;
		transform: translateX(10px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Hide the CF7 submit button — our shared button triggers it. */
.sd-multistep input[type="submit"],
.sd-multistep button[type="submit"],
.sd-multistep .wpcf7-submit {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.sd-multistep .sd-btn-group {
	display: flex !important;
	flex-direction: row !important;
	gap: 10px !important;
	margin-top: 12px !important;
}

.sd-multistep .sd-btn-group .sd-btn-next {
	flex: 1 1 auto !important;
	padding: var(--sd-btn-padding, 14px 24px) !important;
	background: var(--sd-accent) !important;
	color: var(--sd-text-on-accent) !important;
	border: none !important;
	border-radius: var(--sd-button-radius) !important;
	font-size: var(--sd-btn-size, 16px) !important;
	font-weight: var(--sd-btn-weight, 700) !important;
	font-family: inherit !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	transition: opacity 0.2s ease, transform 0.1s ease;
	line-height: 1.4 !important;
	text-decoration: none !important;
	letter-spacing: var(--sd-btn-spacing, 0.5px) !important;
	text-transform: var(--sd-btn-transform, none) !important;
}

.sd-multistep .sd-btn-group .sd-btn-next:hover {
	opacity: 0.88;
}

.sd-multistep .sd-btn-group .sd-btn-next:active {
	transform: scale(0.98);
}

.sd-multistep .sd-btn-group .sd-btn-back {
	padding: var(--sd-btn-padding, 14px 18px) !important;
	background: transparent !important;
	color: inherit !important;
	border: 2px solid rgba(255, 255, 255, 0.15) !important;
	border-radius: var(--sd-button-radius) !important;
	font-size: var(--sd-btn-size, 16px) !important;
	font-weight: var(--sd-btn-weight, 700) !important;
	font-family: inherit !important;
	cursor: pointer !important;
	display: none !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 6px !important;
	transition: opacity 0.2s ease, transform 0.1s ease;
	white-space: nowrap !important;
	line-height: 1.4 !important;
	text-decoration: none !important;
	letter-spacing: var(--sd-btn-spacing, 0.5px) !important;
	text-transform: var(--sd-btn-transform, none) !important;
	opacity: 0.5;
}

.sd-multistep .sd-btn-group .sd-btn-back:hover {
	opacity: 0.75;
}

.sd-multistep .sd-btn-group .sd-btn-back:active {
	transform: scale(0.98);
}

.sd-multistep .sd-btn-group .sd-btn-back.visible {
	display: flex !important;
}

/* ==========================================================================
   Validation error styling
   ========================================================================== */

.sd-multistep .wpcf7-not-valid {
	border-color: var(--sd-error) !important;
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}

.sd-multistep .wpcf7-not-valid-tip {
	color: var(--sd-error) !important;
	font-size: 12px !important;
	margin-top: 4px !important;
	padding-left: 4px !important;
}

/* ==========================================================================
   Success message (after CF7 submission)
   ========================================================================== */

.sd-multistep .sd-success-message {
	display: none !important;
	text-align: center !important;
	padding: 20px 0 !important;
}

.sd-multistep .sd-success-message.active {
	display: block !important;
	animation: sdSlideIn 0.3s ease;
}

.sd-multistep .sd-success-icon {
	width: 56px !important;
	height: 56px !important;
	background: #22c55e !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	margin: 0 auto 16px !important;
}

.sd-multistep .sd-success-message h3 {
	font-size: 18px !important;
	color: inherit !important;
	margin-bottom: 8px !important;
}

.sd-multistep .sd-success-message p {
	font-size: 14px !important;
	opacity: 0.7;
}

/* ==========================================================================
   Checkmark animation on step completion
   ========================================================================== */

@keyframes sdCheckBounce {
	0%   { transform: scale(1); }
	40%  { transform: scale(1.35); }
	70%  { transform: scale(0.9); }
	100% { transform: scale(1); }
}

.sd-multistep .sd-step-circle.completing {
	animation: sdCheckBounce 0.38s cubic-bezier(0.36, 0.07, 0.19, 0.97) !important;
}

/* ==========================================================================
   Review panel
   ========================================================================== */

.sd-review-panel {
	margin-bottom: 12px;
	animation: sdSlideIn 0.25s ease;
}

.sd-review-title {
	font-size: 11px !important;
	font-weight: 600 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.6px !important;
	opacity: 0.5;
	margin-bottom: 10px !important;
}

.sd-review-fields {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.sd-review-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 8px 12px;
	background: rgba(255, 255, 255, 0.06);
	border-radius: var(--sd-border-radius);
	font-size: 14px;
}

.sd-review-label {
	opacity: 0.6;
	flex-shrink: 0;
	font-size: 13px;
}

.sd-review-value {
	font-weight: 600;
	text-align: right;
	word-break: break-word;
	min-width: 0;
}

/* ==========================================================================
   Retry button
   ========================================================================== */

.sd-multistep .sd-btn-retry {
	margin-top: 14px !important;
	padding: 9px 22px !important;
	background: transparent !important;
	border: 1.5px solid rgba(255, 255, 255, 0.2) !important;
	border-radius: var(--sd-button-radius) !important;
	color: inherit !important;
	opacity: 0.65;
	cursor: pointer !important;
	font-family: inherit !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	transition: opacity 0.2s ease;
	display: inline-block !important;
}

.sd-multistep .sd-btn-retry:hover {
	opacity: 1 !important;
}

/* ==========================================================================
   sd_choice — clickable card radio buttons
   ========================================================================== */

.sd-choice-group {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 4px;
	justify-content: center;
}

/* Items take up 1/3 of the row minus gap */
.sd-choice-group > .sd-choice-item {
	flex: 1 1 calc(33.333% - 6px);
	max-width: calc(50% - 4px);
}

.sd-choice-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	flex: 1;
	min-width: 0;
	gap: 6px;
	padding: 12px 14px;
	border: 2px solid var(--sd-border);
	border-radius: var(--sd-border-radius);
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease;
	background: rgba(255, 255, 255, 0.04);
	text-align: center;
	user-select: none;
	position: relative;
}

.sd-choice-item:hover {
	border-color: var(--sd-primary);
	background: rgba(255, 255, 255, 0.08);
}

/* :has() for modern browsers */
.sd-choice-item:has(.sd-choice-radio:checked),
.sd-choice-item.selected {
	border-color: var(--sd-primary);
	background: var(--sd-primary);
}

.sd-choice-radio {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

.sd-choice-label {
	font-size: 13px;
	font-weight: 500;
	line-height: 1.2;
}

/* Validation error on sd-choice group */
.sd-choice-group.wpcf7-not-valid {
	outline: 2px solid var(--sd-error);
	outline-offset: 4px;
	border-radius: var(--sd-border-radius);
}

/* ==========================================================================
   Mobile responsive
   ========================================================================== */

@media (max-width: 480px) {
	.sd-multistep .sd-btn-group {
		flex-direction: column !important;
	}

	.sd-multistep .sd-btn-group .sd-btn-back.visible {
		order: 1 !important;
	}

	.sd-multistep .sd-btn-group .sd-btn-next {
		order: 0 !important;
	}

	/* Compact padding on small screens */
	.sd-choice-item {
		padding: 10px 6px;
	}

}

/* ==========================================================================
   Choice indicator (circle checkmark inside each choice card)
   ========================================================================== */

.sd-choice-item .sd-choice-indicator {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--sd-border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  transition: background 0.15s, border-color 0.15s;
}

.sd-choice-item:has(input:checked) .sd-choice-indicator,
.sd-choice-item.is-checked .sd-choice-indicator {
  border-color: var(--sd-text-on-primary);
  background: var(--sd-text-on-primary);
}

.sd-choice-item:has(input:checked) .sd-choice-indicator::after,
.sd-choice-item.is-checked .sd-choice-indicator::after {
  content: "";
  width: 10px;
  height: 5px;
  border-left: 2px solid var(--sd-primary);
  border-bottom: 2px solid var(--sd-primary);
  transform: rotate(-45deg);
  margin-top: -2px;
}

.sd-choice-item:has(input:checked),
.sd-choice-item.is-checked {
  background: var(--sd-primary);
  color: var(--sd-text-on-primary);
  border-color: var(--sd-primary);
}
