/*
 * Propstack Kontaktformular
 * Reduzierte, isolierte Styles für das Formular.
 * Fonts werden vom Projekt/Theme geladen.
 */
.pscf_contact_outer {
	--pscf-max-width: 1100px;
	--pscf-padding-inline: clamp(1.125rem, 0.833rem + 0.972vw, 2rem);
	--pscf-margin-top: 0;
	--pscf-margin-bottom: 0;
	--pscf-padding-top: 0;
	--pscf-padding-bottom: clamp(8.75rem, 5.4167rem + 11.111vw, 18.75rem);
	--pscf-mobile-breakpoint: 781px;
	--pscf-col-width: 49%;
	--pscf-bg: transparent;
	--pscf-text: #f0d787;
	--pscf-field-border: rgba(240, 215, 135, 0.55);
	--pscf-focus-bg: #455d5a;
	--pscf-button-bg: #455d5a;
	--pscf-button-text: #f0d787;
	--pscf-font-copy: "Campton", sans-serif;
	--pscf-font-headline: "Bookmania", serif;
	--pscf-headline-size: 40px;
	--pscf-subhead-size: 16px;
	--pscf-label-size: 14px;
	--pscf-copy-size: clamp(1rem, 0.9583rem + 0.1389vw, 1.125rem);
	--pscf-row-gap: 18px;
	--pscf-form-head-margin-bottom: 80px;
	--pscf-checks-padding-top: 80px;
	--pscf-checks-padding-bottom: 80px;
	--pscf-consent-padding-top: 48px;
	--pscf-consent-padding-bottom: 48px;
	--pscf-textarea-min-height: 160px;
	--pscf-button-width: 140px;
	--pscf-button-padding: 1rem 2.5rem;
	width: 100%;
	margin-top: var(--pscf-margin-top);
	margin-bottom: var(--pscf-margin-bottom);
	padding-top: var(--pscf-padding-top);
	padding-bottom: var(--pscf-padding-bottom);
	background: var(--pscf-bg);
	color: var(--pscf-text);
}
.pscf_contact_outer, .pscf_contact_outer *, .pscf_contact_outer *::before, .pscf_contact_outer *::after {
	box-sizing: border-box;
}
.pscf_contact_inner {
	width: 100%;
	max-width: var(--pscf-max-width);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--pscf-padding-inline);
	padding-right: var(--pscf-padding-inline);
}
.pscf_form_head {
	text-align: left;
	margin-bottom: var(--pscf-form-head-margin-bottom);
}
.pscf_h2 {
	margin: 0 0 1rem 0;
	font-family: var(--pscf-font-headline);
	font-weight: 400;
	font-size: var(--pscf-headline-size);
	line-height: 100%;
	letter-spacing: 0;
	color: var(--pscf-text);
}
.pscf_intro {
	margin: 0;
	font-family: var(--pscf-font-copy);
	font-weight: 400;
	font-size: var(--pscf-subhead-size);
	line-height: 125%;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--pscf-text);
}
.pscf_contact_outer .cs_form {
	margin-top: 24px;
	color: var(--pscf-text);
}
.pscf_contact_outer .cs_form_msg {
	margin-bottom: 18px;
}
.pscf_contact_outer .cs_form_msg .msg {
	margin: 0 0 14px 0;
	font-family: var(--pscf-font-copy);
	font-size: var(--pscf-copy-size);
	line-height: 133%;
	font-weight: 300;
	letter-spacing: 0.02em;
	color: var(--pscf-text);
}
.pscf_contact_outer .cs_form_msg .msg.err {
	font-weight: 600;
}
.pscf_contact_outer .cs_form_row {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	margin-bottom: var(--pscf-row-gap);
}
.pscf_contact_outer .cs_form_row_2col > * {
	flex: 0 0 var(--pscf-col-width);
	width: var(--pscf-col-width);
	max-width: var(--pscf-col-width);
	min-width: 0;
}
.pscf_contact_outer .cs_field {
	width: 100%;
}
.pscf_contact_outer .cs_field label, .pscf_contact_outer .cs_fieldset legend {
	display: block;
	margin-bottom: 8px;
	margin-left: 0;
	font-family: var(--pscf-font-copy);
	font-weight: 400;
	font-size: var(--pscf-label-size);
	line-height: 14px;
	letter-spacing: 0.01em;
	color: var(--pscf-text);
}
.pscf_contact_outer .cs_fieldset legend {
	margin-bottom: 10px;
}
.pscf_contact_outer .cs_field input, .pscf_contact_outer .cs_field textarea {
	width: 100%;
	color: var(--pscf-text) !important;
	background: transparent !important;
	background-color: transparent !important;
	border: 0;
	border-bottom: 1px solid var(--pscf-field-border);
	padding: 12px 0 10px;
	font-family: var(--pscf-font-copy);
	font-size: var(--pscf-copy-size);
	line-height: 133%;
	font-weight: 300;
	letter-spacing: 0.02em;
	border-radius: 0 !important;
	box-shadow: none !important;
	outline: none;
	appearance: none;
}
.pscf_contact_outer .cs_field textarea {
	border: 1px solid var(--pscf-field-border);
	min-height: var(--pscf-textarea-min-height);
	padding: 14px;
	resize: vertical;
}
.pscf_contact_outer .cs_field input::placeholder, .pscf_contact_outer .cs_field textarea::placeholder {
	color: rgba(240, 215, 135, 0.65);
}
.pscf_contact_outer .cs_field input:focus, .pscf_contact_outer .cs_field input:active, .pscf_contact_outer .cs_field input:focus-visible, .pscf_contact_outer .cs_field textarea:focus, .pscf_contact_outer .cs_field textarea:active, .pscf_contact_outer .cs_field textarea:focus-visible {
	outline: none !important;
	border-color: transparent !important;
	background: var(--pscf-focus-bg) !important;
	background-color: var(--pscf-focus-bg) !important;
	color: var(--pscf-text) !important;
	box-shadow: none !important;
}
.pscf_contact_outer .cs_field input:focus, .pscf_contact_outer .cs_field input:active, .pscf_contact_outer .cs_field input:focus-visible {
	padding-left: 3px;
	padding-right: 3px;
}
.pscf_contact_outer .cs_field textarea:focus, .pscf_contact_outer .cs_field textarea:active, .pscf_contact_outer .cs_field textarea:focus-visible {
	padding-left: 17px;
	padding-right: 17px;
}
.pscf_contact_outer .cs_fieldset {
	border: 0;
	padding: 0;
	margin: 0;
	width: 100%;
}
.pscf_contact_outer .cs_form_checks {
	padding-top: var(--pscf-checks-padding-top);
	padding-bottom: var(--pscf-checks-padding-bottom);
}
.pscf_contact_outer .cs_check {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin-bottom: 10px;
	margin-left: 0;
	font-family: var(--pscf-font-copy);
	font-size: var(--pscf-copy-size);
	line-height: 145%;
	font-weight: 300;
	letter-spacing: 0.02em;
	color: var(--pscf-text);
	opacity: 0.95;
}
.pscf_contact_outer .cs_check input[type="checkbox"] {
	-webkit-appearance: none !important;
	appearance: none !important;
	flex: 0 0 auto;
	margin-top: 3px;
	margin-right: 12px;
	width: 18px !important;
	height: 18px !important;
	min-width: 18px;
	min-height: 18px;
	padding: 0 !important;
	border: 1px solid var(--pscf-text) !important;
	background: var(--pscf-bg) !important;
	background-color: var(--pscf-bg) !important;
	border-radius: 0 !important;
	display: inline-grid !important;
	place-content: center;
	cursor: pointer;
	box-shadow: none !important;
}
.pscf_contact_outer .cs_check input[type="checkbox"]:checked {
	background: var(--pscf-bg) !important;
	background-color: var(--pscf-bg) !important;
}
.pscf_contact_outer .cs_check input[type="checkbox"]:checked::after {
	opacity: 1;
}
.pscf_contact_outer .cs_check input[type="checkbox"]:focus, .pscf_contact_outer .cs_check input[type="checkbox"]:focus-visible {
	outline: none !important;
	box-shadow: 0 0 0 2px var(--pscf-text) !important;
}

.pscf_contact_outer .cs_check input[type="checkbox"] {
	width: 16px;
	/* Größe der Checkbox */
	height: 16px;
	border: 1px solid var(--pscf-text);
	background-color: transparent;
	border-radius: 0;
	appearance: none;
	position: relative;
	/* Ermöglicht absolute Positionierung des Häkchens */
	cursor: pointer;
	vertical-align: middle;
	/* Verhindert Verschieben des Textes */
}

.pscf_contact_outer .cs_check input[type="checkbox"]:checked::before {
	content: "\2713";
	/* Unicode für Häkchen */
	color: var(--pscf-text);
	/* Häkchen */
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	/* Zentriert das Häkchen */
	font-size: 14px;
	/* Größe des Häkchens */
}

.pscf_contact_outer .cs_small {
	font-size: 0.9em;
	opacity: 0.85;
}
.pscf_contact_outer .cs_form_row_consent {
	padding-top: var(--pscf-consent-padding-top);
	padding-bottom: var(--pscf-consent-padding-bottom);
}
.pscf_contact_outer .cs_check_inline, .pscf_contact_outer .cs_check_consent {
	margin-bottom: 0;
	font-family: var(--pscf-font-copy);
	font-size: var(--pscf-copy-size);
	line-height: 145%;
	font-weight: 300;
	letter-spacing: 0.02em;
	color: var(--pscf-text);
}
.pscf_contact_outer .cs_check_inline a, .pscf_contact_outer .cs_check_consent a {
	color: var(--pscf-text);
	text-decoration: underline;
	text-underline-offset: 0.14em;
}
.pscf_contact_outer .cs_form_row_actions {
	margin-bottom: 0;
}
.pscf_contact_outer .cs_reqhint_wrap {
	width: var(--pscf-col-width);
	max-width: var(--pscf-col-width);
	min-width: 0;
}
.pscf_contact_outer .cs_reqhint {
	margin-top: 10px;
	font-family: var(--pscf-font-copy);
	color: var(--pscf-text);
}
.pscf_contact_outer .cs_form_right {
	width: var(--pscf-col-width);
	max-width: var(--pscf-col-width);
	min-width: 0;
	display: flex;
	justify-content: flex-end;
}
.pscf_contact_outer .cs_btn, .pscf_contact_outer .cs_btn_send {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--pscf-button-width);
	background: var(--pscf-button-bg);
	padding: var(--pscf-button-padding);
	text-decoration: none;
	border: 0;
	border-radius: 0;
	font-family: var(--pscf-font-copy);
	font-weight: 400;
	font-size: clamp(0.875rem, 0.8333rem + 0.1389vw, 1rem);
	line-height: 100%;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--pscf-button-text);
	cursor: pointer;
	text-align: center;
	box-shadow: none;
}
.pscf_contact_outer .cs_btn:hover, .pscf_contact_outer .cs_btn_send:hover {
	color: var(--pscf-button-text);
	background: var(--pscf-button-bg);
	opacity: 0.5;
}
.pscf_contact_outer .cs_btn:disabled, .pscf_contact_outer .cs_btn_send:disabled {
	cursor: default;
	opacity: 0.7;
}
.pscf_contact_outer .emailWdh {
	display: none !important;
}
@media (max-width: 781px) {
	.pscf_contact_outer .cs_form_row_2col > *, .pscf_contact_outer .cs_reqhint_wrap, .pscf_contact_outer .cs_form_right {
		flex: 0 0 100% !important;
		width: 100% !important;
		max-width: 100% !important;
	}
	.pscf_contact_outer .cs_form_row_2col > * + * {
		margin-top: 18px;
	}
	.pscf_contact_outer .cs_form_right {
		justify-content: flex-start;
		margin-top: 18px;
	}
	.pscf_contact_outer .cs_form_checks {
		padding-top: 48px;
		padding-bottom: 48px;
	}
}