/**
 * Custom Form Builder — public / preview presentation
 * Stacks fields vertically (grid), premium inputs, full-width CTA.
 * Brand CTA red aligns with site header buttons (~ #a32126).
 */

.fb-form-shell {
	--fb-surface: #faf8f5;
	--fb-surface-2: #f3efe8;
	--fb-ink: var(--barrington-text-dark, #2e2a20);
	--fb-muted: rgba(46, 42, 32, 0.58);
	--fb-placeholder: rgba(46, 42, 32, 0.42);
	/* Brick red — Barrington Paint marketing / header CTAs */
	--fb-accent: #a32126;
	--fb-ring: rgba(163, 33, 38, 0.26);
	background-color: var(--fb-surface);
	background-image:
		repeating-radial-gradient(circle at 10% 12%, rgba(46, 42, 32, 0.035) 0 1px, transparent 1px 26px),
		repeating-radial-gradient(circle at 90% 78%, rgba(46, 42, 32, 0.028) 0 1px, transparent 1px 22px),
		linear-gradient(180deg, var(--fb-surface) 0%, var(--fb-surface-2) 100%);
}

.fb-custom-form.form-one {
	--fb-accent: #a32126;
	--fb-ring: rgba(163, 33, 38, 0.26);
	max-width: 640px;
	margin-inline: auto;
}

.fb-custom-form.form-one .form-one__group {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.35rem;
	margin: 0;
	align-items: start;
}

@media (min-width: 576px) {
	.fb-custom-form.form-one .form-one__group {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		column-gap: 1.25rem;
		row-gap: 1.35rem;
	}
}

.fb-custom-form.form-one .form-one__control--full {
	grid-column: 1 / -1;
}

.fb-custom-form .fb-field-wrap {
	min-width: 0;
}

.fb-custom-form .fb-field-label {
	display: block;
	margin-bottom: 0.45rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--fb-ink);
	letter-spacing: 0.01em;
	line-height: 1.35;
}

.fb-custom-form .fb-field-label--legend {
	padding: 0;
	margin-bottom: 0.65rem;
}

.fb-custom-form .fb-field-label--select-spacer {
	min-height: 1.35rem;
	margin-bottom: 0.45rem;
	visibility: hidden;
}

.fb-custom-form .fb-field-wrap:has(.fb-field-control[required]:not([type="checkbox"]):not([type="radio"])) .fb-field-label:not(.fb-field-label--select-spacer)::after,
.fb-custom-form .fb-field-wrap:has(textarea[required]) .fb-field-label:not(.fb-field-label--select-spacer)::after,
.fb-custom-form .fb-field-wrap:has(select[required]) .fb-field-label:not(.fb-field-label--select-spacer)::after {
	content: " *";
	color: var(--fb-accent);
	font-weight: 700;
}

.fb-custom-form.form-one .fb-field-control,
.fb-custom-form.form-one select.fb-field-control {
	display: block;
	width: 100%;
	min-height: 3.25rem;
	height: auto;
	padding: 0.85rem 1.15rem;
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.45;
	color: var(--fb-ink);
	background-color: #fff;
	border: 1px solid rgba(228, 218, 204, 0.85);
	border-radius: 14px;
	box-shadow: 0 8px 22px rgba(46, 42, 32, 0.06);
	transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}

.fb-custom-form.form-one textarea.fb-field-control {
	min-height: 9.5rem;
	resize: vertical;
	padding-top: 1rem;
}

.fb-custom-form.form-one .fb-field-control::placeholder {
	color: var(--fb-placeholder);
	opacity: 1;
}

.fb-custom-form.form-one .fb-field-control:hover {
	border-color: rgba(46, 42, 32, 0.18);
}

.fb-custom-form.form-one .fb-field-control:focus {
	outline: none;
	border-color: rgba(163, 33, 38, 0.45);
	box-shadow:
		0 0 0 4px var(--fb-ring),
		0 12px 28px rgba(46, 42, 32, 0.08);
}

.fb-custom-form.form-one .fb-field-control--range {
	min-height: auto;
	padding-block: 0.35rem;
	box-shadow: none;
	border-radius: 999px;
	accent-color: var(--fb-accent);
}

.fb-custom-form.form-one .fb-field-control--file {
	padding: 0.65rem 1rem;
	line-height: 1.4;
}

.fb-custom-form.form-one .fb-field-control--file::file-selector-button {
	margin-right: 12px;
	padding: 0.55rem 1.2rem;
	border-radius: 999px;
	border: none;
	font-family: var(--barrington-font, "Plus Jakarta Sans", system-ui, sans-serif);
	font-weight: 700;
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	background: var(--fb-accent);
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	cursor: pointer;
	box-shadow: 0 3px 14px rgba(163, 33, 38, 0.32);
	transition: filter 0.15s ease, box-shadow 0.15s ease;
}

.fb-custom-form.form-one .fb-field-control--file::file-selector-button:hover {
	filter: brightness(1.06);
	box-shadow: 0 5px 18px rgba(163, 33, 38, 0.38);
}

.fb-custom-form .fb-field-hint {
	display: block;
	margin-top: 0.45rem;
	font-size: 0.8125rem;
	color: var(--fb-muted);
	line-height: 1.4;
}

.fb-custom-form .fb-layout-heading {
	margin: 0.25rem 0 0;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--fb-ink);
	letter-spacing: -0.01em;
}

.fb-custom-form .fb-layout-paragraph {
	margin: 0;
	color: var(--fb-muted);
	font-size: 0.9375rem;
	line-height: 1.55;
}

.fb-custom-form .fb-layout-divider {
	border: 0;
	border-top: 1px solid rgba(228, 218, 204, 0.95);
	opacity: 1;
	margin: 0.35rem 0;
}

.fb-custom-form .fb-field-fieldset {
	border: none;
	padding: 0;
	margin: 0;
	min-width: 0;
}

.fb-custom-form .fb-radio-row {
	display: flex;
	align-items: flex-start;
	gap: 0.55rem;
	margin-bottom: 0.45rem;
}

.fb-custom-form .fb-radio-row:last-child {
	margin-bottom: 0;
}

.fb-custom-form .fb-radio-input {
	margin-top: 0.28rem;
	accent-color: var(--fb-accent);
	transform: scale(1.05);
}

.fb-custom-form .fb-radio-label {
	font-size: 0.9375rem;
	color: var(--fb-ink);
	line-height: 1.45;
}

.fb-custom-form .fb-checkbox-label {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--fb-ink);
}

.fb-custom-form .fb-checkbox-input {
	width: 1.05rem;
	height: 1.05rem;
	accent-color: var(--fb-accent);
}

.fb-custom-form .fb-submit-wrap {
	display: flex;
	justify-content: center;
	padding-top: 0.35rem;
}

/* Submit — same classes as header CTA (.main-header__right__btn.barrington-btn); scoped to custom forms only */
.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn {
	width: auto;
	max-width: 100%;
	min-height: 3.25rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	padding: 14px 22px;
	border-radius: 999px;
	border: none !important;
	font-family: var(--barrington-font, "Plus Jakarta Sans", system-ui, sans-serif);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	text-transform: none;
	white-space: nowrap;
	background: var(--fb-accent) !important;
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	box-shadow:
		0 4px 18px rgba(163, 33, 38, 0.35),
		0 2px 6px rgba(0, 0, 0, 0.08);
	transition: background-color 0.2s ease, transform 0.18s ease, box-shadow 0.18s ease;
	position: relative;
	z-index: 0;
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn i,
.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn .icon-arrow-point-to-right {
	margin-left: 12px;
	font-size: 14px;
	color: #fff !important;
	-webkit-text-fill-color: #fff;
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn .icon-arrow-point-to-right::before {
	color: #fff !important;
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn::before {
	display: none !important;
	content: none !important;
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:focus,
.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:focus-visible {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	background: var(--fb-accent) !important;
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:hover {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	background: #000 !important;
	filter: none !important;
	transform: translateY(-1px);
	box-shadow:
		0 14px 36px rgba(0, 0, 0, 0.28),
		0 4px 12px rgba(0, 0, 0, 0.14);
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:focus i,
.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:active i,
.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:hover i {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
}

.fb-custom-form button[type="submit"].main-header__right__btn.barrington-btn:active {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	background: #1a1a1a !important;
	filter: none !important;
	transform: translateY(0);
	box-shadow: 0 8px 22px rgba(0, 0, 0, 0.22);
}

@media (max-width: 575.98px) {
	.fb-custom-form.form-one button[type="submit"].main-header__right__btn.barrington-btn {
		width: 100%;
		white-space: normal;
		text-align: center;
		padding: 0.95rem 1.75rem;
	}
}
