.anfrage-page {
	background: var(--color-bg);
	padding-block: 0;
}

.anfrage-hero {
	background:
		linear-gradient(90deg, rgba(23, 72, 63, 0.08) 0 1px, transparent 1px 88px),
		linear-gradient(180deg, var(--color-bg-warm), var(--color-surface));
	padding-block: clamp(2.5rem, 7vw, 5rem);
}

.anfrage-eyebrow {
	color: var(--color-primary);
	font-weight: 900;
	text-transform: uppercase;
}

.anfrage-hero h1 {
	font-size: clamp(2.2rem, 5vw, 3.8rem);
	margin-block-end: 0.75rem;
}

.anfrage-hero p:last-child {
	color: var(--color-text-secondary);
	font-size: 1.15rem;
	max-width: 66ch;
}

.anfrage-form-section {
	padding-block: clamp(2rem, 6vw, 4rem);
}

.anfrage-form {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	margin-inline: auto;
	max-width: 980px;
	overflow: hidden;
}

.anfrage-progress {
	background: rgba(27, 58, 107, 0.04);
	border-bottom: 1px solid var(--color-border);
	padding: 1rem clamp(1.25rem, 4vw, 2rem);
}

.anfrage-progress__mobile {
	color: var(--color-primary);
	font-weight: 900;
	margin: 0;
	text-align: center;
}

.anfrage-progress__steps {
	display: none;
	list-style: none;
	margin: 0;
	padding: 0;
}

.anfrage-progress__steps li {
	align-items: center;
	color: var(--color-text-secondary);
	display: flex;
	flex-wrap: wrap;
	font-size: clamp(0.78rem, 1.2vw, 0.92rem);
	font-weight: 800;
	gap: 0.45rem;
	line-height: 1.2;
	min-width: 0;
}

.anfrage-progress__steps span {
	align-items: center;
	background: var(--color-border);
	border-radius: var(--radius-full);
	display: inline-flex;
	height: 32px;
	justify-content: center;
	width: 32px;
}

.anfrage-progress__steps .is-active {
	color: var(--color-primary);
}

.anfrage-progress__steps .is-active span,
.anfrage-progress__steps .is-complete span {
	background: var(--color-accent);
	color: var(--color-text);
}

.form-step {
	border: 0;
	display: none;
	margin: 0;
	padding: clamp(1.8rem, 4vw, 2.5rem) clamp(1.25rem, 4vw, 2rem) clamp(1.25rem, 4vw, 2rem);
}

.form-step.is-active {
	animation: anfrage-step-in 0.28s ease both;
	display: block;
}

.form-step legend {
	color: var(--color-primary);
	display: block;
	font-family: var(--font-heading);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 900;
	margin-block-end: 1.4rem;
	max-width: 100%;
	padding: 0;
}

.form-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.anfrage-form label {
	color: var(--color-text);
	display: grid;
	font-weight: 800;
	gap: 0.4rem;
}

.anfrage-form input,
.anfrage-form select,
.anfrage-form textarea {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font: inherit;
	min-height: 44px;
	padding: 0.75rem 0.85rem;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.anfrage-form input:focus,
.anfrage-form select:focus,
.anfrage-form textarea:focus {
	border-color: var(--color-border-focus);
	box-shadow: 0 0 0 3px rgba(27, 58, 107, 0.14);
	outline: 0;
}

.anfrage-form .is-invalid {
	border-color: #b91c1c;
}

.field-error,
.anfrage-status.is-error {
	color: #b91c1c;
	font-size: 0.9rem;
	font-weight: 700;
}

.anfrage-status {
	padding-inline: clamp(1.25rem, 4vw, 2rem);
	padding-block-start: 1rem;
}

.anfrage-status.is-info {
	color: var(--color-primary);
	font-weight: 800;
}

.radio-grid,
.checkbox-grid {
	display: grid;
	gap: 0.75rem;
	margin-block-start: 1rem;
}

.radio-grid label,
.checkbox-grid label,
.checkbox-line,
.consent-box label {
	align-items: center;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	display: flex;
	gap: 0.55rem;
	min-height: 44px;
	padding: 0.75rem;
}

.extras-groups {
	gap: 16px;
	grid-template-columns: 1fr;
}

.extras-group {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	display: grid;
	gap: 0.75rem;
	margin: 0;
	padding: 1rem;
}

.extras-group legend {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 900;
	margin: 0;
	padding: 0 0.25rem;
}

.extras-group label {
	background: var(--color-bg);
	margin: 0;
}

.extras-group label:has(textarea) {
	align-items: stretch;
	display: grid;
}

.extras-group textarea {
	width: 100%;
}

.toggle-extra-address {
	background: transparent;
	border: 0;
	color: var(--color-primary);
	cursor: pointer;
	font-weight: 900;
	margin-block: 1rem;
	min-height: 44px;
	padding: 0;
}

.extra-address {
	animation: anfrage-step-in 0.24s ease both;
}

.gutliste-layout {
	display: grid;
	gap: 1.25rem;
}

.gutliste-accordions {
	display: grid;
	gap: 0.75rem;
	min-width: 0;
}

.gutliste-category {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.gutliste-category__toggle {
	align-items: center;
	background: var(--color-bg);
	border: 0;
	color: var(--color-text);
	cursor: pointer;
	display: flex;
	font: inherit;
	font-weight: 900;
	justify-content: space-between;
	min-height: 52px;
	padding: 0.9rem 1rem;
	text-align: left;
	width: 100%;
}

.gutliste-category__toggle:hover,
.gutliste-category__toggle:focus-visible {
	background: var(--color-accent-light);
	outline: 0;
}

.gutliste-category__toggle::after {
	align-items: center;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-full);
	color: var(--color-primary);
	content: "+";
	display: inline-flex;
	font-size: 1.35rem;
	height: 34px;
	justify-content: center;
	line-height: 1;
	margin-inline-start: 0.75rem;
	width: 34px;
}

.gutliste-category__toggle[aria-expanded="true"]::after {
	content: "−";
}

.gutliste-category__toggle small {
	color: var(--color-text-secondary);
	font-size: 0.85rem;
	font-weight: 800;
	text-align: right;
}

.gutliste-category__panel {
	animation: anfrage-step-in 0.22s ease both;
	display: grid;
	gap: 0.55rem;
	padding: 0.75rem;
}

.gutliste-item {
	align-items: center;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	display: grid;
	gap: 0.75rem;
	padding: 0.72rem;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.gutliste-item:has(input:checked) {
	border-color: rgba(245, 166, 35, 0.72);
	box-shadow: var(--shadow-sm);
}

.gutliste-item__label {
	align-items: center !important;
	background: transparent !important;
	border: 0 !important;
	display: grid !important;
	gap: 0.45rem !important;
	grid-template-columns: auto 1fr auto;
	min-height: 44px;
	padding: 0 !important;
}

.gutliste-item__label small {
	color: var(--color-text-secondary);
	font-weight: 700;
	white-space: nowrap;
}

.gutliste-qty {
	animation: gutliste-qty-in 0.18s ease both;
	display: inline-grid;
	gap: 0.25rem;
	grid-template-columns: 38px 62px 38px;
	justify-content: end;
}

.gutliste-qty[hidden] {
	display: none;
}

.gutliste-qty button,
.gutliste-qty input {
	border-radius: var(--radius-sm);
	min-height: 38px;
	text-align: center;
}

.gutliste-qty button {
	background: var(--color-primary);
	border: 0;
	color: var(--color-surface);
	cursor: pointer;
	font-size: 1.1rem;
	font-weight: 900;
}

.gutliste-custom {
	margin-block-start: 0.25rem;
}

.gutliste-note {
	background: var(--color-accent-light);
	border-radius: var(--radius-sm);
	color: var(--color-text-secondary);
	font-size: 0.92rem;
	font-weight: 700;
	margin: 0;
	padding: 0.85rem;
}

.gutliste-summary {
	background:
		linear-gradient(135deg, rgba(27, 58, 107, 0.98), rgba(14, 31, 59, 1)),
		var(--color-primary);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-md);
	color: var(--color-surface);
	display: grid;
	gap: 0.75rem;
	padding: 1rem;
}

.gutliste-summary span {
	color: rgba(255, 255, 255, 0.78);
	font-weight: 800;
}

.gutliste-summary strong {
	color: var(--color-accent);
	font-family: var(--font-heading);
	font-size: clamp(1.6rem, 4vw, 2.25rem);
	line-height: 1.1;
}

.gutliste-breakdown-toggle {
	background: rgba(255, 255, 255, 0.10);
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: var(--radius-full);
	color: var(--color-surface);
	cursor: pointer;
	font-weight: 900;
	min-height: 44px;
	padding: 0.65rem 0.9rem;
}

.gutliste-breakdown {
	display: grid;
	gap: 0.45rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.gutliste-breakdown li {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, 0.16);
	display: flex;
	justify-content: space-between;
	padding-block-start: 0.45rem;
}

.gutliste-breakdown strong {
	font-size: 1rem;
}

.washer-note {
	background: var(--color-accent-light);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-weight: 700;
	margin-block-start: 1rem;
	padding: 0.85rem;
}

.consent-box {
	display: grid;
	gap: 0.75rem;
	margin-block-start: 1rem;
}

.form-actions {
	align-items: center;
	background: var(--color-bg);
	border-top: 1px solid var(--color-border);
	display: grid;
	gap: 0.75rem;
	grid-template-columns: 1fr;
	padding: 1rem clamp(1.25rem, 4vw, 2rem);
}

.form-actions .button {
	min-height: 44px;
}

.form-actions .form-prev {
	justify-self: start;
}

.form-actions .form-next {
	justify-self: end;
}

.spinner {
	border: 2px solid rgba(255, 255, 255, 0.45);
	border-radius: 50%;
	border-top-color: var(--color-surface);
	display: none;
	height: 18px;
	width: 18px;
}

.form-next.is-loading::after {
	animation: anfrage-spin 0.8s linear infinite;
	border: 2px solid rgba(255, 255, 255, 0.45);
	border-radius: 50%;
	border-top-color: currentcolor;
	content: "";
	height: 16px;
	margin-inline-start: 0.5rem;
	width: 16px;
}

.anfrage-success {
	animation: anfrage-step-in 0.35s ease both;
	padding: clamp(2rem, 6vw, 4rem);
	text-align: center;
}

.anfrage-success h2 {
	color: var(--color-primary);
	font-size: clamp(2rem, 5vw, 3rem);
}

@keyframes anfrage-step-in {
	from {
		opacity: 0;
		transform: translateY(14px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes anfrage-spin {
	to {
		transform: rotate(360deg);
	}
}

@keyframes gutliste-qty-in {
	from {
		opacity: 0;
		transform: translateY(-6px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (min-width: 700px) {
	.anfrage-progress__mobile {
		display: none;
	}

	.anfrage-progress__steps {
		display: grid;
		gap: 0.75rem;
		grid-template-columns: repeat(6, minmax(0, 1fr));
	}

	.form-actions {
		grid-template-columns: 1fr 1fr;
	}

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

	.checkbox-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.extras-groups {
		grid-template-columns: 1fr;
	}
}

@media (min-width: 980px) {
	.checkbox-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}

	.extras-groups {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.extras-group--wide {
		grid-column: 1 / -1;
	}

	.gutliste-layout {
		align-items: start;
		grid-template-columns: minmax(0, 1fr) 290px;
	}

	.gutliste-summary {
		position: sticky;
		top: 150px;
	}

	.gutliste-item {
		grid-template-columns: minmax(0, 1fr) auto;
	}
}

@media (prefers-reduced-motion: reduce) {
	.form-step.is-active,
	.extra-address,
	.anfrage-success,
	.gutliste-category__panel,
	.gutliste-qty {
		animation: none;
	}
}
