/* Springtide AI Voice Form — frontend styles
   ============================================
   All rules namespaced under .svf- so they can't bleed into Avada or other themes. */

.svf-wrap {
	--svf-navy: #00006b;
	--svf-navy-hover: #1a1a85;
	--svf-blue: #7da7fa;
	--svf-text: #1f1f27;
	--svf-muted: #6a6f7d;
	--svf-border: #e0dede;
	--svf-card-bg: #ffffff;
	--svf-warn-bg: #fff4e1;
	--svf-warn-border: #f0c373;
	--svf-warn-text: #7a4e0d;
	--svf-warn-strong: #b86b00;
	--svf-ok-bg: #e8f7ef;
	--svf-ok-border: #7fd1a1;
	--svf-ok-text: #1d6b3b;
	--svf-err-bg: #fdecec;
	--svf-err-border: #f1a2a2;
	--svf-err-text: #8a1f1f;
	--svf-radius: 6px;
	font-family: Roboto, "Helvetica Neue", Helvetica, Arial, sans-serif;
	color: var(--svf-text);
	max-width: 640px;
	margin: 0 auto;
	box-sizing: border-box;
}
.svf-wrap *,
.svf-wrap *::before,
.svf-wrap *::after { box-sizing: inherit; }

.svf-banner {
	background: var(--svf-warn-bg);
	border: 1px solid var(--svf-warn-border);
	color: var(--svf-warn-text);
	border-radius: var(--svf-radius);
	padding: 14px 18px;
	margin: 0 0 24px;
	font-size: 14px;
	line-height: 1.5;
}
.svf-banner strong {
	color: var(--svf-warn-strong);
	letter-spacing: 1px;
}

.svf-card {
	background: var(--svf-card-bg);
	border: 1px solid var(--svf-border);
	border-radius: var(--svf-radius);
	padding: 32px;
	box-shadow: 0 2px 12px rgba(0, 0, 107, 0.08);
}

.svf-title {
	color: var(--svf-navy);
	font-family: Roboto, sans-serif;
	font-weight: 900;
	font-size: 24px;
	margin: 0 0 8px;
	line-height: 1.2;
}
.svf-lede {
	color: var(--svf-muted);
	font-size: 14px;
	line-height: 1.55;
	margin: 0 0 24px;
}

.svf-form { margin: 0; }
.svf-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}
.svf-field { margin-bottom: 14px; }
.svf-field-empty { visibility: hidden; }

.svf-field label {
	display: block;
	color: var(--svf-navy);
	font-weight: 700;
	font-size: 11px;
	margin-bottom: 6px;
	letter-spacing: 2px;
	text-transform: uppercase;
}
.svf-req { color: #c8332e; margin-left: 2px; }

.svf-field input,
.svf-field select {
	width: 100%;
	background: #fff;
	color: var(--svf-text);
	border: 1px solid var(--svf-border);
	border-radius: 3px;
	padding: 12px 14px;
	font-size: 15px;
	font-family: inherit;
	line-height: 1.4;
	transition: border-color 0.15s, box-shadow 0.15s;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.svf-field input:focus,
.svf-field select:focus {
	outline: none;
	border-color: var(--svf-navy);
	box-shadow: 0 0 0 3px rgba(125, 167, 250, 0.25);
}
.svf-field input::placeholder { color: #a8acb8; }

.svf-select {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%2300006b' d='M6 8 0 0h12z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 10px 7px;
	padding-right: 36px;
}

.svf-consent {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 13px;
	color: var(--svf-muted);
	line-height: 1.5;
	margin: 18px 0 4px;
	cursor: pointer;
}
.svf-consent input {
	width: 16px;
	height: 16px;
	margin-top: 2px;
	accent-color: var(--svf-navy);
	flex-shrink: 0;
}

.svf-button {
	width: 100%;
	background: #ffffff;
	color: var(--svf-navy);
	border: 1px solid var(--svf-navy);
	border-radius: 0;
	padding: 15px 18px;
	font-family: Roboto, sans-serif;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	cursor: pointer;
	transition: background-color 0.2s, color 0.2s;
	margin-top: 18px;
}
.svf-button:hover:not(:disabled) {
	background: var(--svf-navy);
	color: #ffffff;
}
.svf-button:disabled { opacity: 0.55; cursor: not-allowed; }

.svf-status {
	margin-top: 14px;
	padding: 12px 14px;
	border-radius: 4px;
	font-size: 14px;
	line-height: 1.45;
}
.svf-ok {
	background: var(--svf-ok-bg);
	border: 1px solid var(--svf-ok-border);
	color: var(--svf-ok-text);
}
.svf-err {
	background: var(--svf-err-bg);
	border: 1px solid var(--svf-err-border);
	color: var(--svf-err-text);
}

.svf-hp {
	position: absolute !important;
	left: -10000px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

@media (max-width: 520px) {
	.svf-row { grid-template-columns: 1fr; }
	.svf-card { padding: 24px; }
}
