/* ── Sidebar Form Section ── */

.op-sidebar-form {
	--_sf-bg: rgba(var(--op-rgb-parchment), 0.14);
	--_sf-fill: var(--op-color-parchment);
	--_sf-fg-rgb: var(--op-rgb-parchment);
	--_sf-input-bg: rgba(var(--op-rgb-parchment), 0.05);
	--_sf-input-bg-hover: rgba(var(--op-rgb-parchment), 1);
	--_sf-input-bg-focus: rgba(var(--op-rgb-parchment), 1);
	--_sf-input-border: rgba(var(--op-rgb-parchment), 0.12);
	--_sf-input-border-hover: rgba(var(--op-rgb-parchment), 0.2);
	--_sf-choice-bg: rgba(var(--op-rgb-parchment), 0.04);
	--_sf-choice-bg-hover: rgba(var(--op-rgb-parchment), 0.09);
	--_sf-choice-border: rgba(var(--op-rgb-parchment), 0.1);
	--_sf-choice-border-hover: rgba(var(--op-rgb-parchment), 0.18);
	--op-eyebrow-color: var(--op-color-faded-gold);
	--op-eyebrow-line-color: var(--op-color-terracotta);
	--op-heading-color: var(--op-color-parchment);
	--op-highlight-color: var(--op-color-faded-gold);
	--op-text-color: rgba(var(--op-rgb-parchment), 0.65);
	--op-card-bg: rgba(var(--op-rgb-parchment), 0.06);
	--op-card-border: rgba(var(--op-rgb-parchment), 0.1);
	--op-icon-bg: rgba(var(--op-rgb-dusk), 0.15);
	--op-icon-color: var(--op-color-terracotta-light);
	background-color: var(--op-color-deep-ink);
}

.op-sidebar-form.is-style-parchment {
	--_sf-bg: rgba(var(--op-rgb-white), 1);
	--_sf-fill: var(--op-color-deep-ink);
	--_sf-fg-rgb: var(--op-rgb-deep-ink);
	--_sf-input-bg: rgba(var(--op-rgb-white), 0.94);
	--_sf-input-bg-hover: rgba(var(--op-rgb-white), 1);
	--_sf-input-bg-focus: rgba(var(--op-rgb-white), 1);
	--_sf-input-border: rgba(var(--op-rgb-deep-ink), 0.14);
	--_sf-input-border-hover: rgba(var(--op-rgb-deep-ink), 0.24);
	--_sf-choice-bg: rgba(var(--op-rgb-white), 0.82);
	--_sf-choice-bg-hover: rgba(var(--op-rgb-white), 1);
	--_sf-choice-border: rgba(var(--op-rgb-deep-ink), 0.12);
	--_sf-choice-border-hover: rgba(var(--op-rgb-deep-ink), 0.22);
}

.op-sidebar-form__inner {
	max-width: var(--op-container);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 5fr 7fr;
	gap: var(--wp--preset--spacing--2-xl);
	align-items: start;
	position: relative;
	z-index: 1;
}

/* ── Sidebar (sticky left) ── */

.op-sidebar-form__sidebar {
	min-width: 0;
}

.op-sidebar-form__sticky {
	position: sticky;
	top: 112px;
}

/* ── Eyebrow ── */

/* ── Headline ── */

/* Typography handled by .op-headline atomic class */

/* ── Body ── */

.op-sidebar-form__body {
	margin-bottom: var(--op-text-gap-3xl);
}

/* ── Sidebar progress indicator ── */

.op-sidebar-form__progress {
	display: flex;
	flex-direction: column;
	gap: 0;
	position: relative;
}

.op-sidebar-form__progress::before {
	content: '';
	position: absolute;
	left: 5px;
	top: 14px;
	bottom: 14px;
	width: 1px;
	background-color: rgba(var(--_sf-fg-rgb), 0.12);
}

.op-sidebar-form__progress-step {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 0;
	position: relative;
	cursor: default;
	transition: opacity 0.3s ease;
}

.op-sidebar-form__progress-step.is-completed {
	cursor: pointer;
}

.op-sidebar-form__progress-dot {
	width: 11px;
	height: 11px;
	border-radius: 50%;
	background-color: rgba(var(--_sf-fg-rgb), 0.2);
	flex-shrink: 0;
	position: relative;
	z-index: 1;
	transition:
		background-color 0.3s ease,
		box-shadow 0.3s ease;
}

.op-sidebar-form__progress-step.is-active .op-sidebar-form__progress-dot {
	background-color: var(--op-color-dusk);
	box-shadow: 0 0 0 4px rgba(var(--op-rgb-dusk), 0.2);
}

.op-sidebar-form__progress-step.is-completed .op-sidebar-form__progress-dot {
	background-color: var(--op-color-dusk);
}

.op-sidebar-form__progress-step.is-completed
	.op-sidebar-form__progress-dot::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 5px;
	height: 3px;
	border-left: 1.5px solid var(--op-color-deep-ink);
	border-bottom: 1.5px solid var(--op-color-deep-ink);
	transform: translate(-50%, -60%) rotate(-45deg);
}

.op-sidebar-form__progress-num {
	font-family: var(--wp--preset--font-family--heading);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.1em;
	color: rgba(var(--_sf-fg-rgb), 0.35);
	transition: color 0.3s ease;
}

.op-sidebar-form__progress-step.is-active .op-sidebar-form__progress-num {
	color: rgba(var(--op-rgb-dusk), 0.8);
}

.op-sidebar-form__progress-step.is-completed .op-sidebar-form__progress-num {
	color: rgba(var(--op-rgb-dusk), 0.5);
}

.op-sidebar-form__progress-label {
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--normal);
	color: rgba(var(--_sf-fg-rgb), 0.42);
	transition: color 0.3s ease;
}

.op-sidebar-form__progress-step.is-active .op-sidebar-form__progress-label {
	color: rgba(var(--_sf-fg-rgb), 0.85);
}

.op-sidebar-form__progress-step.is-completed .op-sidebar-form__progress-label {
	color: rgba(var(--_sf-fg-rgb), 0.62);
}

.op-sidebar-form__progress-step.is-completed:hover
	.op-sidebar-form__progress-label {
	color: rgba(var(--_sf-fg-rgb), 0.75);
}

/* ── Form column ── */

.op-sidebar-form__form-col {
	min-width: 0;
}

/* ── CF7 resets ── */

.op-sidebar-form .wpcf7 {
	margin: 0;
	padding: 0;
}

.op-sidebar-form .wpcf7-form {
	margin: 0;
	padding: 0;
}

.op-sidebar-form .orba-form__intro {
	margin-bottom: var(--wp--preset--spacing--lg);
}

.op-sidebar-form .orba-form--fit-check .orba-form__intro {
	display: none;
}

.op-sidebar-form .orba-form__title {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: var(--wp--custom--line-height--tight);
	color: var(--_sf-fill);
	margin-bottom: var(--wp--preset--spacing--2-xs);
}

.op-sidebar-form .orba-form__text {
	font-family: var(--wp--preset--font-family--accent);
	font-size: var(--wp--preset--font-size--base);
	font-style: italic;
	line-height: var(--wp--custom--line-height--body);
	color: rgba(var(--_sf-fg-rgb), 0.62);
}

.op-sidebar-form .orba-field br,
.op-sidebar-form .orba-field__group br {
	display: none;
}

.op-sidebar-form .orba-field > p,
.op-sidebar-form .orba-field__group > p {
	padding: 0;
	margin: 0;
}

.op-sidebar-form .wpcf7-form-control-wrap {
	display: block;
}

/* ── Progress bar ── */

.op-sidebar-form__bar {
	height: 2px;
	background-color: rgba(var(--_sf-fg-rgb), 0.12);
	border-radius: 2px;
	overflow: hidden;
	margin-bottom: var(--op-text-gap-xl);
}

.op-sidebar-form__bar--bottom {
	margin-bottom: 0;
	margin-top: var(--wp--preset--spacing--lg);
}

.op-sidebar-form__bar-fill {
	height: 100%;
	width: 100%;
	background-color: var(--op-color-dusk);
	border-radius: 2px;
	transform-origin: left center;
	transform: scaleX(0.25);
}

/* ── Step visibility ── */

.op-sidebar-form .orba-form__step {
	display: block;
}

.op-sidebar-form .orba-form--fit-check .orba-form__step {
	display: none;
}

.op-sidebar-form .orba-form--fit-check .orba-form__step.is-active {
	display: block;
}

.op-sidebar-form .orba-form--contact .orba-form__step-header {
	display: none;
}

/* ── Step header ── */

.op-sidebar-form .orba-form__step-header {
	margin-bottom: var(--op-text-gap-xl);
}

.op-sidebar-form .orba-form__eyebrow {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	letter-spacing: 1.4px;
	color: rgba(var(--op-rgb-dusk), 0.5);
	text-transform: uppercase;
	margin-bottom: var(--op-text-gap-xs);
}

.op-sidebar-form .orba-form__step-title {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--xl-plus);
	font-weight: 700;
	line-height: 1.2;
	color: var(--_sf-fill);
	margin-bottom: var(--op-text-gap-xs);
}

.op-sidebar-form .orba-form__step-text {
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--normal);
	line-height: var(--wp--custom--line-height--body);
	color: rgba(var(--_sf-fg-rgb), 0.68);
}

/* ── Fields ── */

.op-sidebar-form .orba-form__fields {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--sm);
}

.op-sidebar-form .orba-field {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

.op-sidebar-form .orba-field__label {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--xs);
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(var(--_sf-fg-rgb), 0.64);
	line-height: 1.4;
}

.op-sidebar-form .orba-field__optional {
	font-weight: 400;
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--xs);
	letter-spacing: 0;
	text-transform: none;
	color: rgba(var(--_sf-fg-rgb), 0.46);
}

/* ── Inputs ── */

.op-sidebar-form .orba-field__input,
.op-sidebar-form .wpcf7-form-control.wpcf7-text,
.op-sidebar-form .wpcf7-form-control.wpcf7-email,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel,
.op-sidebar-form .wpcf7-form-control.wpcf7-url,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea {
	background-color: var(--_sf-input-bg);
	border: 1px solid var(--_sf-input-border);
	border-radius: var(--wp--custom--border-radius--base);
	padding: 14px 16px;
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--sm);
	line-height: var(--wp--custom--line-height--normal);
	color: var(--_sf-fill);
	transition:
		border-color 0.25s ease,
		background-color 0.25s ease,
		box-shadow 0.25s ease;
	outline: none;
	width: 100%;
	box-sizing: border-box;
}

.op-sidebar-form .orba-field__input::-moz-placeholder, .op-sidebar-form .wpcf7-form-control.wpcf7-text::-moz-placeholder, .op-sidebar-form .wpcf7-form-control.wpcf7-email::-moz-placeholder, .op-sidebar-form .wpcf7-form-control.wpcf7-tel::-moz-placeholder, .op-sidebar-form .wpcf7-form-control.wpcf7-url::-moz-placeholder, .op-sidebar-form .wpcf7-form-control.wpcf7-textarea::-moz-placeholder {
	color: rgba(var(--_sf-fg-rgb), 0.45);
}

.op-sidebar-form .orba-field__input::placeholder,
.op-sidebar-form .wpcf7-form-control.wpcf7-text::placeholder,
.op-sidebar-form .wpcf7-form-control.wpcf7-email::placeholder,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel::placeholder,
.op-sidebar-form .wpcf7-form-control.wpcf7-url::placeholder,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea::placeholder {
	color: rgba(var(--_sf-fg-rgb), 0.45);
}

.op-sidebar-form .orba-field__input:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-text:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-email:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-url:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea:hover {
	background-color: var(--_sf-input-bg-hover);
	border-color: var(--_sf-input-border-hover);
}

.op-sidebar-form .orba-field__input:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-text:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-email:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-url:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea:focus {
	border-color: rgba(var(--op-rgb-dusk), 0.5);
	background-color: var(--_sf-input-bg-focus);
	box-shadow: 0 0 0 3px rgba(var(--op-rgb-dusk), 0.12);
}

.op-sidebar-form .orba-field__input.is-invalid,
.op-sidebar-form .wpcf7-form-control.wpcf7-not-valid {
	border-color: rgba(var(--op-rgb-error), 0.6);
	box-shadow: 0 0 0 3px rgba(var(--op-rgb-error), 0.1);
}

/* Autofill override */
.op-sidebar-form .orba-field__input:-webkit-autofill,
.op-sidebar-form .orba-field__input:-webkit-autofill:hover,
.op-sidebar-form .orba-field__input:-webkit-autofill:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-text:-webkit-autofill,
.op-sidebar-form .wpcf7-form-control.wpcf7-text:-webkit-autofill:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-text:-webkit-autofill:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-email:-webkit-autofill,
.op-sidebar-form .wpcf7-form-control.wpcf7-email:-webkit-autofill:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-email:-webkit-autofill:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel:-webkit-autofill,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel:-webkit-autofill:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-tel:-webkit-autofill:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-url:-webkit-autofill,
.op-sidebar-form .wpcf7-form-control.wpcf7-url:-webkit-autofill:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-url:-webkit-autofill:focus,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea:-webkit-autofill,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea:-webkit-autofill:hover,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea:-webkit-autofill:focus {
	-webkit-text-fill-color: var(--_sf-fill);
	-webkit-box-shadow: 0 0 0 1000px var(--_sf-bg) inset;
	-webkit-transition: background-color 5000s ease-in-out 0s;
	transition: background-color 5000s ease-in-out 0s;
}

/* Textarea */
.op-sidebar-form .orba-field__input--textarea,
.op-sidebar-form .wpcf7-form-control.wpcf7-textarea {
	max-height: 120px;
	resize: vertical;
}

/* ── Radio fields ── */

.op-sidebar-form .orba-field--radio fieldset {
	border: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

.op-sidebar-form .orba-field--radio legend,
.op-sidebar-form .orba-field__group > .orba-field__label {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--xs);
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(var(--_sf-fg-rgb), 0.64);
	line-height: 1.4;
	margin-bottom: 0;
}

.op-sidebar-form .wpcf7-radio,
.op-sidebar-form .wpcf7-checkbox,
.op-sidebar-form .orba-field__choice {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

.op-sidebar-form .wpcf7-list-item {
	display: block;
	background-color: var(--_sf-choice-bg);
	border: 1px solid var(--_sf-choice-border);
	border-radius: var(--wp--custom--border-radius--base);
	cursor: pointer;
	transition:
		border-color 0.2s ease,
		background-color 0.2s ease;
	margin: 0;
	padding: 0;
}

.op-sidebar-form .wpcf7-list-item:hover {
	background-color: var(--_sf-choice-bg);
	border-color: var(--_sf-choice-border-hover);
}

.op-sidebar-form .wpcf7-list-item label {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	width: 100%;
	padding: 12px 16px;
}

.op-sidebar-form .wpcf7-list-item input[type='radio'],
.op-sidebar-form .wpcf7-list-item input[type='checkbox'] {
	-moz-appearance: none;
	     appearance: none;
	-webkit-appearance: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(var(--_sf-fg-rgb), 0.24);
	background: transparent;
	flex-shrink: 0;
	transition:
		border-color 0.2s ease,
		background-color 0.2s ease;
	cursor: pointer;
	margin: 0;
	padding: 0;
}

.op-sidebar-form .wpcf7-list-item input[type='radio'] {
	border-radius: 50%;
}

.op-sidebar-form .wpcf7-list-item input[type='checkbox'] {
	border-radius: 4px;
}

.op-sidebar-form .wpcf7-list-item input[type='radio']:checked {
	border-color: var(--op-color-dusk);
	background: var(--op-color-dusk);
	box-shadow: inset 0 0 0 3px var(--op-color-deep-ink);
}

.op-sidebar-form .wpcf7-list-item input[type='checkbox']:checked {
	background: var(--op-color-dusk);
	border-color: var(--op-color-dusk);
	box-shadow: inset 0 0 0 2px var(--op-color-deep-ink);
}

.op-sidebar-form .wpcf7-list-item .wpcf7-list-item-label {
	font-family: var(--wp--preset--font-family--heading);
	font-size: 15px;
	color: rgba(var(--_sf-fg-rgb), 0.78);
	line-height: var(--wp--custom--line-height--compact);
}

/* ── Contact form desktop layout ── */

@media (min-width: 961px) {
	.op-sidebar-form:not(.is-layout-super-compact) .orba-form--contact .orba-form__fields {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--wp--preset--spacing--sm);
	}

	.op-sidebar-form:not(.is-layout-super-compact)
		.orba-form--contact
		.orba-field[data-field='message'],
	.op-sidebar-form:not(.is-layout-super-compact)
		.orba-form--contact
		.orba-field[data-field='interest'],
	.op-sidebar-form:not(.is-layout-super-compact)
		.orba-form--contact
		.orba-field[data-field='best-time-contact'] {
		grid-column: 1 / -1;
	}

	.op-sidebar-form:not(.is-layout-super-compact)
		.orba-form--contact
		.orba-field--radio
		.wpcf7-checkbox,
	.op-sidebar-form:not(.is-layout-super-compact)
		.orba-form--contact
		.orba-field--radio
		.orba-field__choice {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--wp--preset--spacing--xs);
	}
}

/* ── Navigation ── */

.op-sidebar-form__nav {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--sm);
	margin-top: var(--wp--preset--spacing--xl);
}

.op-sidebar-form__nav-back:focus-visible,
.op-sidebar-form__nav-next:focus-visible {
	outline: 2px solid rgba(var(--op-rgb-dusk), 0.5);
	outline-offset: 2px;
}

.op-sidebar-form__nav-next {
	margin-left: auto;
	font-weight: 600;
	padding: 14px 32px;
}

/* ── CF7 submit ── */

/* Hide default actions on multi-step forms (JS provides its own nav) */
.op-sidebar-form .orba-form--fit-check .orba-form__actions {
	display: none;
}

/* Show actions on single-page forms */
.op-sidebar-form .orba-form__actions {
	display: block;
	margin-top: var(--wp--preset--spacing--md);
}

.op-sidebar-form .orba-form__submit {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	gap: 12px;
	margin-left: auto;
}

.op-sidebar-form .orba-form__submit p {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: var(--wp--preset--spacing--xs);
	margin: 0;
}

.op-sidebar-form .orba-form--contact .orba-form__submit {
	display: block;
	margin-left: 0;
	width: 100%;
}

.op-sidebar-form .orba-button--primary,
.op-sidebar-form .wpcf7-submit {
	background-color: var(--op-color-dusk);
	color: var(--op-color-white);
	border: 1px solid transparent;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	line-height: 1.5;
	padding: 14px 28px;
	white-space: nowrap;
	cursor: pointer;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		box-shadow 0.2s ease;
}

.op-sidebar-form .orba-form--contact .wpcf7-submit {
	display: block;
	width: auto;
	flex: 1 1 auto;
}

.op-sidebar-form .orba-button--primary:hover,
.op-sidebar-form .wpcf7-submit:hover {
	background-color: var(--op-color-dusk-light);
}

.op-sidebar-form .orba-button--primary:focus-visible,
.op-sidebar-form .wpcf7-submit:focus-visible {
	outline: 2px solid rgba(var(--op-rgb-dusk), 0.5);
	outline-offset: 2px;
}

/* Loading state */
.op-sidebar-form .wpcf7-form.submitting .op-sidebar-form__nav,
.op-sidebar-form .wpcf7-form.submitting .orba-form__submit {
	opacity: 0.6;
	pointer-events: none;
}

.op-sidebar-form .wpcf7-spinner {
	display: inline-block;
	vertical-align: middle;
	order: 1;
	background-color: rgba(var(--_sf-fg-rgb), 0.3);
}

.op-sidebar-form .wpcf7-spinner::before {
	background-color: var(--_sf-fill);
}

/* ── CF7 validation and response messages ── */

.op-sidebar-form .wpcf7-not-valid-tip {
	display: none;
	color: rgba(var(--op-rgb-error), 0.9);
	font-family: var(--wp--preset--font-family--body);
	font-size: 13px;
	margin-top: 6px;
	line-height: var(--wp--custom--line-height--compact);
}

.op-sidebar-form .wpcf7-form.invalid .wpcf7-not-valid-tip,
.op-sidebar-form .wpcf7-form[data-status='invalid'] .wpcf7-not-valid-tip,
.op-sidebar-form .wpcf7-form.unaccepted .wpcf7-not-valid-tip,
.op-sidebar-form .wpcf7-form[data-status='unaccepted'] .wpcf7-not-valid-tip {
	display: block;
}

.op-sidebar-form .wpcf7-response-output {
	border-color: rgba(var(--op-rgb-error), 0.4) !important;
	background-color: rgba(var(--op-rgb-error), 0.08);
	color: rgba(var(--_sf-fg-rgb), 0.78);
	border-radius: var(--wp--custom--border-radius--base);
	padding: 16px !important;
	margin: 24px 0 0 !important;
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--sm);
	line-height: var(--wp--custom--line-height--normal);
}

.op-sidebar-form .wpcf7-mail-sent-ok {
	border-color: rgba(var(--op-rgb-success), 0.4) !important;
	background-color: rgba(var(--op-rgb-success), 0.08);
}

/* ── Success state ── */

.op-sidebar-form__success {
	text-align: center;
	padding: 80px 40px;
}

.op-sidebar-form__success-icon {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background-color: rgba(var(--op-rgb-dusk), 0.15);
	color: var(--op-color-dusk);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 24px;
}

.op-sidebar-form__success-title {
	font-family: var(--wp--preset--font-family--heading);
	font-size: 32px;
	font-weight: 700;
	color: var(--_sf-fill);
	margin-bottom: var(--op-text-gap-sm);
}

.op-sidebar-form__success-text {
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--normal);
	line-height: var(--wp--custom--line-height--relaxed);
	color: rgba(var(--_sf-fg-rgb), 0.68);
	max-width: 400px;
	margin-inline: auto;
}

.op-sidebar-form__summary-table {
	width: 100%;
	max-width: 360px;
	margin: 20px auto 0;
	border-collapse: collapse;
	font-family: var(--wp--preset--font-family--body);
	font-size: 13px;
	line-height: var(--wp--custom--line-height--normal);
}

.op-sidebar-form__summary-table tr + tr {
	border-top: 1px solid rgba(var(--_sf-fg-rgb), 0.12);
}

.op-sidebar-form__summary-table td {
	padding: 7px 0;
	vertical-align: top;
}

.op-sidebar-form__summary-label {
	color: rgba(var(--_sf-fg-rgb), 0.45);
	white-space: nowrap;
	padding-right: 20px;
	text-align: left;
}

.op-sidebar-form__summary-value {
	color: rgba(var(--_sf-fg-rgb), 0.7);
	text-align: right;
	word-break: break-word;
}

/* ── Success signature ── */

.op-sidebar-form__success-signature {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--wp--preset--spacing--sm);
	margin-top: var(--wp--preset--spacing--lg);
}

.op-sidebar-form__success-sig-line {
	display: block;
	width: 40px;
	height: 1px;
	background: var(--op-color-dusk);
	flex-shrink: 0;
}

.op-sidebar-form__success-sig-text {
	font-family: var(--wp--preset--font-family--accent);
	font-size: var(--wp--preset--font-size--base);
	font-style: italic;
	line-height: 20px;
	color: rgba(var(--_sf-fg-rgb), 0.82);
}

/* ── Hide sidebar progress on success ── */

.op-sidebar-form__sidebar.is-success .op-sidebar-form__progress {
	display: none;
}

/* ── Resubmit notice ── */

.op-sidebar-form__resubmit {
	margin-top: var(--wp--preset--spacing--xl);
	padding-top: var(--wp--preset--spacing--lg);
	border-top: 1px solid rgba(var(--_sf-fg-rgb), 0.12);
}

.op-sidebar-form__resubmit-hint {
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--sm);
	line-height: var(--wp--custom--line-height--body);
	color: rgba(var(--_sf-fg-rgb), 0.52);
	margin-bottom: var(--op-text-gap-md);
}

.op-sidebar-form__resubmit-btn {
	padding: 10px 24px;
	font-size: 0.875rem;
	color: rgba(var(--_sf-fg-rgb), 0.72);
}

.op-sidebar-form__resubmit-btn:focus-visible {
	outline: 2px solid rgba(var(--op-rgb-dusk), 0.5);
	outline-offset: 2px;
}

/* ── Layout: reduced section padding for non-large ── */

.op-sidebar-form.is-layout-standard {
	padding-top: 96px;
	padding-bottom: 96px;
}

.op-sidebar-form.is-layout-centered {
	padding-top: 80px;
	padding-bottom: 80px;
}

.op-sidebar-form.is-layout-super-compact {
	padding-top: 48px;
	padding-bottom: 48px;
}

/* ── Layout: standard (narrower 2-column) ── */

.op-sidebar-form.is-layout-standard .op-sidebar-form__inner {
	max-width: 960px;
	grid-template-columns: 4fr 8fr;
	gap: var(--wp--preset--spacing--xl);
}

/* ── Layout: centered (single-column centered) ── */

.op-sidebar-form.is-layout-centered .op-sidebar-form__inner {
	max-width: 640px;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

.op-sidebar-form.is-layout-centered .op-sidebar-form__sidebar {
	text-align: center;
}

.op-sidebar-form.is-layout-centered .op-sidebar-form__sticky {
	position: static;
}

.op-sidebar-form.is-layout-centered .op-sidebar-form__body {
	margin-bottom: var(--op-text-gap-sm);
}

.op-sidebar-form.is-layout-centered .op-eyebrow {
	justify-content: center;
}

/* ── Layout: super-compact (inline CTA bar) ── */

.op-sidebar-form.is-layout-super-compact .op-sidebar-form__inner {
	max-width: var(--op-container);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--wp--preset--spacing--md) var(--wp--preset--spacing--xl);
}

.op-sidebar-form.is-layout-super-compact .op-sidebar-form__sidebar {
	flex: 1 1 auto;
	min-width: 200px;
}

.op-sidebar-form.is-layout-super-compact .op-sidebar-form__sticky {
	position: static;
}

.op-sidebar-form.is-layout-super-compact .op-sidebar-form__body {
	margin-bottom: 0;
}

.op-sidebar-form.is-layout-super-compact .op-sidebar-form__form-col {
	flex: 1 1 320px;
	min-width: 0;
}

/* Flatten the form fields into a single row for super-compact */
.op-sidebar-form.is-layout-super-compact .orba-form__intro {
	display: none;
}

.op-sidebar-form.is-layout-super-compact .orba-form__fields {
	flex-direction: row;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: var(--wp--preset--spacing--sm);
}

.op-sidebar-form.is-layout-super-compact .orba-field {
	flex: 1 1 180px;
	min-width: 0;
}

.op-sidebar-form.is-layout-super-compact .orba-form__actions {
	display: flex;
	margin-top: 0;
}

.op-sidebar-form.is-layout-super-compact .orba-form__submit {
	flex-direction: row;
	margin-left: 0;
}

.op-sidebar-form.is-layout-super-compact .wpcf7-submit,
.op-sidebar-form.is-layout-super-compact .orba-button--primary {
	white-space: nowrap;
}

/* Hide progress bar and step headers in super-compact */
.op-sidebar-form.is-layout-super-compact .op-sidebar-form__bar,
.op-sidebar-form.is-layout-super-compact .op-sidebar-form__progress,
.op-sidebar-form.is-layout-super-compact .orba-form__step-header,
.op-sidebar-form.is-layout-super-compact .op-sidebar-form__nav {
	display: none;
}

/* All steps visible in super-compact (no multi-step) */
.op-sidebar-form.is-layout-super-compact .orba-form__step {
	display: block;
}

/* ── Responsive: tablet ── */

@media (max-width: 960px) {
	.op-sidebar-form__inner {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.op-sidebar-form__sticky {
		position: static;
	}

	.op-sidebar-form__headline {
		font-size: 36px;
	}

	.op-sidebar-form__body {
		margin-bottom: var(--op-text-gap-xl);
	}

	.op-sidebar-form__progress {
		flex-direction: row;
		justify-content: space-between;
	}

	.op-sidebar-form__progress::before {
		left: 14px;
		right: 14px;
		top: 5px;
		bottom: auto;
		height: 1px;
		width: auto;
	}

	.op-sidebar-form__progress-step {
		flex-direction: column;
		align-items: center;
		gap: var(--wp--preset--spacing--xs);
		padding: 0;
		flex: 1;
	}

	.op-sidebar-form__progress-num {
		display: none;
	}

	.op-sidebar-form__progress-label {
		font-size: var(--wp--preset--font-size--xs);
		text-align: center;
	}

	/* Standard layout → single column on tablet */
	.op-sidebar-form.is-layout-standard .op-sidebar-form__inner {
		grid-template-columns: 1fr;
	}

	.op-sidebar-form.is-layout-standard {
		padding-top: 72px;
		padding-bottom: 72px;
	}

	.op-sidebar-form.is-layout-centered {
		padding-top: 64px;
		padding-bottom: 64px;
	}

	.op-sidebar-form.is-layout-super-compact {
		padding-top: 40px;
		padding-bottom: 40px;
	}
}

/* ── Responsive: mobile ── */

@media (max-width: 600px) {
	.op-sidebar-form__headline {
		font-size: var(--wp--preset--font-size--xl);
	}

	.op-sidebar-form__body {
		font-size: var(--wp--preset--font-size--normal);
	}

	.op-sidebar-form .orba-form__step-title {
		font-size: 22px;
	}

	.op-sidebar-form__nav {
		flex-direction: column-reverse;
		gap: 12px;
	}

	.op-sidebar-form__nav-next,
	.op-sidebar-form .orba-form__submit {
		margin-left: 0;
	}

	.op-sidebar-form__nav-next,
	.op-sidebar-form .wpcf7-submit,
	.op-sidebar-form .orba-button--primary {
		width: 100%;
		justify-content: center;
	}

	.op-sidebar-form__nav-back {
		width: 100%;
		justify-content: center;
	}

	.op-sidebar-form__success {
		padding: 48px 20px;
	}

	.op-sidebar-form.is-layout-standard {
		padding-top: 48px;
		padding-bottom: 48px;
	}

	.op-sidebar-form.is-layout-centered {
		padding-top: 48px;
		padding-bottom: 48px;
	}

	.op-sidebar-form.is-layout-super-compact {
		padding-top: 32px;
		padding-bottom: 32px;
	}

	/* Super-compact: stack vertically on mobile */
	.op-sidebar-form.is-layout-super-compact .op-sidebar-form__inner {
		flex-direction: column;
		align-items: stretch;
	}

	.op-sidebar-form.is-layout-super-compact .op-sidebar-form__sidebar {
		text-align: center;
	}

	.op-sidebar-form.is-layout-super-compact .op-eyebrow {
		justify-content: center;
	}

	.op-sidebar-form.is-layout-super-compact .orba-form__fields {
		flex-direction: column;
	}

	.op-sidebar-form.is-layout-super-compact .orba-field {
		flex-basis: auto;
	}
}

