/* ==========================================================================
   RedCommerce Multi-Step CF7
   Inherits accent color, fonts, and button styling from Salient / Nectar.
   ========================================================================== */

.rc-multistep {
	/* Salient accent → fallback chain */
	--rc-accent: var(--nectar-accent-color, #00b8d9);
	--rc-accent-hover: var(--nectar-accent-color, #00a3c4);
	--rc-line-bg: rgba(255, 255, 255, 0.12);
	--rc-circle-border: rgba(255, 255, 255, 0.2);
	--rc-circle-text: rgba(255, 255, 255, 0.35);
	--rc-error: #ef4444;
	--rc-btn-radius: 10px;

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

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

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

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

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

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

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

/* ==========================================================================
   Standalone input styling (when NOT inside popup)
   Match the popup's field appearance so both look identical.
   ========================================================================== */

.rc-multistep input[type="text"],
.rc-multistep input[type="email"],
.rc-multistep input[type="tel"],
.rc-multistep input[type="number"],
.rc-multistep input[type="url"],
.rc-multistep input[type="search"],
.rc-multistep input[type="date"],
.rc-multistep textarea,
.rc-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: 10px !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;
}

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

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

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

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

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

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

.rc-multistep .rc-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(--rc-circle-border) !important;
	background: transparent !important;
	color: var(--rc-circle-text) !important;
	padding: 0 !important;
	margin: 0 !important;
	line-height: 1 !important;
	box-shadow: none;
}

.rc-multistep .rc-step-circle.active {
	background: var(--rc-accent) !important;
	border-color: var(--rc-accent) !important;
	color: #fff !important;
	box-shadow: 0 2px 8px rgba(0, 184, 217, 0.35) !important;
}

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

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

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

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

.rc-multistep fieldset.rc-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;
}

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

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

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

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

/* Hide the CF7 submit button — our shared button triggers it. */
.rc-multistep input[type="submit"],
.rc-multistep button[type="submit"],
.rc-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 — inherit Salient styling
   ========================================================================== */

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

.rc-multistep .rc-btn-group .rc-btn-next {
	flex: 1 1 auto !important;
	padding: var(--rc-btn-padding, 14px 24px) !important;
	background: var(--rc-accent) !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--rc-btn-radius) !important;
	font-size: var(--rc-btn-size, 16px) !important;
	font-weight: var(--rc-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(--rc-btn-spacing, 0.5px) !important;
	text-transform: var(--rc-btn-transform, none) !important;
}

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

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

.rc-multistep .rc-btn-group .rc-btn-back {
	padding: var(--rc-btn-padding, 14px 18px) !important;
	background: transparent !important;
	color: inherit !important;
	border: 2px solid rgba(255, 255, 255, 0.15) !important;
	border-radius: var(--rc-btn-radius) !important;
	font-size: var(--rc-btn-size, 16px) !important;
	font-weight: var(--rc-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(--rc-btn-spacing, 0.5px) !important;
	text-transform: var(--rc-btn-transform, none) !important;
	opacity: 0.5;
}

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

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

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

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

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

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

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

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

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

.rc-multistep .rc-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;
}

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

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

/* ==========================================================================
   Google Places Autocomplete compatibility
   ========================================================================== */

.rc-multistep .wpcf7-gmautocomplete {
	width: 100%;
}

.pac-container {
	z-index: 999999 !important;
}

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

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

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

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

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

.rc-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;
}

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

.rc-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: 8px;
	font-size: 14px;
}

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

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

/* Popup (white background) overrides */
.rc-popup .rc-review-row {
	background: #f8f9fa !important;
}

.rc-popup .rc-review-label {
	color: #868e96 !important;
	opacity: 1 !important;
}

.rc-popup .rc-review-value {
	color: #212529 !important;
}

.rc-popup .rc-review-title {
	color: #adb5bd !important;
	opacity: 1 !important;
}

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

.rc-multistep .rc-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(--rc-btn-radius, 10px) !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;
}

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

/* Popup version */
.rc-popup .rc-multistep .rc-btn-retry {
	border-color: #dee2e6 !important;
	color: #6c757d !important;
	opacity: 1;
}

.rc-popup .rc-multistep .rc-btn-retry:hover {
	border-color: #adb5bd !important;
	color: #343a40 !important;
}

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

.rc-choice-group {
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	margin-bottom: 4px;
}

.rc-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 rgba(255, 255, 255, 0.15);
	border-radius: 10px;
	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;
}

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

/* :has() for modern browsers */
.rc-choice-item:has(.rc-choice-radio:checked),
.rc-choice-item.selected {
	border-color: var(--rc-accent);
	background: rgba(0, 184, 217, 0.12);
}

.rc-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;
}

.rc-choice-icon {
	font-size: 28px;
	line-height: 1;
	color: inherit;
	opacity: 0.65;
	transition: opacity 0.15s ease, color 0.15s ease;
}

/* Built-in inline SVG sizing */
.rc-choice-icon svg {
	width: 28px;
	height: 28px;
	display: block;
}

/* Salient nectar_icon output inside choice cards */
.rc-choice-icon--nectar .nectar_icon,
.rc-choice-icon--nectar .nectar_icon_wrap {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 28px !important;
	height: 28px !important;
}

.rc-choice-icon--nectar .nectar_icon svg,
.rc-choice-icon--nectar .nectar_icon img {
	width: 28px !important;
	height: 28px !important;
	display: block !important;
}

.rc-choice-icon--nectar i[class*="im-icon-"] {
	font-size: 28px !important;
	line-height: 1 !important;
}

.rc-choice-item:has(.rc-choice-radio:checked) .rc-choice-icon,
.rc-choice-item.selected .rc-choice-icon {
	opacity: 1;
	color: var(--rc-accent);
}

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

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

/* Popup (white background) overrides */
.rc-popup .rc-choice-item {
	border-color: #e9ecef;
	background: #f8f9fa;
	color: #212529;
}

.rc-popup .rc-choice-item:hover {
	border-color: var(--rc-accent);
	background: #eef9fb;
}

.rc-popup .rc-choice-item:has(.rc-choice-radio:checked),
.rc-popup .rc-choice-item.selected {
	border-color: var(--rc-accent);
	background: rgba(0, 184, 217, 0.08);
}

.rc-popup .rc-choice-item .rc-choice-icon {
	opacity: 0.5;
}

.rc-popup .rc-choice-item:has(.rc-choice-radio:checked) .rc-choice-icon,
.rc-popup .rc-choice-item.selected .rc-choice-icon {
	opacity: 1;
	color: var(--rc-accent);
}

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

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

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

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

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