/* Clean full-width contact page background frame. */
.lps-contact-scene {
	--lps-scene-navy: #071923;
	--lps-scene-blue: #0e3444;
	--lps-scene-mid: #185466;
	--lps-scene-gold: #e2c27a;
	--lps-scene-mist: rgba(232, 244, 241, 0.44);
	background:
		linear-gradient(90deg, rgba(3, 13, 19, 0.92) 0%, rgba(7, 28, 38, 0.76) 18%, rgba(13, 47, 61, 0.52) 50%, rgba(7, 28, 38, 0.76) 82%, rgba(3, 13, 19, 0.92) 100%),
		radial-gradient(ellipse at 50% -18%, rgba(125, 185, 194, 0.22), transparent 54%),
		linear-gradient(180deg, #071923 0%, #12394a 46%, #071923 100%);
	box-sizing: border-box;
	isolation: isolate;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	min-height: calc(100vh - 72px);
	overflow: hidden;
	padding: clamp(30px, 4vw, 74px) 20px clamp(48px, 5vw, 92px);
	position: relative;
	width: 100vw;
}

.lps-contact-scene *,
.lps-contact-scene *::before,
.lps-contact-scene *::after {
	box-sizing: border-box;
}

.lps-contact-scene::before {
	background:
		linear-gradient(145deg, transparent 0 47%, rgba(6, 22, 31, 0.70) 48% 100%) left bottom / 47% 62% no-repeat,
		linear-gradient(214deg, transparent 0 48%, rgba(5, 20, 29, 0.72) 49% 100%) right bottom / 50% 64% no-repeat,
		linear-gradient(170deg, transparent 0 56%, rgba(13, 48, 61, 0.50) 57% 100%) 50% 100% / 70% 48% no-repeat,
		linear-gradient(188deg, transparent 0 60%, rgba(21, 77, 93, 0.28) 61% 100%) 50% 100% / 100% 40% no-repeat;
	bottom: 0;
	content: "";
	height: 56%;
	left: 0;
	opacity: 0.88;
	pointer-events: none;
	position: absolute;
	right: 0;
	z-index: -3;
}

.lps-contact-scene::after {
	background:
		linear-gradient(90deg, rgba(3, 12, 18, 0.86) 0%, rgba(3, 12, 18, 0.34) 15%, transparent 32%, transparent 68%, rgba(3, 12, 18, 0.34) 85%, rgba(3, 12, 18, 0.86) 100%),
		radial-gradient(ellipse at 50% 92%, rgba(232, 244, 241, 0.22), transparent 52%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: -4;
}

.lps-contact-scene__mountains {
	background:
		radial-gradient(ellipse at 18% 92%, rgba(65, 116, 125, 0.22), transparent 42%),
		radial-gradient(ellipse at 82% 88%, rgba(65, 116, 125, 0.20), transparent 43%),
		linear-gradient(180deg, transparent 0%, rgba(13, 47, 61, 0.10) 38%, rgba(7, 25, 35, 0.42) 100%);
	bottom: 0;
	filter: blur(0.2px);
	height: 100%;
	left: 0;
	mix-blend-mode: screen;
	opacity: 0.38;
	pointer-events: none;
	position: absolute;
	right: 0;
	z-index: -2;
}

.lps-contact-scene__mist {
	background:
		radial-gradient(ellipse at 18% 74%, rgba(238, 248, 245, 0.22), transparent 34%),
		radial-gradient(ellipse at 82% 70%, rgba(238, 248, 245, 0.20), transparent 35%),
		linear-gradient(180deg, transparent 0%, rgba(237, 247, 244, 0.06) 42%, rgba(237, 247, 244, 0.16) 78%, rgba(237, 247, 244, 0.05) 100%);
	filter: blur(0.5px);
	inset: 0;
	mix-blend-mode: screen;
	pointer-events: none;
	position: absolute;
	z-index: -1;
}

.lps-contact--in-scene {
	filter: drop-shadow(0 30px 80px rgba(0, 0, 0, 0.24));
	position: relative;
	z-index: 1;
}

.lps-contact--in-scene::before {
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.42), 0 34px 90px rgba(0, 0, 0, 0.25);
}

@media (max-width: 760px) {
	.lps-contact-scene {
		padding: 18px 12px 40px;
	}
}

.lps-contact {
	--lps-ink: #123436;
	--lps-text: #334548;
	--lps-muted: #6b7e80;
	--lps-sage: #6f9288;
	--lps-sage-dark: #37645e;
	--lps-sage-soft: #dfece8;
	--lps-blue: #315f73;
	--lps-mist: #eef7f4;
	--lps-cream: #fbf7ee;
	--lps-warm: #fffaf0;
	--lps-card: #ffffff;
	--lps-border: #d9e7e1;
	--lps-error: #9f2f2f;
	--lps-error-bg: #fff1f1;
	--lps-success: #2f6f58;
	--lps-success-bg: #eefaf4;
	--lps-focus: #2f6f8f;
	--lps-shadow: 0 24px 70px rgba(18, 52, 54, 0.14);
	--lps-shadow-soft: 0 14px 36px rgba(18, 52, 54, 0.09);
	color: var(--lps-text);
	font-family: inherit;
	margin: 0 auto;
	max-width: 1220px;
	padding: clamp(28px, 4vw, 64px) 18px;
	position: relative;
}

.lps-contact *,
.lps-contact *::before,
.lps-contact *::after {
	box-sizing: border-box;
}

.lps-contact::before {
	background:
		radial-gradient(circle at 18% 4%, rgba(111, 146, 136, 0.18), transparent 34%),
		radial-gradient(circle at 92% 14%, rgba(49, 95, 115, 0.12), transparent 38%),
		linear-gradient(135deg, rgba(251, 248, 241, 0.85), rgba(238, 247, 244, 0.72));
	border-radius: 38px;
	content: "";
	inset: 0;
	position: absolute;
	z-index: -2;
}

.lps-contact::after {
	background:
		radial-gradient(ellipse at 50% 0%, rgba(255, 255, 255, 0.24), transparent 56%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.10), transparent 62%);
	border-radius: 38px;
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: -1;
}

.lps-contact__hero {
	align-items: end;
	display: grid;
	gap: 24px;
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: 22px;
	padding: clamp(24px, 4vw, 44px) clamp(20px, 4vw, 44px) 8px;
}

.lps-contact__hero-copy {
	max-width: 800px;
}

.lps-contact__eyebrow {
	color: var(--lps-sage-dark);
	font-size: 0.76rem;
	font-weight: 850;
	letter-spacing: 0.14em;
	line-height: 1.25;
	margin: 0 0 10px;
	text-transform: uppercase;
}

.lps-contact h2,
.lps-contact h3,
.lps-contact h4 {
	color: var(--lps-ink);
	font-family: inherit;
	line-height: 1.12;
	margin: 0;
}

.lps-contact h2 {
	font-size: clamp(2.55rem, 5vw, 5rem);
	letter-spacing: -0.065em;
	margin-bottom: 14px;
}

.lps-contact h3 {
	font-size: clamp(1.8rem, 3vw, 2.7rem);
	letter-spacing: -0.045em;
	margin-bottom: 12px;
}

.lps-contact h4 {
	font-size: 1.08rem;
	letter-spacing: -0.02em;
	margin-bottom: 12px;
}

.lps-contact p {
	font-size: 1rem;
	line-height: 1.65;
	margin: 0;
}

.lps-contact__hero-copy p:last-child {
	font-size: clamp(1.06rem, 1.45vw, 1.26rem);
	line-height: 1.62;
	max-width: 760px;
}

.lps-contact a {
	color: var(--lps-sage-dark);
	font-weight: 780;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

.lps-contact__hero-actions {
	align-items: center;
	background: rgba(255, 255, 255, 0.74);
	border: 1px solid rgba(217, 231, 225, 0.95);
	border-radius: 999px;
	box-shadow: var(--lps-shadow-soft);
	display: flex;
	gap: 14px;
	padding: 8px 16px 8px 8px;
	white-space: nowrap;
}

.lps-contact__call-button,
.lps-contact__button {
	appearance: none;
	background: linear-gradient(135deg, var(--lps-sage-dark), var(--lps-sage));
	border: 0;
	border-radius: 999px;
	box-shadow: 0 16px 34px rgba(65, 107, 99, 0.26);
	color: #fff !important;
	cursor: pointer;
	display: inline-flex;
	font: inherit;
	font-weight: 850;
	justify-content: center;
	letter-spacing: 0.01em;
	line-height: 1.1;
	min-height: 50px;
	padding: 14px 24px;
	text-decoration: none;
	transition: transform 140ms ease, box-shadow 140ms ease, opacity 140ms ease, filter 140ms ease;
}

.lps-contact__call-button:hover,
.lps-contact__button:hover {
	box-shadow: 0 18px 40px rgba(65, 107, 99, 0.36);
	filter: saturate(1.04);
	transform: translateY(-1px);
}

.lps-contact__hero-phone {
	color: var(--lps-ink);
	font-size: 1.02rem;
	font-weight: 860;
}

.lps-contact__notice {
	align-items: start;
	background: var(--lps-card);
	border: 1px solid var(--lps-border);
	border-radius: 22px;
	box-shadow: var(--lps-shadow-soft);
	display: grid;
	gap: 12px;
	grid-template-columns: auto minmax(0, 1fr);
	margin: 0 clamp(16px, 4vw, 44px) 22px;
	padding: 17px 19px;
}

.lps-contact__notice-icon {
	align-items: center;
	background: rgba(159, 116, 47, 0.1);
	border: 1px solid rgba(159, 116, 47, 0.26);
	border-radius: 999px;
	color: #8a6326;
	display: inline-flex;
	font-weight: 900;
	height: 30px;
	justify-content: center;
	line-height: 1;
	width: 30px;
}

.lps-contact__notice strong {
	color: var(--lps-ink);
	display: block;
	font-weight: 900;
	margin-bottom: 3px;
}

.lps-contact__notice span {
	display: block;
	line-height: 1.55;
}

.lps-contact__notice--crisis {
	background: linear-gradient(135deg, #fffaf0, #fff4df);
	border-color: #ead6aa;
}

.lps-contact__notice--success {
	background: var(--lps-success-bg);
	border-color: rgba(47, 111, 88, 0.35);
	color: var(--lps-success);
	grid-template-columns: 1fr;
}

.lps-contact__notice--error {
	background: var(--lps-error-bg);
	border-color: rgba(159, 47, 47, 0.35);
	color: var(--lps-error);
	grid-template-columns: 1fr;
}

.lps-contact__notice p + p {
	margin-top: 6px;
}

.lps-contact__shell {
	display: grid;
	grid-template-columns: minmax(0, 1.18fr) minmax(360px, 0.82fr);
	gap: 32px;
	align-items: start;
	padding: 0 clamp(16px, 4vw, 44px) clamp(20px, 4vw, 44px);
}

.lps-contact__form-card,
.lps-contact__side-card {
	backdrop-filter: blur(8px);
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid rgba(217, 231, 225, 0.98);
	border-radius: 30px;
	box-shadow: var(--lps-shadow);
	position: relative;
}

.lps-contact__form-card {
	overflow: hidden;
	padding: clamp(28px, 4vw, 48px);
}

.lps-contact__form-card::before {
	background: linear-gradient(90deg, var(--lps-sage-dark), var(--lps-sage), #d1ad6d);
	content: "";
	height: 7px;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.lps-contact__side-card {
	padding: 32px;
	position: sticky;
	top: 28px;
}

.lps-contact__intro {
	margin-bottom: 22px;
}

.lps-contact__privacy {
	align-items: start;
	background: linear-gradient(135deg, var(--lps-mist), #f7fbf9);
	border: 1px solid var(--lps-border);
	border-radius: 18px;
	color: var(--lps-text);
	display: grid;
	font-size: 0.96rem;
	gap: 4px;
	line-height: 1.58;
	margin-bottom: 26px;
	padding: 16px 18px;
}

.lps-contact__privacy strong {
	color: var(--lps-ink);
}

.lps-contact__form {
	display: grid;
	gap: 19px;
}

.lps-contact__grid {
	display: grid;
	gap: 18px;
}

.lps-contact__grid--two {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.lps-contact__field {
	display: grid;
	gap: 8px;
}

.lps-contact__field label {
	color: var(--lps-ink);
	font-size: 0.94rem;
	font-weight: 850;
}

.lps-contact__field label span {
	color: var(--lps-error);
}

.lps-contact__field input,
.lps-contact__field select,
.lps-contact__field textarea {
	appearance: none;
	background: #fff;
	border: 1px solid #cbdcd5;
	border-radius: 16px;
	box-shadow: inset 0 1px 0 rgba(18, 52, 54, 0.025);
	color: var(--lps-ink);
	font: inherit;
	font-size: 1rem;
	line-height: 1.42;
	min-height: 50px;
	outline: none;
	padding: 13px 15px;
	transition: border-color 160ms ease, box-shadow 160ms ease, background-color 160ms ease, transform 160ms ease;
	width: 100%;
}

.lps-contact__field select {
	background-image: linear-gradient(45deg, transparent 50%, var(--lps-sage-dark) 50%), linear-gradient(135deg, var(--lps-sage-dark) 50%, transparent 50%);
	background-position: calc(100% - 18px) 21px, calc(100% - 12px) 21px;
	background-repeat: no-repeat;
	background-size: 6px 6px, 6px 6px;
	padding-right: 42px;
}

.lps-contact__field textarea {
	min-height: 156px;
	resize: vertical;
}

.lps-contact__field input:hover,
.lps-contact__field select:hover,
.lps-contact__field textarea:hover {
	border-color: #adc8c0;
}

.lps-contact__field input:focus,
.lps-contact__field select:focus,
.lps-contact__field textarea:focus,
.lps-contact__check input:focus-visible,
.lps-contact__button:focus-visible,
.lps-contact__call-button:focus-visible {
	border-color: var(--lps-focus);
	box-shadow: 0 0 0 4px rgba(47, 111, 143, 0.15);
}

.lps-contact__help,
.lps-contact__fineprint {
	color: var(--lps-muted);
	font-size: 0.9rem;
}

.lps-contact__check {
	align-items: flex-start;
	background: var(--lps-cream);
	border: 1px solid #eadfca;
	border-radius: 18px;
	color: var(--lps-text);
	cursor: pointer;
	display: flex;
	font-size: 0.94rem;
	gap: 12px;
	line-height: 1.5;
	padding: 15px 17px;
}

.lps-contact__check input {
	accent-color: var(--lps-sage-dark);
	flex: 0 0 auto;
	height: 18px;
	margin-top: 3px;
	width: 18px;
}

.lps-contact__actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: space-between;
	padding-top: 4px;
}

.lps-contact__button:disabled {
	cursor: wait;
	opacity: 0.72;
	transform: none;
}

.lps-contact__hp {
	left: -9999px !important;
	position: absolute !important;
	top: auto !important;
}

.lps-contact__detail-list {
	display: grid;
	gap: 18px;
	margin-top: 28px;
}

.lps-contact__detail {
	border-top: 1px solid var(--lps-border);
	display: grid;
	gap: 6px;
	padding-top: 17px;
}

.lps-contact__detail--phone a {
	font-size: clamp(1.35rem, 2vw, 1.8rem);
	letter-spacing: -0.035em;
	line-height: 1.05;
}

.lps-contact__detail-label {
	color: var(--lps-muted);
	font-size: 0.76rem;
	font-weight: 850;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.lps-contact address {
	font-style: normal;
	line-height: 1.55;
}

.lps-contact ul,
.lps-contact ol {
	margin: 0;
	padding-left: 1.2rem;
}

.lps-contact li + li {
	margin-top: 7px;
}

.lps-contact__map-link {
	display: inline-flex;
	margin-top: 6px;
}

.lps-contact__next {
	background:
		linear-gradient(135deg, rgba(238, 247, 244, 0.96), rgba(251, 248, 241, 0.96));
	border: 1px solid var(--lps-border);
	border-radius: 22px;
	margin-top: 28px;
	padding: 20px;
}

.lps-contact__next li {
	line-height: 1.55;
}

@media (max-width: 980px) {
	.lps-contact__hero,
	.lps-contact__shell {
		grid-template-columns: 1fr;
	}

	.lps-contact__hero-actions {
		justify-self: start;
	}

	.lps-contact__side-card {
		position: static;
	}
}

@media (max-width: 760px) {
	.lps-contact__grid--two {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 560px) {
	.lps-contact {
		padding-left: 12px;
		padding-right: 12px;
	}

	.lps-contact::before,
	.lps-contact::after {
		border-radius: 26px;
	}

	.lps-contact__hero,
	.lps-contact__shell {
		padding-left: 14px;
		padding-right: 14px;
	}

	.lps-contact__notice {
		grid-template-columns: 1fr;
		margin-left: 14px;
		margin-right: 14px;
	}

	.lps-contact__form-card,
	.lps-contact__side-card {
		border-radius: 22px;
		padding: 22px;
	}

	.lps-contact__hero-actions,
	.lps-contact__actions {
		align-items: stretch;
		flex-direction: column;
		width: 100%;
	}

	.lps-contact__button,
	.lps-contact__call-button {
		width: 100%;
	}
}
