/* Kontaktseite – einspaltig, minimalistische Linien-Felder, Marine-Akzent (DM2030) */
.dm2030-contact {
	--contact-navy: #1a3a52;
	--contact-muted: #64748b;
	--contact-panel: #eceff3;
	--contact-line: rgba(26, 58, 82, 0.28);
}

.dm2030-contact .dm2030-contact-main .fade-in {
	animation: dm2030-fadeIn 0.7s ease forwards;
}

.dm2030-contact .dm2030-contact-form-panel {
	background: var(--contact-panel);
}

.dm2030-contact .dm2030-contact-title {
	font-style: normal;
	font-weight: 700 !important;
	letter-spacing: 0.02em;
}

.dm2030-contact .dm2030-contact-icon {
	width: 3.25rem;
	height: 3.25rem;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--contact-navy);
	color: #ffffff;
	border-radius: 2px;
	box-shadow: 0 2px 8px rgba(26, 58, 82, 0.15);
}

.dm2030-contact .dm2030-contact-label {
	font-size: 0.9375rem;
	font-weight: 600;
	text-transform: none;
	letter-spacing: 0.01em;
	color: var(--contact-navy);
}

.dm2030-contact .dm2030-contact-req {
	margin-left: 0.12em;
	text-decoration: none;
	font-weight: 700;
	color: var(--contact-navy);
	border: 0;
	cursor: help;
}

.dm2030-contact .dm2030-contact-meta-line .dm2030-contact-meta-link {
	font-weight: 400;
	color: inherit;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
}

.dm2030-contact .dm2030-contact-meta-line .dm2030-contact-meta-link:hover {
	text-decoration: underline;
}

.dm2030-contact .dm2030-contact-meta-line .dm2030-contact-meta-link:focus-visible {
	outline: 2px solid var(--contact-navy);
	outline-offset: 3px;
}

/* Minimal: nur untere Linie statt Kasten */
.dm2030-contact .input-field.dm2030-contact-input {
	display: block;
	width: 100%;
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--contact-line);
	border-radius: 0;
	padding: 0.35rem 0 0.6rem;
	box-shadow: none;
	transition: border-color 0.2s ease;
}

.dm2030-contact .dm2030-contact-textarea.dm2030-contact-input {
	min-height: 7.5rem;
	line-height: 1.55;
	resize: vertical;
	padding-top: 0.45rem;
}

.dm2030-contact .input-field.dm2030-contact-input::placeholder {
	color: #94a3b8;
}

.dm2030-contact .input-field.dm2030-contact-input:hover {
	border-bottom-color: rgba(26, 58, 82, 0.42);
}

.dm2030-contact .input-field.dm2030-contact-input:focus {
	border-bottom-color: var(--contact-navy);
	border-bottom-width: 2px;
	padding-bottom: calc(0.6rem - 1px);
	outline: none;
	box-shadow: none;
	background: transparent;
}

.dm2030-contact .dm2030-contact-submit {
	background: var(--contact-navy);
	border: none;
	cursor: pointer;
}

.dm2030-contact .dm2030-contact-submit-arrow {
	font-size: 1.125rem;
	line-height: 1;
	transition: transform 0.2s ease;
}

.dm2030-contact .dm2030-contact-submit:hover .dm2030-contact-submit-arrow {
	transform: translateX(4px);
}

@keyframes dm2030-fadeIn {
	from {
		opacity: 0;
		transform: translateY(14px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
