/* ==========================================================================
   Contact Form 7 Styling — Netzwerktreffen 2026
   Floating labels (label sits inside input, at top border)
   ========================================================================== */

/* --- Form Grid: 2 columns on desktop --- */
.wpcf7-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem 1.5rem;
}

/* Full-width elements: textarea, submit, messages, acceptance */
.wpcf7-form p:has(textarea),
.wpcf7-form p:has([type="submit"]),
.wpcf7-form p:has(.wpcf7-acceptance),
.wpcf7-form p:has(.wpcf7-checkbox),
.wpcf7-form p:has(.wpcf7-radio),
.wpcf7-form .wpcf7-response-output {
	grid-column: 1 / -1;
}

/* --- Floating Label: <label> becomes the visual input container --- */
.wpcf7-form label {
	display: block;
	position: relative;
	border: 1px solid rgba(125, 125, 125, 0.3);
	border-radius: var(--ppg-radius-md, 0.5rem);
	padding: 0.5rem 1rem 0;
	font-family: var(--ppg-font-heading, 'Plus Jakarta Sans', system-ui, sans-serif);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: rgba(125, 125, 125, 0.6);
	background-color: rgba(255, 255, 255, 0.08);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	cursor: text;
}

/* Hide the <br> between label text and input */
.wpcf7-form label br {
	display: none;
}

/* Light background context */
.has-background-background-color .wpcf7-form label,
.has-white-background-color .wpcf7-form label {
	background-color: #fff;
	border-color: var(--wp--preset--color--border, #e5e5e5);
}

/* Focus state on the label container */
.wpcf7-form label:focus-within {
	border-color: var(--ppg-color-primary, #8faad9);
	box-shadow: 0 0 0 3px rgba(143, 170, 217, 0.25);
}

/* --- Inputs inside label: no border, transparent bg --- */
.wpcf7-form input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.wpcf7-form select,
.wpcf7-form textarea {
	width: 100%;
	padding: 0.25rem 0 0.625rem;
	font-family: inherit;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--wp--preset--color--text, #1f2937);
	background: transparent;
	border: none;
	outline: none;
	appearance: none;
}

/* Textarea */
.wpcf7-form textarea {
	min-height: 8rem;
	resize: vertical;
}

/* Select arrow */
.wpcf7-form select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23666' stroke-width='1.5'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0 center;
	padding-right: 1.5rem;
}

/* Placeholder */
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder {
	color: rgba(125, 125, 125, 0.5);
}

/* --- Submit Button (default: dark, for light backgrounds) --- */
.wpcf7-form input[type="submit"] {
	display: inline-block;
	padding: 1rem 2.5rem;
	font-family: inherit;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: #1f2431;
	border: 2px solid #1f2431;
	border-radius: var(--ppg-radius-lg, 0.75rem);
	cursor: pointer;
	transition: transform 0.3s ease, box-shadow 0.3s ease,
				background-color 0.3s ease, color 0.3s ease,
				border-color 0.3s ease;
}

.wpcf7-form input[type="submit"]:hover {
	background: var(--ppg-color-primary, #8faad9);
	border-color: var(--ppg-color-primary, #8faad9);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 8px 25px -5px rgba(143, 170, 217, 0.4);
}

/* Dark background: outlined white button */
.ppg-accordion[style*="background-color:#1f2431"] .wpcf7-form input[type="submit"],
.has-primary-background-color .wpcf7-form input[type="submit"],
.ppg-cta .wpcf7-form input[type="submit"] {
	color: #fff;
	background: transparent;
	border-color: #fff;
}

.ppg-accordion[style*="background-color:#1f2431"] .wpcf7-form input[type="submit"]:hover,
.has-primary-background-color .wpcf7-form input[type="submit"]:hover,
.ppg-cta .wpcf7-form input[type="submit"]:hover {
	background: #fff;
	color: #1f2431;
	border-color: #fff;
}

.wpcf7-form input[type="submit"]:focus-visible {
	outline: 2px solid var(--ppg-color-primary, #8faad9);
	outline-offset: 3px;
}

/* --- Checkboxes / Radio / Acceptance: no floating label style --- */
.wpcf7-form p:has(.wpcf7-acceptance) label,
.wpcf7-form p:has(.wpcf7-checkbox) label,
.wpcf7-form p:has(.wpcf7-radio) label {
	border: none;
	background: transparent;
	padding: 0;
	font-size: 0.9375rem;
	color: inherit;
	cursor: default;
}

.wpcf7-form p:has(.wpcf7-acceptance) label:focus-within,
.wpcf7-form p:has(.wpcf7-checkbox) label:focus-within,
.wpcf7-form p:has(.wpcf7-radio) label:focus-within {
	box-shadow: none;
	border-color: transparent;
}

.wpcf7-form .wpcf7-list-item {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-right: 1.5rem;
}

/* --- Validation --- */
.wpcf7-form label:has(.wpcf7-not-valid) {
	border-color: #e74c3c !important;
}

.wpcf7-not-valid-tip {
	color: #e74c3c;
	font-size: 0.75rem;
	margin-top: 0.125rem;
}

/* --- Response Messages --- */
.wpcf7-response-output {
	grid-column: 1 / -1;
	padding: 1rem 1.25rem !important;
	border-radius: var(--ppg-radius-md, 0.5rem) !important;
	font-size: 0.9375rem;
	margin: 0.5rem 0 0 !important;
}

.wpcf7-form.sent .wpcf7-response-output {
	border-color: #27ae60 !important;
	background: rgba(39, 174, 96, 0.08);
	color: #27ae60;
}

.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output {
	border-color: #e74c3c !important;
	background: rgba(231, 76, 60, 0.08);
	color: #e74c3c;
}

/* --- Spinner --- */
.wpcf7-spinner {
	margin-left: 1rem;
}

/* --- Responsive: single column on mobile --- */
@media (max-width: 48rem) {
	.wpcf7-form {
		grid-template-columns: 1fr;
	}

	.wpcf7-form input[type="submit"] {
		width: 100%;
	}
}
