/*
 * Bernhardt Riley contact form styles.
 * Brand tokens: #181A31 navy · #39428E blue · #5AB7A3 teal · Raleway / Montserrat.
 */

.brfl-form {
	--brfl-navy: #181A31;
	--brfl-blue: #39428E;
	--brfl-teal: #5AB7A3;
	--brfl-teal-hover: #49998A;
	--brfl-teal-soft: #e8f5f2;
	--brfl-bg: #ffffff;
	--brfl-bg-alt: #f5f7fa;
	--brfl-border: #c9cfdc;
	--brfl-border-strong: #9aa3b8;
	--brfl-ink: #1a1d2b;
	--brfl-ink-muted: #5b6478;
	--brfl-error: #c83a3a;
	--brfl-radius: 10px;
	--brfl-radius-sm: 6px;
	--brfl-shadow: 0 12px 40px rgba(24, 26, 49, .12);
	--brfl-shadow-focus: 0 0 0 3px rgba(90, 183, 163, .35);

	max-width: 720px;
	margin: 0 auto;
	padding: 32px;
	background: var(--brfl-bg);
	border-radius: var(--brfl-radius);
	box-shadow: var(--brfl-shadow);
	font-family: 'Montserrat', system-ui, -apple-system, sans-serif;
	color: var(--brfl-ink);
	box-sizing: border-box;
}

.brfl-form *,
.brfl-form *::before,
.brfl-form *::after {
	box-sizing: border-box;
}

/* Header ------------------------------------------------------------- */
.brfl-form__header {
	margin-bottom: 24px;
}

.brfl-form__title {
	font-family: 'Raleway', system-ui, sans-serif;
	font-size: clamp(24px, 3vw, 32px);
	font-weight: 800;
	color: var(--brfl-navy);
	line-height: 1.15;
	margin: 0 0 10px;
}

.brfl-form__subtitle {
	font-size: 14px;
	line-height: 1.6;
	color: var(--brfl-ink-muted);
	margin: 0;
}

/* Layout ------------------------------------------------------------- */
.brfl-form__form {
	display: flex;
	flex-direction: column;
	gap: 18px;
	margin: 0;
}

.brfl-form__row {
	display: grid;
	gap: 16px;
}

@media (min-width: 560px) {
	.brfl-form__row--two {
		grid-template-columns: 1fr 1fr;
	}
}

.brfl-form__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.brfl-form__label {
	font-size: 12.5px;
	font-weight: 700;
	letter-spacing: .03em;
	text-transform: uppercase;
	color: var(--brfl-navy);
}

.brfl-form__req {
	color: var(--brfl-teal);
	margin-left: 2px;
}

.brfl-form .brfl-form__input,
.brfl-form .brfl-form__select,
.brfl-form .brfl-form__textarea {
	width: 100%;
	min-height: 48px;
	padding: 12px 14px;
	font: inherit;
	font-size: 15px;
	color: var(--brfl-ink);
	background: #fcfcfd;
	border: 1.5px solid var(--brfl-border);
	border-radius: var(--brfl-radius-sm);
	transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	box-shadow: none;
}

.brfl-form__textarea {
	resize: vertical;
	min-height: 120px;
	line-height: 1.55;
}

.brfl-form__select {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none'><path d='M3 5l4 4 4-4' stroke='%23181A31' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 14px;
	padding-right: 38px;
}

.brfl-form__input:hover,
.brfl-form__select:hover,
.brfl-form__textarea:hover {
	border-color: var(--brfl-border-strong);
}

.brfl-form__input:focus,
.brfl-form__select:focus,
.brfl-form__textarea:focus {
	outline: none;
	border-color: var(--brfl-teal);
	box-shadow: var(--brfl-shadow-focus);
	background: #fff;
}

.brfl-form__field.is-invalid .brfl-form__input,
.brfl-form__field.is-invalid .brfl-form__select,
.brfl-form__field.is-invalid .brfl-form__textarea {
	border-color: var(--brfl-error);
	box-shadow: 0 0 0 3px rgba(200, 58, 58, .15);
}

.brfl-form__field-error {
	font-size: 12px;
	color: var(--brfl-error);
	font-weight: 600;
	margin-top: 2px;
}

.brfl-form__field-hint {
	font-size: 12px;
	color: var(--brfl-ink-muted);
	line-height: 1.5;
	margin: 4px 0 0;
}

/* Honeypot ----------------------------------------------------------- */
.brfl-form__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Consent block ------------------------------------------------------ */
.brfl-form__consent {
	border: 1px solid var(--brfl-border);
	border-radius: var(--brfl-radius);
	padding: 22px 22px 20px;
	margin: 6px 0 4px;
	background: var(--brfl-bg-alt);
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.brfl-form__consent-title {
	font-family: 'Raleway', system-ui, sans-serif;
	font-size: 14px;
	font-weight: 800;
	color: var(--brfl-navy);
	letter-spacing: .02em;
	margin: 0;
}

.brfl-form__consent-meta {
	font-family: 'Montserrat', sans-serif;
	font-size: 12.5px;
	font-weight: 500;
	line-height: 1.55;
	color: var(--brfl-ink-muted);
	margin: -8px 0 4px;
}

.brfl-form__consent-meta strong {
	color: var(--brfl-navy);
	font-weight: 700;
}

.brfl-form__check {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 12px;
	align-items: start;
	cursor: pointer;
	font-size: 13px;
	line-height: 1.55;
	color: var(--brfl-ink-muted);
}

.brfl-form__check-input {
	position: absolute;
	opacity: 0;
	width: 22px;
	height: 22px;
	margin: 0;
	cursor: pointer;
}

.brfl-form__check-box {
	width: 22px;
	height: 22px;
	border: 2px solid var(--brfl-border-strong);
	border-radius: 5px;
	background: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
	flex-shrink: 0;
	margin-top: 1px;
}

.brfl-form__check-box::after {
	content: "";
	width: 12px;
	height: 12px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'><path d='M2 6.5l2.5 2.5L10 3.5' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	opacity: 0;
	transition: opacity .15s ease;
}

.brfl-form__check-input:checked + .brfl-form__check-box {
	background: var(--brfl-teal);
	border-color: var(--brfl-teal);
}

.brfl-form__check-input:checked + .brfl-form__check-box::after {
	opacity: 1;
}

.brfl-form__check-input:focus-visible + .brfl-form__check-box {
	box-shadow: var(--brfl-shadow-focus);
}

.brfl-form__check-text strong {
	color: var(--brfl-navy);
	font-weight: 700;
}

/* Actions ------------------------------------------------------------ */
.brfl-form__actions {
	display: flex;
	flex-direction: column;
	gap: 14px;
	align-items: stretch;
	width: 100%;
}

.brfl-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 14px 28px;
	font-family: 'Raleway', system-ui, sans-serif;
	font-size: 14px;
	font-weight: 800;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #fff;
	background: var(--brfl-teal);
	border: none;
	border-radius: var(--brfl-radius-sm);
	cursor: pointer;
	transition: background .15s ease, transform .05s ease, box-shadow .15s ease;
	align-self: flex-start;
	min-width: 200px;
}

.brfl-form__submit:hover {
	background: var(--brfl-teal-hover);
}

.brfl-form__submit:focus-visible {
	outline: none;
	box-shadow: var(--brfl-shadow-focus);
}

.brfl-form__submit:active {
	transform: translateY(1px);
}

.brfl-form__submit:disabled {
	opacity: .65;
	cursor: progress;
}

.brfl-form__submit-spinner {
	display: none;
	animation: brfl-spin 1s linear infinite;
}

.brfl-form__submit.is-loading .brfl-form__submit-spinner {
	display: inline-block;
}

.brfl-form__submit.is-loading .brfl-form__submit-label::after {
	content: "ing";
}

@keyframes brfl-spin {
	to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
	.brfl-form__submit-spinner { animation: none; }
}

.brfl-form__legal {
	font-size: 12px;
	color: var(--brfl-ink-muted);
	line-height: 1.6;
	margin: 0;
	width: 100%;
}

.brfl-form__legal a {
	color: var(--brfl-blue);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.brfl-form__legal a:hover {
	color: var(--brfl-teal-hover);
}

/* Status (success/error after submit) -------------------------------- */
.brfl-form__status {
	display: none;
	padding: 14px 16px;
	margin: 0 0 8px;
	border-radius: var(--brfl-radius-sm);
	font-size: 14px;
	line-height: 1.5;
	font-weight: 600;
}

.brfl-form__status.is-success {
	display: block;
	background: var(--brfl-teal-soft);
	color: #1f5b50;
	border-left: 4px solid var(--brfl-teal);
}

.brfl-form__status.is-error {
	display: block;
	background: #fdecec;
	color: #842121;
	border-left: 4px solid var(--brfl-error);
}

/* Mobile tweaks ------------------------------------------------------ */
@media (max-width: 480px) {
	.brfl-form {
		padding: 22px;
		border-radius: var(--brfl-radius-sm);
	}
	.brfl-form__submit {
		width: 100%;
		min-width: 0;
	}
}
