/**
 * Friedrich Sailer Theme – Main Stylesheet
 * Based on Figma Design: Website2026 / 01_Startseite
 *
 * Structure:
 * 1. CSS Custom Properties (Design Tokens)
 * 2. Global Resets & Base
 * 3. Header
 * 4. Hero Slider
 * 5. Teaser Text
 * 6. Produktkatalog
 * 7. Kompetenz Slider
 * 8. Branchenübersicht
 * 9. Text & Bild (Hygienic Design)
 * 10. Referenzen
 * 11. Footer Kontakt
 * 12. Button Styles
 * 13. Utilities & Animations
 */

/* ==========================================================================
   1. CSS Custom Properties (Design Tokens from Figma)
   ========================================================================== */

:root {
	/* Colors */
	--fs-rot: #E30613;
	--fs-hellgrau: #F0F0F0;
	--fs-dunkelgrau: #535353;
	--fs-mittelgrau: #707070;
	--fs-weiss: #FFFFFF;
	--fs-schwarz: #000000;
	--fs-siegel-blau: #2C6AB3;

	/* Typography */
	--fs-font-azo: 'Azo Sans', sans-serif;
	--fs-font-open: 'Open Sans', sans-serif;

	/* Font Weights */
	--fs-weight-light: 300;
	--fs-weight-regular: 400;
	--fs-weight-medium: 500;
	--fs-weight-bold: 700;

	/* Font Sizes */
	--fs-size-xs: 10px;
	--fs-size-sm: 16px;
	--fs-size-md: 18px;
	--fs-size-lg: 25px;
	--fs-size-teaser: 35px;
	--fs-size-heading: 40px;

	/* Spacing */
	--fs-section-padding: 120px;
	--fs-content-width: 1364px;
	--fs-wide-width: 1920px;
	--fs-side-padding: 278px;
	--fs-heading-gap: 10px;
	--fs-section-header-gap: 38px;

	/* Shadows */
	--fs-shadow-card: 0px 0px 15px 0px rgba(0, 0, 0, 0.16);

	/* Transitions */
	--fs-transition: 0.3s ease;
	--fs-transition-slow: 0.6s ease;

	/* Z-Index */
	--fs-z-header: 1000;
	--fs-z-hero-overlay: 10;
	--fs-z-slider-nav: 5;
}


/* ==========================================================================
   2. Global Resets & Base
   ========================================================================== */

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

body {
	font-family: var(--fs-font-open);
	font-size: var(--fs-size-md);
	font-weight: var(--fs-weight-regular);
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
	background-color: var(--fs-weiss);
	margin: 0;
	padding: 0;
	overflow-x: hidden;
	padding-top: calc(var(--fs-header-offset, 0px) + var(--fs-adminbar-offset, 0px));
}

body.admin-bar {
	--fs-adminbar-offset: 32px;
}

@media (max-width: 782px) {
	body.admin-bar {
		--fs-adminbar-offset: 46px;
	}
}

img {
	max-width: 100%;
	height: auto;
}


/* ==========================================================================
   3. Header
   ========================================================================== */

.fs-header,
.site-header {
	position: fixed;
	top: var(--fs-adminbar-offset, 0px);
	left: 0;
	right: 0;
	width: 100%;
	z-index: var(--fs-z-header);
	background-color: var(--fs-hellgrau);
	transition: var(--fs-transition);
}

.fs-header--shrink {
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.fs-header--shrink .fs-header__inner {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

.fs-header--shrink .site-header__inner {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

.fs-header--shrink .fs-logo img {
	height: 50px !important;
	width: auto !important;
}

.fs-header--shrink .site-header__logo img {
	height: 50px !important;
	width: auto !important;
}

.fs-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: var(--fs-wide-width);
	margin: 0 auto;
	position: relative;
	transition: padding var(--fs-transition);
}

.fs-header__logo {
	flex-shrink: 0;
}

.fs-logo {
	margin: 0 !important;
}

.fs-logo img {
	width: 248px !important;
	height: 76px !important;
	object-fit: contain;
	transition: var(--fs-transition);
}

/* Navigation */
.fs-header__nav-wrap {
	flex: 1;
	display: flex;
	justify-content: center;
}

.fs-main-nav {
	gap: 40px;
}

.fs-main-nav .wp-block-navigation-item__content,
.fs-main-nav .wp-block-navigation-link__content {
	font-family: var(--fs-font-open);
	font-size: var(--fs-size-md);
	font-weight: var(--fs-weight-regular);
	color: var(--fs-dunkelgrau);
	text-decoration: none;
	transition: color var(--fs-transition);
}

.fs-main-nav .wp-block-navigation-item__content:hover,
.fs-main-nav .wp-block-navigation-link__content:hover {
	color: var(--fs-rot);
}

.fs-main-nav .wp-block-navigation-item.has-fs-solutions-mega.is-fs-solutions-open > .wp-block-navigation-item__content {
	color: var(--fs-rot);
}

/* Lösungen Mega Menu */
.fs-solutions-mega {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	padding: 0 140px 24px;
	z-index: calc(var(--fs-z-header) + 2);
}

.fs-solutions-mega[hidden] {
	display: none;
}

.fs-solutions-mega__inner {
	max-width: 1640px;
	margin: 0 auto;
	padding: 24px 42px 32px;
	background: var(--fs-weiss);
	border: 1px solid rgba(83, 83, 83, 0.14);
	border-radius: 8px;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
}

.fs-solutions-mega__tabs {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin-bottom: 28px;
}

.fs-solutions-mega__tab {
	min-width: 170px;
	height: 34px;
	padding: 0 20px;
	border: 1px solid rgba(83, 83, 83, 0.28);
	border-radius: 17px;
	background: transparent;
	color: var(--fs-dunkelgrau);
	font-family: var(--fs-font-open);
	font-size: 16px;
	font-weight: var(--fs-weight-regular);
	line-height: 1;
	cursor: pointer;
	transition: var(--fs-transition);
}

.fs-solutions-mega__tab:hover,
.fs-solutions-mega__tab.is-active {
	border-color: var(--fs-dunkelgrau);
	font-weight: var(--fs-weight-bold);
}

.fs-solutions-mega__tab:focus-visible,
.fs-solutions-mega__link:focus-visible {
	outline: 2px solid rgba(227, 6, 19, 0.5);
	outline-offset: 2px;
}

.fs-solutions-mega__panel {
	display: none;
}

.fs-solutions-mega__panel.is-active {
	display: block;
}

.fs-solutions-mega__panel[hidden] {
	display: none !important;
}

.fs-solutions-mega__grid {
	display: grid;
	gap: 12px 20px;
}

.fs-solutions-mega__grid--branchen {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.fs-solutions-mega__grid--produkte {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.fs-solutions-mega__link {
	display: flex;
	align-items: center;
	gap: 10px;
	min-height: 38px;
	padding: 7px 14px;
	border-radius: 20px;
	background: var(--fs-hellgrau);
	color: var(--fs-dunkelgrau);
	font-size: 15px;
	line-height: 1.25;
	text-decoration: none;
	transition: var(--fs-transition);
}

.fs-solutions-mega__link:hover {
	background: #e7e7e7;
	color: var(--fs-rot);
}

.fs-solutions-mega__link--produkt {
	min-height: 42px;
	border-radius: 4px;
	padding: 10px 12px;
}

.fs-solutions-mega__icon {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	object-fit: contain;
}

.fs-main-nav .wp-block-navigation-item.has-fs-competences-mega.is-fs-competences-open > .wp-block-navigation-item__content {
	color: var(--fs-rot);
}

.fs-main-nav .wp-block-navigation-item.has-fs-company-mega.is-fs-company-open > .wp-block-navigation-item__content {
	color: var(--fs-rot);
}

.fs-competences-mega {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	padding: 0 140px 24px;
	z-index: calc(var(--fs-z-header) + 2);
}

.fs-competences-mega[hidden] {
	display: none;
}

.fs-competences-mega__inner {
	max-width: 1640px;
	margin: 0 auto;
	padding: 24px 42px 32px;
	background: var(--fs-weiss);
	border: 1px solid rgba(83, 83, 83, 0.14);
	border-radius: 8px;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
}

.fs-competences-mega__tabs {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin-bottom: 28px;
}

.fs-competences-mega__tab {
	min-width: 190px;
	height: 34px;
	padding: 0 20px;
	border: 1px solid rgba(83, 83, 83, 0.28);
	border-radius: 17px;
	background: transparent;
	color: var(--fs-dunkelgrau);
	font-family: var(--fs-font-open);
	font-size: 16px;
	font-weight: var(--fs-weight-regular);
	line-height: 1;
	cursor: pointer;
	transition: var(--fs-transition);
}

.fs-competences-mega__tab:hover,
.fs-competences-mega__tab.is-active {
	border-color: var(--fs-dunkelgrau);
	font-weight: var(--fs-weight-bold);
}

.fs-competences-mega__tab:focus-visible,
.fs-competences-mega__link:focus-visible {
	outline: 2px solid rgba(227, 6, 19, 0.5);
	outline-offset: 2px;
}

.fs-competences-mega__panel {
	display: none;
}

.fs-competences-mega__panel.is-active {
	display: block;
}

.fs-competences-mega__panel[hidden] {
	display: none !important;
}

.fs-competences-mega__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px 20px;
}

.fs-competences-mega__link {
	display: flex;
	align-items: center;
	min-height: 42px;
	padding: 10px 12px;
	border-radius: 4px;
	background: var(--fs-hellgrau);
	color: var(--fs-dunkelgrau);
	font-size: 15px;
	line-height: 1.25;
	text-decoration: none;
	transition: var(--fs-transition);
}

.fs-competences-mega__link:hover {
	background: #e7e7e7;
	color: var(--fs-rot);
}

.fs-company-mega {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	padding: 0 140px 24px;
	z-index: calc(var(--fs-z-header) + 2);
}

.fs-company-mega[hidden] {
	display: none;
}

.fs-company-mega__inner {
	max-width: 1640px;
	margin: 0 auto;
	padding: 24px 42px 32px;
	background: var(--fs-weiss);
	border: 1px solid rgba(83, 83, 83, 0.14);
	border-radius: 8px;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
}

.fs-company-mega__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px 40px;
}

.fs-company-mega__link {
	display: flex;
	align-items: center;
	min-height: 42px;
	padding: 10px 12px;
	border-radius: 4px;
	background: var(--fs-hellgrau);
	color: var(--fs-dunkelgrau);
	font-size: 15px;
	line-height: 1.25;
	text-decoration: none;
	transition: var(--fs-transition);
}

.fs-company-mega__link:hover {
	background: #e7e7e7;
	color: var(--fs-rot);
}

.fs-company-mega__link:focus-visible {
	outline: 2px solid rgba(227, 6, 19, 0.5);
	outline-offset: 2px;
}

/* Header Actions (Search, Cart, Kontakt) */
.fs-header__actions {
	position: absolute;
	right: 140px;
	top: 0;
	bottom: auto;
	width: auto;
	min-width: 170px;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 14px;
	padding-top: 47px;
	flex-shrink: 0;
}

.fs-header__utility {
	position: static;
	display: flex;
	align-items: center;
	gap: 18px;
}

.fs-header__utility > p {
	margin: 0;
	display: contents;
}

.fs-header__cta {
	position: static;
	margin: 0 !important;
}

.fs-header--shrink .fs-header__actions {
	gap: 10px;
	padding-top: 15px;
}

/* Search Button */
.fs-search-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 0;
	padding: 0;
	color: var(--fs-dunkelgrau);
	text-decoration: none;
	transition: color var(--fs-transition);
	cursor: pointer;
}

.fs-search-btn:hover {
	color: var(--fs-rot);
}

.fs-search-btn:hover svg circle,
.fs-search-btn:hover svg line {
	stroke: var(--fs-rot);
}

.fs-search-btn svg {
	transition: transform 0.2s ease;
}

.fs-search-btn[aria-expanded="true"] svg {
	transform: scale(1.2);
}

.fs-search-panel {
	position: absolute;
	top: 0;
	right: 50%;
	transform: translateX(50%);
	z-index: 30;
	width: min(920px, calc(100vw - 40px));
	max-height: min(78vh, 860px);
	overflow: auto;
	padding: 18px 28px 24px;
	border: 1px solid rgba(83, 83, 83, 0.14);
	border-radius: 18px;
	background: var(--fs-weiss);
	box-shadow: 0 16px 36px rgba(0, 0, 0, 0.14);
}

.fs-search-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(83, 83, 83, 0.55);
	z-index: 25;
}

body.fs-search-open {
	overflow: hidden;
}

.fs-search-form {
	display: grid;
	grid-template-columns: 1fr 42px;
	gap: 12px;
	margin-bottom: 14px;
}

.fs-search-form__label {
	grid-column: 1 / -1;
	font-size: 14px;
	color: var(--fs-dunkelgrau);
}

.fs-search-form__input {
	height: 56px;
	border: 1px solid rgba(83, 83, 83, 0.2);
	border-radius: 999px;
	padding: 0 24px;
	font-size: 16px;
}

.fs-search-form__input:focus {
	outline: 2px solid rgba(227, 6, 19, 0.35);
	outline-offset: 0;
	border-color: var(--fs-rot);
}

.fs-search-form__submit {
	height: 42px;
	width: 42px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: transparent;
	color: var(--fs-dunkelgrau);
	font-size: 20px;
	cursor: pointer;
}

.fs-search-scope {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
}

.fs-search-scope__chip {
	height: 28px;
	padding: 0 18px;
	border: 1px solid rgba(83, 83, 83, 0.45);
	border-radius: 999px;
	background: transparent;
	color: var(--fs-dunkelgrau);
	font-size: 14px;
	cursor: pointer;
}

.fs-search-scope__chip.is-active {
	border-color: var(--fs-dunkelgrau);
	font-weight: 700;
}

.fs-search-panel__results {
	display: grid;
	gap: 0;
}

.fs-search-preview-card {
	display: grid;
	grid-template-columns: 96px 1fr;
	gap: 18px;
	padding: 16px 0;
	border-top: 1px solid rgba(83, 83, 83, 0.2);
}

.fs-search-preview-card__image img {
	width: 96px;
	height: 72px;
	object-fit: cover;
	border-radius: 6px;
}

.fs-search-preview-card__title {
	margin: 0 0 6px;
	font-size: 24px;
}

.fs-search-preview-card__title a {
	color: var(--fs-dunkelgrau);
	text-decoration: none;
}

.fs-search-preview-card__excerpt {
	margin: 0;
	font-size: 14px;
	line-height: 1.4;
}

.fs-search-preview__empty {
	margin: 12px 0 8px;
}

.fs-search-panel__footer {
	margin-top: 16px;
	display: flex;
	justify-content: center;
}

.fs-search-debug {
	margin: 12px 0 0;
	padding: 10px 12px;
	background: #f5f5f5;
	border: 1px dashed #b4b4b4;
	border-radius: 8px;
	font-size: 12px;
	line-height: 1.35;
	white-space: pre-wrap;
}

/* Warenkorb Button */
.fs-warenkorb-btn {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	color: inherit;
	cursor: pointer;
}

.fs-warenkorb-icon {
	display: block;
	width: 31px;
	height: 29px;
}

.fs-warenkorb-btn:hover .fs-warenkorb-icon {
	opacity: 0.85;
}

/* Cart Badge */
.fs-cart-badge {
	position: absolute;
	top: -8px;
	right: -14px;
	background-color: var(--fs-rot);
	color: var(--fs-weiss);
	font-size: 10px;
	font-weight: var(--fs-weight-bold);
	border-radius: 50%;
	width: 23px;
	height: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

/* Kontakt Button */
.fs-btn-kontakt .wp-block-button__link {
	border: 1px solid var(--fs-dunkelgrau) !important;
	border-radius: 16px !important;
	padding: 4px 24px !important;
	background: transparent !important;
	color: var(--fs-dunkelgrau) !important;
	font-size: var(--fs-size-md) !important;
	font-weight: var(--fs-weight-regular) !important;
	line-height: 1.36 !important;
	transition: var(--fs-transition);
	text-decoration: none;
	white-space: nowrap;
}

.fs-btn-kontakt .wp-block-button__link:hover {
	background: var(--fs-dunkelgrau) !important;
	color: var(--fs-weiss) !important;
}

/* Search page */
.fs-search-results {
	max-width: var(--fs-wide-width);
	margin: 0 auto;
	padding: 56px var(--fs-container-padding) 80px;
}

.fs-search-results__title {
	font-size: clamp(32px, 4vw, 52px);
	line-height: 1.2;
	margin-bottom: 14px;
}

.fs-search-results__eyebrow {
	margin: 0 0 10px;
	font-size: 44px;
	line-height: 1.2;
	color: var(--fs-dunkelgrau);
}

.fs-search-results__hint {
	color: var(--fs-grau);
	margin-bottom: 34px;
}

.fs-search-results__filter {
	display: flex;
	justify-content: flex-end;
	gap: 10px;
	margin-bottom: 22px;
}

.fs-search-results__loop {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 0;
}

.fs-search-result-card {
	padding: 36px 0;
	border-bottom: 1px solid rgba(83, 83, 83, 0.22);
	background: transparent;
}

.fs-search-result-card__columns {
	display: grid;
	grid-template-columns: 208px 1fr;
	gap: 30px;
	align-items: start;
}

.fs-search-result-card__type {
	color: var(--fs-grau);
	font-size: 14px;
	text-transform: none;
	letter-spacing: 0;
	margin: 0 0 8px;
}

.fs-search-result-card__title a {
	color: var(--fs-dunkelgrau);
	text-decoration: none;
}

.fs-search-result-card__image img {
	width: 100%;
	height: 168px;
	object-fit: cover;
	border-radius: 8px;
}

.fs-search-result-card__title a:hover {
	color: var(--fs-rot);
}

.fs-search-result-card__excerpt {
	margin-top: 10px;
	font-size: 16px;
	line-height: 1.45;
}

.fs-search-result-card__more {
	margin: 20px 0 0;
	font-size: 14px;
}

.fs-search-result-card__more a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 124px;
	padding: 5px 16px 6px;
	border: 1px solid var(--fs-mittelgrau);
	border-radius: 999px;
	text-decoration: none;
	color: var(--fs-dunkelgrau);
}

.fs-search-results__loadmore-wrap {
	display: flex;
	justify-content: center;
	margin-top: 64px;
	padding-bottom: 12px;
}

.fs-search-results__loadmore {
	appearance: none;
	min-width: 164px;
	height: 30px;
	padding: 0 18px;
	border: 1px solid rgba(83, 83, 83, 0.52);
	border-radius: 999px;
	background: transparent;
	color: #8f8f8f;
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 300;
	line-height: 1;
	cursor: pointer;
	transition: all var(--fs-transition-fast);
}

.fs-search-results__loadmore:hover {
	color: var(--fs-dunkelgrau);
	border-color: var(--fs-dunkelgrau);
	background: rgba(255, 255, 255, 0.6);
}

.fs-search-results__loadmore:focus-visible {
	outline: 2px solid rgba(83, 83, 83, 0.35);
	outline-offset: 2px;
}

.fs-search-noresults {
	padding: 26px 24px;
	border: 1px dashed rgba(83, 83, 83, 0.45);
	border-radius: 16px;
}

.fs-footer-kontakt__form > p,
.fs-footer-meta > p {
	margin: 0;
}


/* ==========================================================================
   4. Hero Slider
   ========================================================================== */

.fs-hero-slider {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.fs-hero-slider__viewport {
	position: relative;
	width: min(1774px, calc(100% - 92px));
	margin: 0 auto;
	overflow: hidden;
}

.fs-hero-slider__track {
	display: flex;
	transition: transform var(--fs-transition-slow);
	width: 100%;
}

.fs-hero-slide {
	flex: 0 0 100%;
	width: 100%;
}

.fs-hero-slide__cover {
	min-height: 730px;
}

.fs-hero-slide__cover .wp-block-cover__inner-container {
	display: flex;
	align-items: flex-end;
	min-height: 730px;
	padding: 0;
}

.fs-hero-slide__content {
	width: 100%;
	max-width: none;
}

.fs-hero-title {
	font-family: var(--fs-font-open);
	font-weight: var(--fs-weight-bold);
	font-size: var(--fs-size-heading);
	line-height: 1.36;
	color: var(--fs-weiss) !important;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Branchen Overlay Tiles */
.fs-hero-branchen-overlay {
	position: relative;
	margin-top: -46px;
	z-index: var(--fs-z-hero-overlay);
}

.fs-hero-branchen-tiles {
	max-width: 1774px;
	margin: 0 auto;
	display: flex !important;
	justify-content: flex-start;
	gap: 16px;
	flex-wrap: nowrap !important;
	padding: 0 80px;
}

.fs-branchen-tile {
	flex: 0 0 auto;
	width: 260px;
	min-height: 92px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	cursor: pointer;
	transition: background var(--fs-transition), transform var(--fs-transition);
	border: none;
	border-radius: 5px;
	padding: 19px 26px !important;
}

.fs-branchen-tile p,
.fs-branchen-tile h4 {
	margin: 0 !important;
}

.fs-branchen-tile__title {
	font-size: 18px !important;
	line-height: 1.3618 !important;
}

/* First tile: light grey background, dark bold text (active state) */
.fs-branchen-tile--first {
	background-color: var(--fs-hellgrau) !important;
}

.fs-branchen-tile--active {
	background-color: var(--fs-hellgrau) !important;
}

.fs-branchen-tile--first .fs-branchen-tile__line1 {
	color: var(--fs-dunkelgrau) !important;
	font-weight: var(--fs-weight-bold) !important;
}

.fs-branchen-tile--first .fs-branchen-tile__line2 {
	color: var(--fs-dunkelgrau) !important;
	font-weight: var(--fs-weight-bold) !important;
}

.fs-branchen-tile--first .fs-branchen-tile__title,
.fs-branchen-tile--active .fs-branchen-tile__title {
	color: var(--fs-dunkelgrau) !important;
	font-weight: var(--fs-weight-bold) !important;
}

/* Other tiles: red background, white normal text */
.fs-branchen-tile:not(.fs-branchen-tile--first):not(.fs-branchen-tile--active) {
	background-color: var(--fs-rot) !important;
}

.fs-branchen-tile:not(.fs-branchen-tile--first):not(.fs-branchen-tile--active) .fs-branchen-tile__line1 {
	color: var(--fs-weiss) !important;
	font-weight: var(--fs-weight-regular) !important;
}

.fs-branchen-tile:not(.fs-branchen-tile--first):not(.fs-branchen-tile--active) .fs-branchen-tile__line2 {
	color: var(--fs-weiss) !important;
	font-weight: var(--fs-weight-regular) !important;
}

.fs-branchen-tile:not(.fs-branchen-tile--first):not(.fs-branchen-tile--active) .fs-branchen-tile__title {
	color: var(--fs-weiss) !important;
	font-weight: var(--fs-weight-regular) !important;
}

/* Hover effects */
.fs-branchen-tile:not(.fs-branchen-tile--first):not(.fs-branchen-tile--active):hover {
	background-color: #C80510 !important;
}

.fs-branchen-tile--first:hover {
	background-color: #E8E8E8 !important;
}


/* ==========================================================================
   5. Teaser Text
   ========================================================================== */

.fs-teaser-text {
	text-align: center;
}

.fs-teaser-text__content {
	font-family: var(--fs-font-open);
	font-size: var(--fs-size-teaser);
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}


/* ==========================================================================
   6. Produktkatalog
   ========================================================================== */

.fs-produktkatalog__content {
	display: flex !important;
	align-items: flex-start;
	justify-content: space-between;
	gap: 129px;
}

.fs-produktkatalog__intro {
	flex: 0 0 561px;
	max-width: 561px;
}

.fs-produktkatalog__title {
	margin-bottom: 32px !important;
	max-width: 561px;
}

.fs-produktkatalog__text {
	max-width: 521px;
	margin: 0 0 32px !important;
}

.fs-produktkatalog__cta {
	margin-top: 0 !important;
}

.fs-btn-kategorien .wp-block-button__link {
	border-radius: 16px !important;
	padding: 4px 18px !important;
	font-size: 16px !important;
	font-weight: 300 !important;
	line-height: 1.36 !important;
}

.fs-produktkatalog__slider {
	flex: 0 0 669px;
	max-width: 669px;
}

.fs-produktkatalog__grid {
	display: grid !important;
	grid-template-columns: repeat(2, 311px);
	grid-template-rows: repeat(2, 359px);
	column-gap: 47px;
	row-gap: 32px;
}

.fs-produkt-card {
	background: var(--fs-hellgrau);
	width: 311px;
	height: 359px;
	overflow: hidden;
}

.fs-produkt-card__image {
	margin: 0 !important;
	height: 250px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-top: 40px;
}

.fs-produkt-card__image img {
	object-fit: contain;
	height: auto;
	max-width: 100%;
}

.fs-produkt-card--1 .fs-produkt-card__image img {
	width: 227px;
}

.fs-produkt-card--2 .fs-produkt-card__image img {
	width: 222px;
}

.fs-produkt-card--3 .fs-produkt-card__image img {
	width: 251px;
}

.fs-produkt-card--4 .fs-produkt-card__image img {
	width: 119px;
}

.fs-produkt-card__label {
	margin: 0 !important;
	padding: 23px 33px 0;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.5;
	color: var(--fs-dunkelgrau);
}

.fs-produktkatalog__pagination .fs-slider-dots {
	gap: 13px;
}

.fs-produktkatalog__pagination .fs-dot {
	width: 21px;
	height: 21px;
	border: none;
	background: #E1E1E1;
}


/* ==========================================================================
   7. Kompetenz Slider
   ========================================================================== */

.fs-kompetenz-slider {
	overflow: hidden;
}

.fs-kompetenz-slider__header {
	max-width: 632px;
	margin: 0 auto;
}

.fs-kompetenz-slider__header .fs-section-heading {
	max-width: 632px;
}

.fs-kompetenz-slider__carousel {
	position: relative;
	max-width: 1636px;
	margin: 0 auto;
	min-height: 359px;
}

.fs-kompetenz-slider__track {
	display: grid !important;
	grid-template-columns: repeat(4, 310px);
	gap: 41px;
	justify-content: center;
	padding: 0 68px;
}

.fs-kompetenz-element {
	width: 310px;
	min-height: 359px;
	background: var(--fs-hellgrau);
	padding: 42px 44px 30px;
	overflow: hidden;
}

.fs-kompetenz-element__title {
	margin: 0 0 18px !important;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.3618;
	color: var(--fs-dunkelgrau);
}

.fs-kompetenz-element__desc {
	margin: 0 !important;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.3618;
	color: var(--fs-dunkelgrau);
}

/* Slider Navigation */
.fs-kompetenz-slider__cta {
	padding-top: 45px;
}

.fs-slider-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	cursor: pointer;
	user-select: none;
	border: 0;
	background: transparent;
	color: #A8A8A8;
	transition: var(--fs-transition);
	font-size: 52px;
	line-height: 1;
	padding: 0;
	margin: 0;
	width: 28px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-slider-arrow--prev {
	left: 0;
}

.fs-slider-arrow--next {
	right: 0;
}

.fs-slider-arrow:hover {
	color: var(--fs-dunkelgrau);
}


/* ==========================================================================
   8. Branchenübersicht
   ========================================================================== */

.fs-branchenuebersicht {
	position: relative;
}

.fs-branchenuebersicht__grid {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px 20px;
}

.fs-branche-btn {
	display: flex !important;
	align-items: center;
	gap: 12px;
	padding: 0 !important;
	background: #dfdfdf;
	border-radius: 999px;
	height: 49px;
	cursor: pointer;
	transition: background-color var(--fs-transition), transform var(--fs-transition);
	overflow: hidden;
	box-shadow: none;
	text-decoration: none;
}

.fs-branche-btn:hover {
	background: #d7d7d7;
	transform: translateY(-1px);
}

.fs-branche-btn__icon {
	width: 60px;
	height: 49px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 !important;
	background-color: transparent;
}

.fs-branche-btn__icon img {
	width: 32px;
	height: 32px;
	object-fit: contain;
}

.fs-branche-btn__label {
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: var(--fs-weight-regular);
	color: var(--fs-dunkelgrau);
	line-height: 1.3;
	margin: 0 !important;
	padding-right: 12px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}


/* ==========================================================================
   9. Text & Bild (Hygienic Design)
   ========================================================================== */

.fs-text-bild__columns {
	align-items: center;
}

.fs-text-bild__text {
	padding-right: 60px;
}

.fs-text-bild__image {
	overflow: hidden;
}

.fs-hygienic-photo img {
	width: 100%;
	height: 545px;
	object-fit: cover;
}

.fs-text-bild__buttons {
	display: flex;
	gap: 16px;
}


/* ==========================================================================
   10. Referenzen
   ========================================================================== */

.fs-referenzen__cards {
	gap: 32px;
}

.fs-referenz-card__inner {
	overflow: hidden;
	border-radius: 0;
	box-shadow: var(--fs-shadow-card);
	transition: box-shadow var(--fs-transition), transform var(--fs-transition);
}

.fs-referenz-card__inner:hover {
	box-shadow: 0 4px 25px rgba(0, 0, 0, 0.2);
	transform: translateY(-4px);
}

.fs-referenz-card__image img {
	width: 100%;
	height: 311px;
	object-fit: cover;
}

.fs-referenz-card__image {
	margin-bottom: 0 !important;
}

.fs-referenz-card__title {
	margin-bottom: 0;
}


/* ==========================================================================
   11. Footer Kontakt
   ========================================================================== */

.fs-footer-kontakt {
	position: relative;
}

.fs-footer-kontakt__bottom {
	border-top: 1px solid rgba(0, 0, 0, 0.1);
	margin-top: 40px;
}

.fs-footer-kontakt--small .fs-footer-kontakt__bottom {
	margin-top: 0;
}

.fs-kontakt-form {
	display: block;
	width: 100%;
}

.fs-kontakt-form__status {
	display: none;
	margin-bottom: 18px;
	padding: 8px 12px;
	border-radius: 8px;
	font-size: 14px;
	line-height: 1.4;
}

.fs-kontakt-form__status.is-visible {
	display: block;
}

.fs-kontakt-form__status.is-success {
	background: rgba(0, 128, 0, 0.08);
	color: #2d6a35;
}

.fs-kontakt-form__status.is-error {
	background: rgba(227, 6, 19, 0.08);
	color: #8d1f28;
}

.fs-kontakt-form__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	column-gap: 24px;
	row-gap: 16px;
}

.fs-form-field {
	position: relative;
	display: flex;
	flex-direction: column;
}

.fs-form-field--span-2 {
	grid-column: span 2;
}

.fs-form-label {
	color: var(--fs-dunkelgrau);
	margin-bottom: 8px;
	font-size: 18px;
	font-weight: 300;
	line-height: 1.3;
}

.fs-kontakt-form input,
.fs-kontakt-form textarea,
.fs-kontakt-form select {
	width: 100%;
	border: 0;
	border-bottom: 1px solid #707070;
	background: transparent;
	color: var(--fs-dunkelgrau);
	font: inherit;
	font-size: 18px;
	font-weight: 300;
	line-height: 1.3;
	padding: 0 0 8px;
	border-radius: 0;
}

.fs-kontakt-form select {
	padding-right: 24px;
	background-image: linear-gradient(45deg, transparent 50%, #707070 50%), linear-gradient(135deg, #707070 50%, transparent 50%);
	background-position: calc(100% - 15px) calc(50% - 1px), calc(100% - 10px) calc(50% - 1px);
	background-size: 5px 5px, 5px 5px;
	background-repeat: no-repeat;
	appearance: none;
}

.fs-kontakt-form textarea {
	border: 1px solid #a8a8a8;
	padding: 12px;
	min-height: 100px;
	resize: vertical;
}

.fs-form-field--textarea {
	margin-top: 20px;
}

.fs-kontakt-form input:focus,
.fs-kontakt-form textarea:focus,
.fs-kontakt-form select:focus {
	outline: none;
	border-color: var(--fs-dunkelgrau);
}

.fs-kontakt-form__consent-row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
	margin-top: 24px;
}

.fs-kontakt-form__consent {
	display: inline-flex;
	align-items: flex-start;
	gap: 12px;
	max-width: 72%;
	color: var(--fs-dunkelgrau);
	cursor: pointer;
}

.fs-kontakt-form__consent input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.fs-kontakt-form__consent-indicator {
	width: 26px;
	height: 26px;
	border: 1px solid #707070;
	border-radius: 50%;
	flex: 0 0 26px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 2px;
}

.fs-kontakt-form__consent input:checked + .fs-kontakt-form__consent-indicator::after {
	content: '';
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--fs-dunkelgrau);
}

.fs-form-consent-text {
	margin-left: 0;
	font-size: 10px;
	font-weight: 300;
	line-height: 1.36;
}

.fs-kontakt-submit {
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	background: transparent;
	color: var(--fs-dunkelgrau);
	border: 1px solid var(--fs-dunkelgrau);
	border-radius: 20px;
	padding: 5px 24px;
	font-size: 16px;
	font-weight: 300;
	line-height: 1.2;
	cursor: pointer;
	transition: var(--fs-transition);
	text-decoration: none;
}

.fs-kontakt-submit:hover {
	background: var(--fs-dunkelgrau);
	color: var(--fs-weiss);
}

.fs-kontakt-submit--primary {
	background: linear-gradient(180deg, #e30613 0%, #9f0009 100%);
	border-color: #e30613;
	color: #fff;
	min-width: 186px;
}

.fs-kontakt-submit--primary:hover {
	filter: brightness(1.05);
	background: linear-gradient(180deg, #e30613 0%, #9f0009 100%);
	color: #fff;
}

.fs-kontakt-submit--ghost {
	min-width: 120px;
}

.fs-kontakt-form__grid--quickapply {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.fs-form-field--upload {
	margin-top: 20px;
}

.fs-form-field--upload input[type="file"] {
	padding: 6px 0;
	border-bottom: 1px solid #a8a8a8;
}

.fs-form-field--captcha {
	max-width: 220px;
	margin-top: 12px;
}

.fs-kontakt-form__consent-row--quickapply {
	align-items: center;
}

.fs-quick-application__actions {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.fs-footer-company {
	display: flex;
	align-items: center;
	gap: 20px;
}

.fs-footer-logo {
	margin: 0 !important;
}

.fs-footer-address p {
	margin: 0;
	line-height: 1.36;
}

.fs-social-icons {
	margin: 0 !important;
	display: flex;
	align-items: center;
	gap: 10px;
}

.fs-social-icons__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 25px;
	height: 25px;
	color: var(--fs-dunkelgrau);
	transition: transform var(--fs-transition), color var(--fs-transition);
}

.fs-social-icons__link svg {
	display: block;
	width: 100%;
	height: 100%;
	fill: currentColor;
}

.fs-social-icons__link:hover {
	color: var(--fs-rot);
	transform: scale(1.08);
}

.fs-footer-meta {
	align-items: flex-end;
	row-gap: 16px;
}

.fs-footer-menu {
	background: transparent;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0;
}

.fs-footer-menu a + a::before {
	content: '·';
	margin: 0 8px;
	color: var(--fs-dunkelgrau);
}

.fs-footer-menu a {
	color: var(--fs-dunkelgrau);
	text-decoration: none;
	transition: color var(--fs-transition);
	font-size: 24px;
	font-weight: 300;
	line-height: 1.3;
}

.fs-footer-menu a:hover {
	color: var(--fs-rot);
}


/* ==========================================================================
   12. Button Styles
   ========================================================================== */

/* Section Label (Red small heading above each section) */
.fs-section-label {
	font-family: var(--fs-font-open);
	font-size: var(--fs-size-md) !important;
	font-weight: var(--fs-weight-bold) !important;
	color: var(--fs-rot) !important;
	margin-bottom: var(--fs-heading-gap);
	text-transform: none;
	letter-spacing: 0;
}

/* Section Heading (Large Azo Sans headings) */
.fs-section-heading {
	font-family: var(--fs-font-azo) !important;
	font-size: var(--fs-size-heading) !important;
	font-weight: var(--fs-weight-medium) !important;
	line-height: 1.33 !important;
	color: var(--fs-dunkelgrau) !important;
}

/* Section Description */
.fs-section-desc {
	font-size: var(--fs-size-md);
	font-weight: var(--fs-weight-regular);
	color: var(--fs-dunkelgrau);
	line-height: 1.36;
}

/* Button: With Arrow */
.is-style-fs-with-arrow .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: transparent;
	color: var(--fs-dunkelgrau);
	border: 1px solid var(--fs-dunkelgrau);
	border-radius: 20px;
	padding: 5px 24px;
	font-size: var(--fs-size-sm);
	font-weight: var(--fs-weight-light);
	transition: var(--fs-transition);
	text-decoration: none;
}

.is-style-fs-with-arrow .wp-block-button__link::after {
	content: '→';
	font-size: 14px;
	transition: transform var(--fs-transition);
}

.is-style-fs-with-arrow .wp-block-button__link:hover {
	background: var(--fs-dunkelgrau);
	color: var(--fs-weiss);
}

.is-style-fs-with-arrow .wp-block-button__link:hover::after {
	transform: translateX(4px);
}

/* Button: Outline Red */
.is-style-fs-outline-red .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: transparent;
	color: var(--fs-rot);
	border: 1px solid var(--fs-rot);
	border-radius: 20px;
	padding: 5px 24px;
	font-size: var(--fs-size-sm);
	font-weight: var(--fs-weight-light);
	transition: var(--fs-transition);
	text-decoration: none;
}

.is-style-fs-outline-red .wp-block-button__link::before {
	content: '';
	display: inline-block;
	width: 20px;
	height: 19px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 19'%3E%3Cpath d='M2 2h16v15H2z' fill='none' stroke='%23E30613' stroke-width='1.5'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
}

.is-style-fs-outline-red .wp-block-button__link:hover {
	background: var(--fs-rot);
	color: var(--fs-weiss);
}

/* Button: Outline Dark */
.is-style-fs-outline-dark .wp-block-button__link {
	background: transparent;
	color: var(--fs-dunkelgrau);
	border: 1px solid var(--fs-dunkelgrau);
	border-radius: 20px;
	padding: 5px 24px;
	transition: var(--fs-transition);
	text-decoration: none;
}

.is-style-fs-outline-dark .wp-block-button__link:hover {
	background: var(--fs-dunkelgrau);
	color: var(--fs-weiss);
}


/* ==========================================================================
   13. Utilities & Animations
   ========================================================================== */

/* Slider Dots */
.fs-slider-dots {
	display: flex;
	gap: 12px;
	justify-content: center;
}

.fs-dot {
	width: 21px;
	height: 21px;
	border-radius: 50%;
	border: 2px solid #A8A8A8;
	background: transparent;
	cursor: pointer;
	font-size: 0;
	transition: var(--fs-transition);
}

.fs-dot--active {
	border-color: var(--fs-rot);
	background: var(--fs-rot);
}

/* Fade-in animation for sections */
@keyframes fs-fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.fs-animate {
	opacity: 0;
}

.fs-animate--visible {
	animation: fs-fadeInUp 0.6s ease forwards;
}

/* Screen Reader Text */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}


/* ==========================================================================
   Responsive Breakpoints
   ========================================================================== */

@media (max-width: 1440px) {
	.fs-footer-kontakt__columns {
		padding-left: 140px !important;
		padding-right: 140px !important;
	}

	.fs-footer-kontakt__bottom {
		padding-left: 140px !important;
		padding-right: 140px !important;
	}

	.fs-branchenuebersicht__header,
	.fs-branchenuebersicht__grid {
		padding-left: 140px !important;
		padding-right: 140px !important;
	}
}

@media (max-width: 1200px) {
	.fs-produktkatalog__content {
		gap: 48px;
	}

	.fs-produktkatalog__intro {
		flex-basis: 48%;
		max-width: 48%;
	}

	.fs-produktkatalog__slider {
		flex-basis: 52%;
		max-width: 52%;
	}

	.fs-produktkatalog__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-template-rows: auto;
		column-gap: 24px;
	}

	.fs-produkt-card {
		width: 100%;
		height: 340px;
	}

	.fs-branchenuebersicht__grid {
		grid-template-columns: repeat(4, 1fr) !important;
	}

	.fs-kompetenz-slider__track {
		grid-template-columns: repeat(2, 310px);
		row-gap: 24px;
	}

	.fs-slider-arrow {
		display: none;
	}
}

@media (max-width: 992px) {
	:root {
		--fs-section-padding: 60px;
		--fs-size-heading: 32px;
		--fs-size-teaser: 28px;
	}

	.fs-solutions-mega {
		display: none !important;
	}

	.fs-competences-mega {
		display: none !important;
	}

	.fs-company-mega {
		display: none !important;
	}

	.fs-header__inner {
		padding-left: 24px !important;
		padding-right: 24px !important;
	}

	.fs-header__actions {
		display: none !important;
	}

	.fs-header__utility,
	.fs-header__cta {
		position: static;
	}

	.fs-main-nav .wp-block-navigation__responsive-container-open {
		display: inline-flex !important;
		align-items: center;
		justify-content: center;
		width: 34px;
		height: 34px;
		padding: 0;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open {
		background: var(--fs-weiss) !important;
		color: var(--fs-dunkelgrau) !important;
		padding: 24px 22px 36px !important;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
		margin: 0;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
		top: 0;
		right: 0;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
		padding-top: 54px !important;
		align-items: stretch !important;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
		width: 100%;
		gap: 0 !important;
		align-items: stretch !important;
		justify-content: flex-start !important;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item {
		width: 100%;
		margin: 0;
		display: block;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
		padding: 0;
		display: block;
		width: 100%;
		text-align: left;
		line-height: 1.35;
	}

	.fs-main-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item:not(.fs-mobile-has-children) > .wp-block-navigation-item__content {
		padding: 10px 0;
	}

	.fs-mobile-nav-row,
	.fs-mobile-submenu-row {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		width: 100%;
	}

	.fs-mobile-nav-row {
		padding: 10px 0;
	}

	.fs-mobile-nav-row > .wp-block-navigation-item__content {
		flex: 1 1 auto;
		min-width: 0;
	}

	.fs-mobile-nav-toggle {
		flex: 0 0 30px;
		width: 30px;
		height: 30px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: var(--fs-dunkelgrau);
		cursor: pointer;
	}

	.fs-mobile-nav-toggle__icon {
		display: block;
		width: 9px;
		height: 9px;
		border-right: 1.8px solid currentColor;
		border-bottom: 1.8px solid currentColor;
		transform: rotate(45deg);
		transform-origin: 50% 50%;
		transition: transform 0.2s ease;
	}

	.fs-mobile-nav-toggle[aria-expanded="true"] .fs-mobile-nav-toggle__icon {
		transform: rotate(-135deg);
	}

	.fs-mobile-nav-submenu {
		list-style: none;
		margin: 0;
		padding: 2px 0 8px;
	}

	.fs-mobile-nav-submenu[hidden] {
		display: none !important;
	}

	.fs-mobile-submenu-item {
		width: 100%;
		margin: 0;
	}

	.fs-mobile-nav-submenu--level-1 > .fs-mobile-submenu-item > .fs-mobile-submenu-row {
		padding: 7px 0 7px 16px;
	}

	.fs-mobile-nav-submenu--level-2 > .fs-mobile-submenu-item > .fs-mobile-submenu-row {
		padding: 6px 0 6px 30px;
	}

	.fs-mobile-nav-submenu--level-3 > .fs-mobile-submenu-item > .fs-mobile-submenu-row {
		padding: 5px 0 5px 44px;
	}

	.fs-mobile-submenu-link {
		flex: 1 1 auto;
		min-width: 0;
		color: var(--fs-dunkelgrau);
		font-size: 18px;
		line-height: 1.35;
		text-decoration: none;
	}

	.fs-mobile-submenu-link:hover {
		color: var(--fs-rot);
	}

	.fs-search-panel {
		top: 40px;
		right: 50%;
	}

	.fs-text-bild__columns {
		flex-direction: column !important;
	}

	.fs-text-bild__text {
		padding-right: 0 !important;
		margin-bottom: 40px;
	}

	.fs-branchenuebersicht__grid {
		grid-template-columns: repeat(3, 1fr) !important;
	}

	.fs-footer-kontakt__columns {
		flex-direction: column !important;
		padding-left: 24px !important;
		padding-right: 24px !important;
	}

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

	.fs-kontakt-form__grid--quickapply {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.fs-form-field--span-2 {
		grid-column: 1 / -1;
	}

	.fs-kompetenz-slider__header {
		max-width: 100%;
		padding-left: 24px;
		padding-right: 24px;
	}

	.fs-kompetenz-slider__track {
		grid-template-columns: repeat(2, minmax(260px, 1fr));
		padding: 0 24px;
		gap: 16px;
	}

	.fs-search-results__loop {
		grid-template-columns: 1fr;
	}

	.fs-search-result-card__columns {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}

@media (max-width: 768px) {
	.fs-hero-slide__cover {
		min-height: 500px;
	}

	.fs-hero-slider__viewport {
		width: 100%;
	}

	.fs-hero-slide__content {
		padding-left: 24px !important;
		padding-bottom: 120px !important;
	}

	.fs-search-panel {
		right: 50%;
		width: min(520px, calc(100vw - 32px));
	}

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

	.fs-hero-title {
		font-size: 28px !important;
	}

	.fs-hero-branchen-overlay {
		display: none;
	}

	.fs-produktkatalog__content {
		flex-direction: column !important;
		gap: 40px;
	}

	.fs-produktkatalog__intro,
	.fs-produktkatalog__slider {
		flex: 1 1 auto;
		max-width: 100%;
	}

	.fs-produktkatalog__grid {
		grid-template-columns: 1fr;
		row-gap: 16px;
	}

	.fs-produkt-card {
		height: auto;
		min-height: 280px;
	}

	.fs-produkt-card__image {
		height: 190px;
		padding-top: 24px;
	}

	.fs-produkt-card__label {
		padding: 16px 20px 20px;
	}

	.fs-kompetenz-slider__track {
		display: flex !important;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		padding: 0 24px 8px;
		gap: 16px;
	}

	.fs-kompetenz-element {
		flex: 0 0 85vw;
		width: 85vw;
		min-height: 320px;
		scroll-snap-align: start;
		padding: 28px 24px;
	}

	.fs-branchenuebersicht__grid {
		grid-template-columns: repeat(2, 1fr) !important;
		padding-left: 24px !important;
		padding-right: 24px !important;
	}

	.fs-branchenuebersicht__header {
		padding-left: 24px !important;
		padding-right: 24px !important;
	}

	.fs-referenzen__cards {
		flex-direction: column !important;
	}

	.fs-footer-kontakt__bottom {
		flex-direction: column !important;
		gap: 24px;
		padding-left: 24px !important;
		padding-right: 24px !important;
	}

	.fs-kontakt-form__grid {
		grid-template-columns: 1fr;
		row-gap: 14px;
	}

	.fs-kontakt-form__grid--quickapply {
		grid-template-columns: 1fr;
	}

	.fs-kontakt-form__consent-row {
		flex-direction: column;
		gap: 16px;
	}

	.fs-kontakt-form__consent {
		max-width: 100%;
	}

	.fs-quick-application__actions {
		width: 100%;
		flex-wrap: wrap;
	}

	.fs-footer-meta {
		align-items: flex-start;
	}

	.fs-footer-menu {
		justify-content: flex-start;
	}

	.fs-footer-menu a {
		font-size: 18px;
	}
}

@media (max-width: 480px) {
	.fs-branchenuebersicht__grid {
		grid-template-columns: 1fr !important;
	}

	.fs-kompetenz-element {
		flex: 0 0 85vw;
	}

	.fs-teaser-text__content {
		font-size: 24px !important;
	}
}

/* ============================================================
   Über uns (Hero + Sections)
   ============================================================ */

.fs-about-hero {
	background: linear-gradient(180deg, var(--fs-hellgrau) 0%, var(--fs-hellgrau) 58%, var(--fs-weiss) 58%, var(--fs-weiss) 100%);
	padding-bottom: 0 !important;
}

.fs-about-hero__inner {
	max-width: min(100%, var(--wp--style--global--content-size, 1364px)) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-about-hero__heading {
	max-width: 550px !important;
	margin-left: 0 !important;
	margin-right: auto !important;
}

.fs-about-hero__image {
	margin-left: 0 !important;
	margin-right: auto !important;
}

.fs-about-hero__image img {
	display: block;
	width: 100%;
	height: auto;
}

.fs-about-hero__breadcrumb {
	max-width: 209px;
	margin-left: 0 !important;
	margin-right: auto !important;
}

.fs-about-intro-centered__text {
	max-width: 798px;
	font-size: 35px !important;
	line-height: 1.36181640625 !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-about-2col__columns {
	align-items: stretch !important;
	justify-content: space-between;
	gap: 0 !important;
	margin-bottom: 0 !important;
	min-height: 707px;
}

.fs-about-2col__left,
.fs-about-2col__right {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-about-2col__right {
	justify-content: stretch;
}

.fs-about-2col__image {
	margin: 0;
	width: 100%;
	height: 707px;
}

.fs-about-boxed__image {
	margin: 0;
	width: 100%;
	height: auto;
}

.fs-about-2col__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.fs-about-boxed__image img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.fs-about-boxed {
	background: var(--fs-hellgrau);
}

.fs-about-boxed__card {
	box-shadow: var(--fs-shadow-card);
	min-height: 606.52px;
}

.fs-about-boxed__columns {
	align-items: center !important;
	justify-content: space-between;
	gap: 0 !important;
	margin-bottom: 0 !important;
}

.fs-about-boxed__image-col,
.fs-about-boxed__text-col {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-about-boxed__text-col {
	justify-content: center;
}

.fs-about-project-cta__card {
	box-shadow: var(--fs-shadow-card);
	min-height: 296.36px;
	width: 100%;
	max-width: 1112px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-about-project-cta__text {
	max-width: 664px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-about-project-cta__button .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	color: var(--fs-rot);
	border: 1px solid var(--fs-rot);
	border-radius: 20px;
	padding: 5px 24px;
	font-size: var(--fs-size-sm);
	font-weight: var(--fs-weight-light);
	text-decoration: none;
	transition: var(--fs-transition);
}

.fs-about-project-cta__button .wp-block-button__link::before,
.fs-about-project-cta__button .wp-block-button__link::after {
	content: none;
}

.fs-about-project-cta__button .wp-block-button__link:hover {
	background: var(--fs-rot);
	color: var(--fs-weiss);
}

@media (max-width: 1200px) {
	.fs-about-hero__title {
		font-size: 42px !important;
	}

	.fs-about-hero__subline {
		font-size: 30px !important;
	}
}

@media (max-width: 980px) {
	.fs-about-hero {
		background: var(--fs-hellgrau);
	}

	.fs-about-hero__title {
		font-size: 34px !important;
		line-height: 1.25 !important;
	}

	.fs-about-hero__subline {
		font-size: 26px !important;
	}

	.fs-about-intro-centered__text {
		font-size: 27px !important;
	}

	.fs-about-2col__columns,
	.fs-about-boxed__columns {
		flex-direction: column !important;
		gap: 30px !important;
	}

	.fs-about-2col__left,
	.fs-about-2col__right,
	.fs-about-boxed__image-col,
	.fs-about-boxed__text-col {
		flex-basis: 100% !important;
		width: 100%;
	}

	/* Mobile requirement: image is always above text for this alternating layout variant. */
	.fs-about-2col-text-image .fs-about-2col__left {
		order: 2;
	}

	.fs-about-2col-text-image .fs-about-2col__right {
		order: 1;
	}

	/* Mobile requirement: boxed about variants should also always show image first. */
	.fs-about-boxed .fs-about-boxed__image-col {
		order: 1;
	}

	.fs-about-boxed .fs-about-boxed__text-col {
		order: 2;
	}

	.fs-about-2col__image,
	.fs-about-boxed__image {
		height: auto;
	}

	.fs-about-2col__image img,
	.fs-about-boxed__image img {
		height: auto;
	}

	.fs-about-boxed__card {
		padding-top: 32px !important;
		padding-right: 24px !important;
		padding-bottom: 32px !important;
		padding-left: 24px !important;
	}

	.fs-about-project-cta__card {
		padding-left: 24px !important;
		padding-right: 24px !important;
	}
}

@media (max-width: 640px) {
	.fs-about-hero__title {
		font-size: 30px !important;
	}

	.fs-about-hero__subline {
		font-size: 24px !important;
	}

	.fs-about-intro-centered__text {
		font-size: 24px !important;
	}
}

/* ============================================================
   2-spaltig Patterns (zweispaltig-*)
   ============================================================ */

.fs-zweispaltig-kasten-rot-weiss-a__columns,
.fs-zweispaltig-kasten-rot-weiss-b__columns,
.fs-zweispaltig-headline-text-list__columns,
.fs-zweispaltig-garner-kasten__columns,
.fs-zweispaltig-subhead-text-bild__columns,
.fs-zweispaltig-subhead-text-button-bild-gross__columns,
.fs-zweispaltig-grauer-kasten-vollbreite__columns,
.fs-zweispaltig-referenzen__columns,
.fs-zweispaltig-media-zentriert__columns {
	align-items: stretch !important;
}

.fs-zweispaltig-kasten-rot-weiss-a__left,
.fs-zweispaltig-kasten-rot-weiss-a__right,
.fs-zweispaltig-kasten-rot-weiss-b__left,
.fs-zweispaltig-kasten-rot-weiss-b__right,
.fs-zweispaltig-headline-text-list__left,
.fs-zweispaltig-headline-text-list__right,
.fs-zweispaltig-garner-kasten__left,
.fs-zweispaltig-garner-kasten__right,
.fs-zweispaltig-subhead-text-bild__left,
.fs-zweispaltig-subhead-text-bild__right,
.fs-zweispaltig-subhead-text-button-bild-gross__left,
.fs-zweispaltig-subhead-text-button-bild-gross__right,
.fs-zweispaltig-grauer-kasten-vollbreite__left,
.fs-zweispaltig-grauer-kasten-vollbreite__right,
.fs-zweispaltig-referenzen__column,
.fs-zweispaltig-media-zentriert__left,
.fs-zweispaltig-media-zentriert__right {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-zweispaltig-kasten-rot-weiss-a__left-box,
.fs-zweispaltig-kasten-rot-weiss-a__right-box,
.fs-zweispaltig-kasten-rot-weiss-b__left-box,
.fs-zweispaltig-kasten-rot-weiss-b__right-box,
.fs-zweispaltig-garner-kasten__panel,
.fs-zweispaltig-subhead-text-button-bild-gross__content,
.fs-zweispaltig-grauer-kasten-vollbreite__panel,
.fs-zweispaltig-headline-text-list__list {
	width: 100%;
	height: 100%;
}

.fs-zweispaltig-kasten-rot-weiss-a__left,
.fs-zweispaltig-kasten-rot-weiss-a__right {
	align-items: center;
}

.fs-zweispaltig-kasten-rot-weiss-a__left-box,
.fs-zweispaltig-kasten-rot-weiss-a__right-box {
	max-width: 92%;
	margin: 0 auto;
}

.fs-zweispaltig-kasten-rot-weiss-a__h3-bold {
	font-family: var(--fs-font-azo) !important;
	font-size: 53px !important;
	font-weight: 700 !important;
	line-height: 1.14 !important;
	letter-spacing: 0;
	color: #FFFFFF !important;
}

.fs-zweispaltig-kasten-rot-weiss-a__h3-light {
	font-family: var(--fs-font-azo) !important;
	font-size: 53px !important;
	font-weight: 300 !important;
	line-height: 1.14 !important;
	letter-spacing: 0;
	color: #FFFFFF !important;
}

.fs-zweispaltig-kasten-rot-weiss-a__list,
.fs-zweispaltig-kasten-rot-weiss-b__list,
.fs-zweispaltig-headline-text-list__list {
	list-style: none;
	padding-left: 0;
	margin-top: 0;
	margin-bottom: 0;
}

.fs-zweispaltig-kasten-rot-weiss-a__list li,
.fs-zweispaltig-kasten-rot-weiss-b__list li,
.fs-zweispaltig-headline-text-list__list li {
	position: relative;
	padding-left: 26px;
	margin-bottom: 12px;
}

.fs-zweispaltig-kasten-rot-weiss-a__list li:last-child,
.fs-zweispaltig-kasten-rot-weiss-b__list li:last-child,
.fs-zweispaltig-headline-text-list__list li:last-child {
	margin-bottom: 0;
}

.fs-zweispaltig-kasten-rot-weiss-a__list li::before,
.fs-zweispaltig-kasten-rot-weiss-b__list li::before,
.fs-zweispaltig-headline-text-list__list li::before {
	content: "✓";
	color: var(--fs-rot);
	position: absolute;
	left: 0;
	top: 0;
	font-weight: 700;
	line-height: 1.36;
}

.fs-zweispaltig-kasten-rot-weiss-b__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px 26px;
	align-items: start;
}

.fs-zweispaltig-kasten-rot-weiss-b__grid-item {
	display: flex;
	flex-direction: column;
	align-items: flex-start !important;
	gap: 14px;
	min-height: 118px;
	justify-content: flex-start;
	text-align: left;
}

.fs-zweispaltig-kasten-rot-weiss-b__grid-item .fs-zweispaltig-kasten-rot-weiss-b__grid-text {
	margin: 0 !important;
}

.fs-zweispaltig-kasten-rot-weiss-b__icon-image {
	margin: 0;
	flex: 0 0 38px;
	width: 38px;
	height: 38px;
	border: 1px solid rgba(255, 255, 255, 0.8);
	border-radius: 50%;
	padding: 7px;
	display: flex;
	align-items: center;
	justify-content: center;
	align-self: flex-start;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.fs-zweispaltig-kasten-rot-weiss-b__icon-image img {
	width: 22px;
	height: 22px;
	display: block;
	object-fit: contain;
}

.fs-zweispaltig-kasten-rot-weiss-b__grid-text {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	flex: 0 0 auto;
	max-width: 190px;
	text-align: left;
	color: #FFFFFF;
}

.fs-zweispaltig-garner-kasten__image,
.fs-zweispaltig-subhead-text-bild__image,
.fs-zweispaltig-subhead-text-button-bild-gross__image,
.fs-zweispaltig-grauer-kasten-vollbreite__image {
	margin: 0;
	width: 100%;
	height: 100%;
}

.fs-zweispaltig-garner-kasten__image img,
.fs-zweispaltig-subhead-text-bild__image img,
.fs-zweispaltig-subhead-text-button-bild-gross__image img,
.fs-zweispaltig-grauer-kasten-vollbreite__image img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.fs-zweispaltig-referenzen__card {
	width: 100%;
	height: auto;
	display: flex;
	flex-direction: column;
	box-shadow: var(--fs-shadow-card);
	background: var(--fs-weiss);
}

.fs-zweispaltig-referenzen__image {
	margin: 0;
}

.fs-zweispaltig-referenzen__image img {
	width: 100%;
	height: auto;
	display: block;
}

.fs-zweispaltig-referenzen__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start !important;
	width: 100% !important;
	max-width: 100% !important;
	padding: 28px 28px 32px 22px;
	text-align: left !important;
}

.fs-zweispaltig-referenzen__content > * {
	align-self: flex-start !important;
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	max-width: none !important;
	text-align: left !important;
}

.fs-zweispaltig-referenzen__content.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	margin-left: 0 !important;
	margin-right: 0 !important;
	max-width: none !important;
}

.fs-zweispaltig-referenzen__content .fs-zweispaltig-referenzen__right-headline,
.fs-zweispaltig-referenzen__content .fs-zweispaltig-referenzen__description {
	text-align: left !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.fs-zweispaltig-referenzen__content .wp-block-buttons {
	width: auto !important;
	justify-content: flex-start !important;
	text-align: left !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.fs-zweispaltig-referenzen__content .has-text-align-center {
	text-align: left !important;
}

.fs-zweispaltig-referenzen__content .wp-block-buttons.is-content-justification-center {
	justify-content: flex-start !important;
}

.fs-zweispaltig-referenzen__content .wp-block-buttons .wp-block-button {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.fs-zweispaltig-referenzen__columns {
	gap: 34px !important;
	align-items: stretch !important;
}

.fs-zweispaltig-headline-text-list .wp-block-button__link,
.fs-zweispaltig-referenzen .wp-block-button__link {
	white-space: nowrap;
}

.fs-zweispaltig-referenzen__left-top-title {
	margin-top: 0;
}

.fs-zweispaltig-referenzen__left-card .fs-zweispaltig-referenzen__content {
	padding-top: 28px;
}

.fs-zweispaltig-referenzen__right-headline {
	color: var(--fs-rot) !important;
}

.fs-zweispaltig-referenzen__left-h4 {
	color: var(--fs-rot) !important;
}

.fs-zweispaltig-referenzen .is-style-fs-with-arrow .wp-block-button__link {
	border: 1px solid var(--fs-dunkelgrau) !important;
	border-radius: 20px !important;
	background: transparent !important;
	color: var(--fs-dunkelgrau) !important;
	padding: 5px 22px !important;
	text-decoration: none !important;
}

.fs-zweispaltig-referenzen .is-style-fs-with-arrow .wp-block-button__link::after {
	content: none !important;
	display: none !important;
}

.fs-zweispaltig-kasten-rot-weiss-b__left-box,
.fs-zweispaltig-kasten-rot-weiss-b__right-box {
	height: auto;
}

.fs-zweispaltig-kasten-rot-weiss-b__right {
	padding-top: 45px;
}

.fs-zweispaltig-referenzen__column--right {
	padding-top: 37px;
}

.fs-zweispaltig-media-zentriert__intro {
	max-width: 40%;
}

.fs-zweispaltig-media-zentriert__content {
	width: 100%;
}

.fs-zweispaltig-media-zentriert__media-wrap {
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: auto;
}

.fs-zweispaltig-media-zentriert__media {
	margin: 0 auto;
	max-width: 1139px;
	width: 100%;
}

.fs-zweispaltig-media-zentriert__media img {
	display: block;
	width: 100%;
	height: auto;
	margin: 0 auto;
}

@media (max-width: 980px) {
	.fs-zweispaltig-kasten-rot-weiss-a__columns,
	.fs-zweispaltig-kasten-rot-weiss-b__columns,
	.fs-zweispaltig-headline-text-list__columns,
	.fs-zweispaltig-garner-kasten__columns,
	.fs-zweispaltig-subhead-text-bild__columns,
	.fs-zweispaltig-subhead-text-button-bild-gross__columns,
	.fs-zweispaltig-grauer-kasten-vollbreite__columns,
	.fs-zweispaltig-referenzen__columns,
	.fs-zweispaltig-media-zentriert__columns {
		flex-direction: column !important;
	}

	.fs-zweispaltig-garner-kasten__image,
	.fs-zweispaltig-subhead-text-bild__image,
	.fs-zweispaltig-subhead-text-button-bild-gross__image,
	.fs-zweispaltig-grauer-kasten-vollbreite__image {
		height: auto;
	}

	.fs-zweispaltig-garner-kasten__image img,
	.fs-zweispaltig-subhead-text-bild__image img,
	.fs-zweispaltig-subhead-text-button-bild-gross__image img,
	.fs-zweispaltig-grauer-kasten-vollbreite__image img {
		height: auto;
		object-fit: contain;
	}

	.fs-zweispaltig-kasten-rot-weiss-a__left-box,
	.fs-zweispaltig-kasten-rot-weiss-a__right-box {
		max-width: 100%;
	}

	.fs-zweispaltig-kasten-rot-weiss-b__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 18px;
	}

	.fs-zweispaltig-kasten-rot-weiss-b__right,
	.fs-zweispaltig-referenzen__column--right {
		padding-top: 0;
	}

	.fs-zweispaltig-media-zentriert__intro {
		max-width: 100%;
	}
}

@media (max-width: 640px) {
	.fs-zweispaltig-kasten-rot-weiss-b__grid {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   3-spaltig Patterns (dreispaltig-*)
   ============================================================ */

.fs-dreispaltig-text-33__columns,
.fs-dreispaltig-text-1-2__columns,
.fs-dreispaltig-text-2-1__columns {
	align-items: stretch !important;
}

.fs-dreispaltig-text-33__column,
.fs-dreispaltig-text-1-2__left,
.fs-dreispaltig-text-1-2__right,
.fs-dreispaltig-text-2-1__left,
.fs-dreispaltig-text-2-1__right {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-dreispaltig-text-33__headline-box,
.fs-dreispaltig-text-1-2__headline-box,
.fs-dreispaltig-text-2-1__headline-box {
	min-height: 72px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.fs-dreispaltig-text-33__body-box,
.fs-dreispaltig-text-1-2__body-box,
.fs-dreispaltig-text-2-1__body-box {
	min-height: 340px;
}

.fs-dreispaltig-intro-cards__columns {
	align-items: stretch !important;
	column-gap: 32px !important;
	row-gap: 32px !important;
}

.fs-dreispaltig-intro-cards__intro,
.fs-dreispaltig-intro-cards__card-col {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-dreispaltig-intro-cards__card-col {
	gap: 32px;
}

.fs-dreispaltig-intro-cards__card {
	display: flex;
	flex-direction: column;
	min-height: 359px;
	width: 100%;
}

.fs-dreispaltig-intro-cards__image {
	margin: 0;
	min-height: 230px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-dreispaltig-intro-cards__image img {
	width: 100%;
	max-height: 230px;
	height: 100%;
	object-fit: contain;
	display: block;
}

.fs-dreispaltig-intro-cards__caption {
	margin-top: auto !important;
}

@media (max-width: 1200px) {
	.fs-dreispaltig-intro-cards__image {
		min-height: 200px;
	}

	.fs-dreispaltig-intro-cards__image img {
		max-height: 200px;
	}
}

@media (max-width: 980px) {
	.fs-dreispaltig-text-33__columns,
	.fs-dreispaltig-text-1-2__columns,
	.fs-dreispaltig-text-2-1__columns,
	.fs-dreispaltig-intro-cards__columns {
		flex-direction: column !important;
	}

	.fs-dreispaltig-text-33__body-box,
	.fs-dreispaltig-text-1-2__body-box,
	.fs-dreispaltig-text-2-1__body-box {
		min-height: 0;
	}

	.fs-dreispaltig-intro-cards__card-col {
		gap: 20px;
	}

	.fs-dreispaltig-intro-cards__card {
		min-height: 0;
	}
}

/* ============================================================
   4-spaltig Patterns (vierspaltig-*)
   ============================================================ */

.fs-vierspaltig-graukachel-subhead__columns,
.fs-vierspaltig-intro-icon-kacheln__columns,
.fs-vierspaltig-rotkachel-mix__columns,
.fs-vierspaltig-karriere-rot__columns,
.fs-vierspaltig-produkthighlights__columns {
	align-items: stretch !important;
}

.fs-vierspaltig-graukachel-subhead__column,
.fs-vierspaltig-intro-icon-kacheln__column,
.fs-vierspaltig-rotkachel-mix__column,
.fs-vierspaltig-karriere-rot__column,
.fs-vierspaltig-produkthighlights__column {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

/* 4-spaltig: Intro + graue Kachel */
.fs-vierspaltig-graukachel-subhead__columns {
	gap: 28px !important;
	border: 0;
}

.fs-vierspaltig-graukachel-subhead__column {
	align-items: stretch;
}

.fs-vierspaltig-graukachel-subhead__column + .fs-vierspaltig-graukachel-subhead__column {
	border-left: 0;
}

.fs-vierspaltig-graukachel-subhead__intro-wrap {
	width: 100%;
	max-width: 100%;
	margin-left: 0 !important;
	margin-right: auto !important;
	text-align: left;
}

.fs-vierspaltig-graukachel-subhead__tile {
	min-height: 300px;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	height: 100%;
}

/* 4-spaltig: Intro + Icon-Kacheln */
.fs-vierspaltig-intro-icon-kacheln__columns {
	gap: 36px !important;
	border: 0;
}

.fs-vierspaltig-intro-icon-kacheln__column + .fs-vierspaltig-intro-icon-kacheln__column {
	border-left: 0;
}

.fs-vierspaltig-intro-icon-kacheln__column {
	align-items: flex-start;
}

.fs-vierspaltig-intro-icon-kacheln__intro-wrap {
	width: 100%;
	max-width: 100%;
	margin-left: 0 !important;
	margin-right: auto !important;
	text-align: left;
}

.fs-vierspaltig-intro-icon-kacheln__lead-tile {
	width: min(100%, 170px);
	min-height: 170px;
	aspect-ratio: 1 / 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.fs-vierspaltig-intro-icon-kacheln__tile {
	width: min(100%, 170px);
	min-height: 170px;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-vierspaltig-intro-icon-kacheln__tile-icon {
	margin: 0;
}

.fs-vierspaltig-intro-icon-kacheln__tile-icon img {
	display: block;
	width: 76px;
	height: 76px;
	max-width: 100%;
}

/* 4-spaltig: Headline + Fließtext + rote Kachel */
.fs-vierspaltig-rotkachel-mix__columns {
	gap: 14px !important;
	align-items: stretch !important;
	border: 0;
	background: transparent;
}

.fs-vierspaltig-rotkachel-mix__column + .fs-vierspaltig-rotkachel-mix__column {
	border-left: 0;
}

.fs-vierspaltig-rotkachel-mix__column {
	gap: 14px;
}

.fs-vierspaltig-rotkachel-mix__intro-body {
	width: 100%;
	max-width: 540px;
	line-height: 1.2 !important;
	margin-bottom: 20px !important;
	margin-left: 0 !important;
	margin-right: auto !important;
	text-align: left !important;
}

.fs-vierspaltig-rotkachel-mix > p.fs-vierspaltig-rotkachel-mix__intro-body {
	margin-bottom: 20px !important;
	margin-left: 0 !important;
	margin-right: auto !important;
}

.fs-vierspaltig-rotkachel-mix > p {
	width: 100%;
	max-width: 540px;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	line-height: 1.2 !important;
	margin-left: 0 !important;
	margin-right: auto !important;
	text-align: left !important;
}

.fs-vierspaltig-rotkachel-mix > p + p {
	margin-top: 8px !important;
}

.fs-vierspaltig-rotkachel-mix__neutral-tile,
.fs-vierspaltig-rotkachel-mix__red-tile {
	min-height: 92px;
	margin: 0 !important;
	display: flex;
	align-items: center;
}

.fs-vierspaltig-rotkachel-mix__tile-row {
	width: 100%;
	margin: 0 !important;
	display: flex;
	align-items: center;
	gap: 34px;
	padding-left: 4px;
}

.fs-vierspaltig-rotkachel-mix__neutral-icon {
	margin: 0 !important;
	padding: 6px 12px;
	border-radius: 8px;
	background: #E2E2E2;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.1;
	color: #535353;
}

.fs-vierspaltig-rotkachel-mix__neutral-desc {
	margin: 0 !important;
	padding: 6px 12px;
	border-radius: 8px;
	background: #E2E2E2;
	font-size: 18px;
	line-height: 1.2;
	color: #535353;
}

.fs-vierspaltig-rotkachel-mix__red-icon-wrap {
	width: 36px;
	height: 36px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.9);
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 36px;
}

.fs-vierspaltig-rotkachel-mix__red-icon {
	margin: 0 !important;
}

.fs-vierspaltig-rotkachel-mix__red-icon img {
	display: block;
	width: 18px;
	height: 18px;
}

.fs-vierspaltig-rotkachel-mix__red-label {
	margin: 0 !important;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.2;
	padding-top: 1px;
	padding-left: 10px;
}

/* 4-spaltig: Karriere rot (Verlauf) */
.fs-vierspaltig-karriere-rot__columns {
	gap: 28px !important;
	align-items: stretch !important;
	border: 0;
}

.fs-vierspaltig-karriere-rot__column + .fs-vierspaltig-karriere-rot__column {
	border-left: 0;
}

.fs-vierspaltig-karriere-rot__intro-wrap {
	width: 100%;
	max-width: 100%;
	margin-left: 0 !important;
	margin-right: auto !important;
	text-align: left;
}

.fs-vierspaltig-karriere-rot__card {
	min-height: 300px;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	height: 100%;
	background: linear-gradient(165deg, #E30613 0%, #BE0712 100%) !important;
}

.fs-vierspaltig-karriere-rot__icon-wrap {
	width: 76px;
	height: 76px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.95);
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-vierspaltig-karriere-rot__icon-image {
	margin: 0 !important;
}

.fs-vierspaltig-karriere-rot__icon-image img {
	width: 44px;
	height: 44px;
	display: block;
}

/* 4-spaltig: Produkthighlights */
.fs-vierspaltig-produkthighlights__layout {
	gap: 28px !important;
	align-items: flex-start !important;
}

.fs-vierspaltig-produkthighlights__intro-col,
.fs-vierspaltig-produkthighlights__slider-col {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-vierspaltig-produkthighlights__panel {
	position: relative;
	overflow: visible;
}

.fs-vierspaltig-produkthighlights__intro-col {
	flex: 0 0 calc((100% - 76px) / 4) !important;
}

.fs-vierspaltig-produkthighlights__slider-col {
	flex: 1 1 auto !important;
}

.fs-vierspaltig-produkthighlights__intro-media {
	margin: 0;
	min-height: 220px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-vierspaltig-produkthighlights__intro-image,
.fs-vierspaltig-produkthighlights__product-image {
	margin: 0;
}

.fs-vierspaltig-produkthighlights__intro-image img {
	width: 100%;
	max-height: 190px;
	object-fit: contain;
	display: block;
}

.fs-vierspaltig-produkthighlights__product-media {
	margin: 0;
	min-height: 220px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
}

.fs-vierspaltig-produkthighlights__product-image img {
	width: 100%;
	max-height: 190px;
	object-fit: contain;
	display: block;
}

.fs-vierspaltig-produkthighlights__intro-col .wp-block-buttons {
	margin-top: auto;
}

.fs-vierspaltig-produkthighlights__slider {
	position: relative;
	padding: 0;
}

.fs-vierspaltig-produkthighlights__slider-viewport {
	overflow: hidden;
}

.fs-vierspaltig-produkthighlights__slider-track {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: stretch;
	gap: 24px;
	transform: translateX(0);
	transition: transform 320ms ease;
}

.fs-vierspaltig-produkthighlights__product-card {
	flex: 0 0 calc((100% - 72px) / 4);
	min-width: calc((100% - 72px) / 4);
	display: flex;
	flex-direction: column;
}

.fs-vierspaltig-produkthighlights__product-media {
	width: 100%;
}

.fs-vierspaltig-produkthighlights__product-card--intro .wp-block-buttons {
	margin-top: 0;
}

.fs-vierspaltig-produkthighlights__arrow {
	position: absolute;
	top: 112px;
	transform: translateY(-50%);
	z-index: 8;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 52px;
	border: 0;
	background: transparent;
	color: #A8A8A8;
	font-size: 52px;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	margin: 0;
	transition: color var(--fs-transition), opacity var(--fs-transition);
	user-select: none;
}

.fs-vierspaltig-produkthighlights__arrow:hover {
	color: var(--fs-dunkelgrau);
}

.fs-vierspaltig-produkthighlights__slider:not(.has-overflow) .fs-vierspaltig-produkthighlights__arrow,
.fs-vierspaltig-produkthighlights__arrow.is-disabled {
	opacity: 0.35;
	cursor: default;
	pointer-events: none;
}

.fs-vierspaltig-produkthighlights__arrow--prev {
	left: -58px;
}

.fs-vierspaltig-produkthighlights__arrow--next {
	right: -58px;
}

/* Fallback: if modifier classes get stripped, keep arrows left/right */
.fs-vierspaltig-produkthighlights .fs-vierspaltig-produkthighlights__arrow:first-of-type {
	left: -58px;
	right: auto;
}

.fs-vierspaltig-produkthighlights .fs-vierspaltig-produkthighlights__arrow:last-of-type {
	right: -58px;
	left: auto;
}

@media (max-width: 1200px) {
	.fs-vierspaltig-graukachel-subhead__columns,
	.fs-vierspaltig-intro-icon-kacheln__columns,
	.fs-vierspaltig-rotkachel-mix__columns,
	.fs-vierspaltig-karriere-rot__columns,
	.fs-vierspaltig-produkthighlights__layout {
		flex-wrap: wrap !important;
		gap: 18px !important;
		border: 0;
	}

	.fs-vierspaltig-graukachel-subhead__column,
	.fs-vierspaltig-intro-icon-kacheln__column,
	.fs-vierspaltig-rotkachel-mix__column,
	.fs-vierspaltig-karriere-rot__column,
	.fs-vierspaltig-produkthighlights__column,
	.fs-vierspaltig-produkthighlights__intro-col,
	.fs-vierspaltig-produkthighlights__slider-col {
		flex-basis: calc(50% - 9px) !important;
	}

	.fs-vierspaltig-graukachel-subhead__column + .fs-vierspaltig-graukachel-subhead__column,
	.fs-vierspaltig-intro-icon-kacheln__column + .fs-vierspaltig-intro-icon-kacheln__column,
	.fs-vierspaltig-rotkachel-mix__column + .fs-vierspaltig-rotkachel-mix__column,
	.fs-vierspaltig-karriere-rot__column + .fs-vierspaltig-karriere-rot__column {
		border-left: 0;
	}

	.fs-vierspaltig-intro-icon-kacheln__intro-wrap {
		width: 100%;
	}

	.fs-vierspaltig-rotkachel-mix__column:first-child {
		flex-basis: 100% !important;
	}

	.fs-vierspaltig-rotkachel-mix__column:not(:first-child) {
		flex-basis: calc(50% - 9px) !important;
	}

	.fs-vierspaltig-produkthighlights__layout {
		gap: 20px !important;
	}

	.fs-vierspaltig-produkthighlights__intro-col {
		flex-basis: 100% !important;
	}

	.fs-vierspaltig-produkthighlights__slider-col {
		flex-basis: 100% !important;
	}

	.fs-vierspaltig-produkthighlights__product-card {
		flex: 0 0 calc((100% - 48px) / 3);
		min-width: calc((100% - 48px) / 3);
	}

	.fs-vierspaltig-produkthighlights__arrow--prev {
		left: -32px;
	}

	.fs-vierspaltig-produkthighlights__arrow--next {
		right: -32px;
	}
}

@media (max-width: 980px) {
	.fs-vierspaltig-produkthighlights__product-card {
		flex: 0 0 calc((100% - 24px) / 2);
		min-width: calc((100% - 24px) / 2);
	}
}

@media (max-width: 720px) {
	.fs-vierspaltig-graukachel-subhead__column,
	.fs-vierspaltig-intro-icon-kacheln__column,
	.fs-vierspaltig-rotkachel-mix__column,
	.fs-vierspaltig-karriere-rot__column,
	.fs-vierspaltig-produkthighlights__column,
	.fs-vierspaltig-produkthighlights__intro-col,
	.fs-vierspaltig-produkthighlights__slider-col {
		flex-basis: 100% !important;
	}

	.fs-vierspaltig-produkthighlights__product-card {
		flex: 0 0 100%;
		min-width: 100%;
	}

	.fs-vierspaltig-produkthighlights__arrow {
		display: none !important;
	}
}

/* ============================================================
   5-spaltig Pattern (fuenfspaltig-slider-full)
   ============================================================ */

.fs-fuenfspaltig-slider-full__track {
	align-items: stretch !important;
	gap: 14px !important;
}

.fs-fuenfspaltig-slider-full__media {
	display: flex;
	flex-direction: column;
	min-width: 0;
	flex-basis: calc(20% - 12px) !important;
}

.fs-fuenfspaltig-slider-full__image {
	margin: 0 !important;
	width: 100%;
	height: 100%;
	border-radius: 6px;
	overflow: hidden;
	background: var(--fs-hellgrau);
}

.fs-fuenfspaltig-slider-full__image img {
	width: 100% !important;
	height: 260px !important;
	display: block;
	object-fit: cover;
	object-position: center;
}

@media (max-width: 1200px) {
	.fs-fuenfspaltig-slider-full__track {
		flex-wrap: wrap !important;
	}

	.fs-fuenfspaltig-slider-full__media {
		flex-basis: calc(33.333% - 10px) !important;
	}

	.fs-fuenfspaltig-slider-full__image img {
		height: 220px !important;
	}
}

@media (max-width: 780px) {
	.fs-fuenfspaltig-slider-full__media {
		flex-basis: calc(50% - 8px) !important;
	}

	.fs-fuenfspaltig-slider-full__image img {
		height: 190px !important;
	}
}

@media (max-width: 520px) {
	.fs-fuenfspaltig-slider-full__media {
		flex-basis: 100% !important;
	}

	.fs-fuenfspaltig-slider-full__image img {
		height: 220px !important;
	}
}

/* ============================================================
   5-spaltig Pattern (fuenfspaltig-karriere-rot)
   ============================================================ */

.fs-fuenfspaltig-karriere-rot__columns {
	display: grid !important;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	align-items: flex-start !important;
	gap: 22px !important;
}

.fs-fuenfspaltig-karriere-rot__column {
	display: flex;
	flex-direction: column;
	min-width: 0;
	flex-basis: auto !important;
	width: 100% !important;
}

.fs-fuenfspaltig-karriere-rot__column:not(:first-child) .fs-fuenfspaltig-karriere-rot__item {
	margin-top: 54px;
}

.fs-fuenfspaltig-karriere-rot__item {
	display: flex;
	flex-direction: column;
	height: 100%;
	width: 100%;
	max-width: 100%;
	text-align: left !important;
}

.fs-fuenfspaltig-karriere-rot__item .wp-block-heading,
.fs-fuenfspaltig-karriere-rot__item .wp-block-paragraph,
.fs-fuenfspaltig-karriere-rot__item .has-text-align-center {
	width: 100%;
	margin-left: 0 !important;
	margin-right: 0 !important;
	text-align: left !important;
}

.fs-fuenfspaltig-karriere-rot__tile {
	display: flex;
	align-items: center;
	justify-content: center;
	align-self: stretch;
	width: 100% !important;
	max-width: 100% !important;
	height: 182px;
	border-radius: 6px;
	background: linear-gradient(165deg, #E30613 0%, #BE0712 100%) !important;
}

.fs-fuenfspaltig-karriere-rot__tile-icon {
	margin: 0 !important;
	width: 68px;
	height: 68px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.9);
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-fuenfspaltig-karriere-rot__tile-icon img {
	width: 36px;
	height: 36px;
	display: block;
	object-fit: contain;
}

.fs-fuenfspaltig-karriere-rot__title {
	color: #535353 !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	line-height: 1.36 !important;
	text-align: left !important;
}

.fs-fuenfspaltig-karriere-rot__desc {
	color: #535353 !important;
	font-size: 18px !important;
	font-weight: 400 !important;
	line-height: 1.36 !important;
	text-align: left !important;
}

@media (max-width: 1320px) {
	.fs-fuenfspaltig-karriere-rot__columns {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.fs-fuenfspaltig-karriere-rot__column {
		flex-basis: auto !important;
	}

	.fs-fuenfspaltig-karriere-rot__column:not(:first-child) .fs-fuenfspaltig-karriere-rot__item {
		margin-top: 0;
	}

	.fs-fuenfspaltig-karriere-rot__intro-title {
		margin-bottom: 18px !important;
	}
}

@media (max-width: 900px) {
	.fs-fuenfspaltig-karriere-rot__columns {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 620px) {
	.fs-fuenfspaltig-karriere-rot__columns {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   5-spaltig Pattern (fuenfspaltig-graukarten)
   ============================================================ */

.fs-fuenfspaltig-graukarten__columns {
	align-items: stretch !important;
	gap: 14px !important;
}

.fs-fuenfspaltig-graukarten__column {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-fuenfspaltig-graukarten__card {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 278px;
	background: var(--fs-hellgrau);
	padding: 18px !important;
}

.fs-fuenfspaltig-graukarten__title,
.fs-fuenfspaltig-graukarten__body,
.fs-fuenfspaltig-graukarten__card .wp-block-heading,
.fs-fuenfspaltig-graukarten__card p {
	text-align: left !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.fs-fuenfspaltig-graukarten__card--primary {
	position: relative;
}

.fs-fuenfspaltig-graukarten__card--primary::after {
	content: none;
	display: none;
}

.fs-fuenfspaltig-graukarten__card--secondary .fs-fuenfspaltig-graukarten__title {
	font-size: 20px !important;
	font-weight: 700 !important;
	line-height: 1.22 !important;
}

.fs-fuenfspaltig-graukarten__card--secondary .fs-fuenfspaltig-graukarten__body {
	font-size: 18px !important;
}

.fs-fuenfspaltig-graukarten__button-row {
	margin-top: 36px !important;
	width: 100%;
	max-width: 100%;
	margin-left: 0 !important;
	margin-right: auto !important;
}

.fs-fuenfspaltig-graukarten__button-row .wp-block-buttons {
	margin-top: 0;
	margin-bottom: 0;
	justify-content: flex-start;
}

.fs-fuenfspaltig-graukarten__button-row .wp-block-button__link {
	white-space: nowrap;
}

@media (max-width: 1320px) {
	.fs-fuenfspaltig-graukarten__columns {
		flex-wrap: wrap !important;
		gap: 16px !important;
	}

	.fs-fuenfspaltig-graukarten__column {
		flex-basis: calc(33.333% - 11px) !important;
	}
}

@media (max-width: 980px) {
	.fs-fuenfspaltig-graukarten__column {
		flex-basis: calc(50% - 8px) !important;
	}
}

@media (max-width: 680px) {
	.fs-fuenfspaltig-graukarten__column {
		flex-basis: 100% !important;
	}
}

/* ============================================================
   5-spaltig Pattern (fuenfspaltig-weisskachel-icon)
   ============================================================ */

.fs-fuenfspaltig-weisskachel-icon__intro {
	max-width: 32%;
	margin-bottom: 132px;
}

.fs-fuenfspaltig-weisskachel-icon__panel {
	background: var(--fs-weiss);
	box-shadow: var(--fs-shadow-card);
	border-radius: 6px;
}

.fs-fuenfspaltig-weisskachel-icon__columns {
	align-items: flex-start !important;
	gap: 24px !important;
}

.fs-fuenfspaltig-weisskachel-icon__columns > .fs-fuenfspaltig-weisskachel-icon__column {
	flex: 1 1 0 !important;
}

.fs-fuenfspaltig-weisskachel-icon__columns > .fs-fuenfspaltig-weisskachel-icon__column:first-child {
	flex: 0.86 1 0 !important;
}

.fs-fuenfspaltig-weisskachel-icon__column {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	min-width: 0;
	gap: 0;
}

.fs-fuenfspaltig-weisskachel-icon__card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	height: 100%;
	min-height: 320px;
}

.fs-fuenfspaltig-weisskachel-icon__card--primary {
	border-right: 0;
	padding-right: 0;
}

.fs-fuenfspaltig-weisskachel-icon__icon-image {
	margin: 0 0 44px;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	border: 1px solid #666;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fs-fuenfspaltig-weisskachel-icon__icon-image img {
	width: 40px;
	height: 40px;
	display: block;
	object-fit: contain;
	filter: brightness(0) saturate(100%);
	opacity: 0.62;
}

.fs-fuenfspaltig-weisskachel-icon__title {
	font-size: 18px !important;
	font-weight: 700 !important;
	line-height: 1.28 !important;
	font-family: var(--fs-font-open) !important;
	min-height: 88px;
	margin-top: 18px !important;
	margin-bottom: 14px !important;
	overflow-wrap: normal;
	word-break: normal;
	hyphens: auto;
}

.fs-fuenfspaltig-weisskachel-icon__card--primary .fs-fuenfspaltig-weisskachel-icon__title {
	font-size: 18px !important;
	font-weight: 700 !important;
	line-height: 1.28 !important;
	font-family: var(--fs-font-open) !important;
	min-height: 88px;
	margin-top: 18px !important;
	margin-bottom: 14px !important;
}

.fs-fuenfspaltig-weisskachel-icon__body {
	margin-top: 0 !important;
	align-self: flex-start;
}

.fs-fuenfspaltig-weisskachel-icon__column > .fs-fuenfspaltig-weisskachel-icon__body {
	margin-top: 0 !important;
}

@media (max-width: 1320px) {
	.fs-fuenfspaltig-weisskachel-icon__intro {
		max-width: 50%;
	}

	.fs-fuenfspaltig-weisskachel-icon__columns {
		flex-wrap: wrap !important;
		gap: 18px !important;
	}

	.fs-fuenfspaltig-weisskachel-icon__column {
		flex-basis: calc(33.333% - 12px) !important;
	}

	.fs-fuenfspaltig-weisskachel-icon__columns > .fs-fuenfspaltig-weisskachel-icon__column:first-child {
		flex: 1 1 0 !important;
	}

	.fs-fuenfspaltig-weisskachel-icon__card--primary {
		border-right: 0;
		padding-right: 0;
	}
}

@media (max-width: 980px) {
	.fs-fuenfspaltig-weisskachel-icon__intro {
		max-width: 70%;
	}

	.fs-fuenfspaltig-weisskachel-icon__column {
		flex-basis: calc(50% - 9px) !important;
	}

	.fs-fuenfspaltig-weisskachel-icon__title {
		font-size: 17px !important;
	}
}

@media (max-width: 680px) {
	.fs-fuenfspaltig-weisskachel-icon__intro {
		max-width: 100%;
	}

	.fs-fuenfspaltig-weisskachel-icon__panel {
		padding: 24px !important;
	}

	.fs-fuenfspaltig-weisskachel-icon__column {
		flex-basis: 100% !important;
	}
}

/* ============================================================
   1-spaltig Patterns (einspaltig-*)
   ============================================================ */

/* --- CTA Anfrage-Card --- */
.fs-cta-card {
	box-shadow: var(--fs-shadow-card);
	text-align: center;
}

.fs-cta-card__label {
	text-transform: none;
}

.fs-cta-card__logo {
	margin-top: 32px;
	margin-bottom: 0 !important;
}

/* --- Zentrierter Text (Trenner/Einleitung) --- */
.fs-text-zentriert__content {
	font-family: var(--wp--preset--font-family--open-sans);
}

/* --- Headline + Fließtext --- */
.fs-headline-text {
	text-align: left;
}

/* --- Bild Vollbreite --- */
.fs-bild-section__image img {
	width: 100%;
	height: auto;
	display: block;
}

.fs-bild-halbe-breite__image img {
	width: 100%;
	height: auto;
	display: block;
}

.fs-bild-halbe-breite__inner {
	width: 100%;
	max-width: 674px;
	margin-left: auto !important;
	margin-right: 0 !important;
}

/* --- Bildergalerie --- */
.fs-bildergalerie-section__main {
	border-radius: 8px;
	overflow: hidden;
}

.fs-bildergalerie-section__main-image {
	margin: 0 !important;
}

.fs-bildergalerie-section__main-image img {
	width: 100%;
	aspect-ratio: 16 / 9;
	height: auto;
	display: block;
	object-fit: cover;
}

.fs-bildergalerie-section__thumb-row {
	margin-top: 24px !important;
	gap: 16px !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
}

.fs-bildergalerie-section__arrow {
	cursor: pointer;
	user-select: none;
	flex: 0 0 32px;
	text-align: center;
	transition: color var(--fs-transition);
}

.fs-bildergalerie-section__arrow:hover {
	color: var(--fs-dunkelgrau) !important;
}

.fs-bildergalerie-section__thumb-viewport {
	flex: 1 1 auto;
	width: 100%;
	min-width: 0;
	overflow: hidden;
}

.fs-bildergalerie-section__thumb-track {
	display: flex !important;
	flex-wrap: nowrap !important;
	gap: 14px !important;
	transform: translateX(0);
	transition: transform 260ms ease;
}

.fs-bildergalerie-section__thumb-track > .fs-bildergalerie-section__thumb {
	flex: 0 0 calc((100% - 56px) / 5) !important;
	min-width: calc((100% - 56px) / 5);
	margin: 0 !important;
}

.fs-bildergalerie-section__thumb {
	border-radius: 8px;
	overflow: hidden;
	cursor: pointer;
	transition: transform var(--fs-transition), box-shadow var(--fs-transition), opacity var(--fs-transition);
	opacity: 0.9;
}

.fs-bildergalerie-section__thumb:hover {
	transform: translateY(-2px);
	box-shadow: var(--fs-shadow-card);
	opacity: 1;
}

.fs-bildergalerie-section__thumb.is-active {
	box-shadow: 0 0 0 2px #E30613;
	opacity: 1;
}

.fs-bildergalerie-section__thumb-image,
.fs-bildergalerie-section__thumb-image img {
	margin: 0 !important;
}

.fs-bildergalerie-section__thumb-image img {
	width: 100%;
	aspect-ratio: 5 / 4;
	height: auto;
	display: block;
	object-fit: cover;
}

/* --- Aufzählung mit Checkmarks --- */
.fs-aufzaehlung-section__description {
	width: min(100%, 620px);
	max-width: 620px;
	margin-right: auto;
	overflow-wrap: break-word;
	word-break: normal;
	hyphens: auto;
}

.fs-aufzaehlung-section__list {
	list-style: none;
	padding-left: 0;
}

.fs-aufzaehlung-section__list li {
	position: relative;
	padding-left: 36px;
	margin-bottom: 12px;
}

.fs-aufzaehlung-section__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 4px;
	width: 20px;
	height: 20px;
	background-color: var(--wp--preset--color--rot);
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E");
	mask-size: contain;
	-webkit-mask-size: contain;
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
}

/* --- Button-Sektion --- */
.fs-button-section .wp-block-button__link {
	font-family: var(--wp--preset--font-family--azo-sans);
}

/* --- FAQ --- */
.fs-faq-section .wp-block-details {
	border: none;
}

.fs-faq-section .wp-block-details summary {
	font-family: var(--wp--preset--font-family--open-sans);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--wp--preset--color--dunkelgrau);
	cursor: pointer;
	padding: 8px 0;
}

.fs-faq-section .wp-block-details[open] summary {
	font-weight: 700;
	color: var(--wp--preset--color--rot);
}

.fs-faq-divider {
	opacity: 1;
	height: 1px !important;
}

.fs-faq-filters {
	gap: 24px;
	justify-content: center;
	flex-wrap: wrap;
}

.fs-faq-filters .wp-block-button {
	margin: 0;
}

.fs-faq-filters .wp-block-button__link {
	min-width: 150px;
	text-align: center;
	justify-content: center;
	font-family: var(--wp--preset--font-family--open-sans);
	cursor: pointer;
	transition: background-color var(--fs-transition), color var(--fs-transition), border-color var(--fs-transition);
}

.fs-faq-filter .wp-block-button__link {
	font-weight: 400 !important;
}

.fs-faq-filter-active .wp-block-button__link,
.fs-faq-filter.is-active .wp-block-button__link {
	font-weight: 700 !important;
	background-color: #535353 !important;
	border-color: #535353 !important;
	color: #fff !important;
}

.fs-faq-filter-select-wrap {
	display: none;
	margin: 0 0 22px !important;
}

.fs-faq-filter-select {
	display: block;
	width: 100%;
	height: 44px;
	padding: 0 46px 0 18px;
	border: 1px solid #ececec;
	border-radius: 999px;
	background-color: var(--fs-weiss);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 16 10'%3E%3Cpath d='M1.5 1.5L8 8l6.5-6.5' fill='none' stroke='%23535353' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-position: right 16px center;
	background-repeat: no-repeat;
	background-size: 16px 10px;
	appearance: none;
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 300;
	line-height: 1.35;
	color: #8f8f8f;
}

.fs-faq-entry.is-hidden {
	display: none !important;
}

.fs-faq-item__content > *:first-child {
	margin-top: 0;
}

.fs-faq-item__content > *:last-child {
	margin-bottom: 0;
}

/* --- 1-spaltig Responsive --- */
@media (max-width: 768px) {
	.fs-cta-card {
		padding: 40px 24px !important;
	}

	.fs-text-zentriert__content {
		font-size: 24px !important;
	}

	.fs-faq-filters {
		flex-wrap: wrap !important;
	}

	.fs-faq-filter-select-wrap {
		display: block;
	}

	.fs-faq-filters {
		display: none !important;
	}

	.fs-bildergalerie-section__arrow {
		font-size: 46px !important;
	}

	.fs-bildergalerie-section__thumb-track {
		gap: 10px !important;
	}

	.fs-bildergalerie-section__thumb-track > .fs-bildergalerie-section__thumb {
		flex: 0 0 calc((100% - 20px) / 3) !important;
		min-width: calc((100% - 20px) / 3);
	}
}

@media (max-width: 640px) {
	.fs-bildergalerie-section__arrow {
		font-size: 38px !important;
	}

	.fs-bildergalerie-section__thumb-track > .fs-bildergalerie-section__thumb {
		flex: 0 0 calc((100% - 10px) / 2) !important;
		min-width: calc((100% - 10px) / 2);
	}
}

/* ============================================================
   03.01 Lösungen
   ============================================================ */

.fs-loesungen-hero {
	min-height: 771px;
}

.fs-loesungen-hero__inner {
	max-width: min(100%, 1015px) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-loesungen-hero__subline {
	margin: 0;
	font-family: var(--fs-font-open);
	font-size: 35px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-loesungen-hero__title {
	margin: 0 !important;
	max-width: 1015px;
	font-family: var(--fs-font-open);
	font-size: 50px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-loesungen-produkte {
	margin-top: -157px !important;
}

.fs-loesungen-produkte__card,
.fs-loesungen-branchen__card {
	background: var(--fs-weiss);
	box-shadow: var(--fs-shadow-card);
}

.fs-loesungen-produkte__card {
	padding: 71px 138px 80px;
}

.fs-loesungen-section-label {
	margin: 0 0 52px !important;
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--wp--preset--color--rot);
}

.fs-loesungen-produkte__grid {
	display: grid !important;
	grid-template-columns: repeat(4, 260px);
	justify-content: center;
	column-gap: 57px;
	row-gap: 34px;
}

.fs-loesungen-produkt-card {
	width: 260px;
	height: 256px;
	overflow: hidden;
	background: var(--fs-hellgrau);
	cursor: pointer;
}

.fs-loesungen-produkt-card__image {
	margin: 0 !important;
	width: 100%;
	height: 162px;
	overflow: hidden;
}

.fs-loesungen-produkt-card__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease;
	transform-origin: center center;
}

.fs-loesungen-produkt-card:hover .fs-loesungen-produkt-card__image img,
.fs-loesungen-produkt-card:focus-within .fs-loesungen-produkt-card__image img {
	transform: scale(1.08);
}

.fs-loesungen-produkt-card__label {
	margin: 21px 0 0 !important;
	padding: 0 20px;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-loesungen-branchen__card {
	padding: 66px 138px 74px;
}

.fs-loesungen-branchen__grid {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 279px));
	justify-content: center;
	column-gap: 81px;
}

.fs-loesungen-branchen__column {
	display: flex;
	flex-direction: column;
	row-gap: 16px;
}

.fs-loesungen-branche-pill {
	min-height: 58px;
	padding: 0 20px 0 16px;
	border-radius: 29px;
	background: var(--fs-hellgrau);
	gap: 12px !important;
	align-items: center !important;
	cursor: pointer;
}

.fs-loesungen-branche-pill__icon {
	margin: 0 !important;
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.fs-loesungen-branche-pill__icon img {
	display: block;
	width: 38px !important;
	height: 38px !important;
	object-fit: contain;
}

.fs-loesungen-branche-pill__label {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.15;
	color: var(--fs-dunkelgrau);
}

@media (max-width: 1500px) {
	.fs-loesungen-produkte__card,
	.fs-loesungen-branchen__card {
		padding-left: 40px;
		padding-right: 40px;
	}

	.fs-loesungen-branchen__grid {
		column-gap: 24px;
	}
}

@media (max-width: 1200px) {
	.fs-loesungen-hero {
		min-height: auto;
	}

	.fs-loesungen-hero__subline {
		font-size: 30px;
	}

	.fs-loesungen-hero__title {
		font-size: 40px;
	}

	.fs-loesungen-produkte {
		margin-top: -120px !important;
	}

	.fs-loesungen-produkte__grid {
		grid-template-columns: repeat(3, 260px);
	}

	.fs-loesungen-branchen__grid {
		grid-template-columns: repeat(2, minmax(0, 279px));
		row-gap: 16px;
	}
}

@media (max-width: 980px) {
	.fs-loesungen-hero {
		padding-top: 72px !important;
		padding-bottom: 72px !important;
	}

	.fs-loesungen-hero__subline {
		font-size: 26px;
	}

	.fs-loesungen-hero__title {
		font-size: 34px;
		line-height: 1.3;
	}

	.fs-loesungen-produkte {
		margin-top: 0 !important;
	}

	.fs-loesungen-produkte__card,
	.fs-loesungen-branchen__card {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.fs-loesungen-section-label {
		margin-bottom: 28px !important;
	}

	.fs-loesungen-produkte__grid {
		grid-template-columns: repeat(2, minmax(0, 260px));
		column-gap: 24px;
		row-gap: 24px;
	}
}

@media (max-width: 700px) {
	.fs-loesungen-hero__subline {
		font-size: 24px;
	}

	.fs-loesungen-hero__title {
		font-size: 30px;
	}

	.fs-loesungen-produkte__card,
	.fs-loesungen-branchen__card {
		padding-left: 20px;
		padding-right: 20px;
	}

	.fs-loesungen-produkte__grid {
		grid-template-columns: minmax(0, 260px);
		justify-content: center;
	}

	.fs-loesungen-branchen__grid {
		grid-template-columns: minmax(0, 279px);
		justify-content: center;
	}
}

/* ============================================================
   05.01 + 05.02 Referenzen
   ============================================================ */

.fs-ref-archive-hero {
	padding-top: 92px !important;
	padding-bottom: 220px !important;
}

.fs-ref-archive-hero__inner,
.fs-ref-archive-main__inner {
	max-width: min(100%, var(--wp--style--global--content-size, 1364px)) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-referenz-detail-hero__inner,
.fs-referenz-detail-meta__inner,
.fs-referenz-detail-overview__inner,
.fs-referenz-detail-description__inner {
	max-width: min(100%, var(--wp--style--global--content-size, 1364px)) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-ref-archive-hero__subline {
	margin: 0 0 12px !important;
	font-family: var(--fs-font-open);
	font-size: 49px;
	font-weight: 400;
	line-height: 1.2;
	color: var(--fs-dunkelgrau);
}

.fs-ref-archive-hero__title {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 65px;
	font-weight: 700;
	line-height: 1.15;
	color: var(--fs-dunkelgrau);
	max-width: 1220px;
}

.fs-ref-archive-main {
	margin-top: -154px !important;
	padding-bottom: 120px !important;
}

.fs-ref-archive-main__inner {
	background: transparent;
}

.fs-ref-archive-filters {
	margin: 0 0 46px !important;
	padding: 25px 40px !important;
	background: var(--fs-weiss);
	border: 1px solid #E5E5E5;
	gap: 10px;
	box-shadow: var(--fs-shadow-card);
}

.fs-ref-chip {
	margin: 0 !important;
	padding: 3px 16px 4px;
	border: 1px solid var(--fs-mittelgrau);
	border-radius: 20px;
	background: transparent;
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 300;
	line-height: 1.35;
	color: var(--fs-dunkelgrau);
}

button.fs-ref-chip {
	appearance: none;
	background: transparent;
	cursor: pointer;
}

.fs-ref-chip.is-active {
	font-weight: 700;
}

.fs-ref-archive-filter-select-wrap {
	display: none;
	margin: 0 0 24px !important;
}

.fs-ref-archive-filter-select {
	display: block;
	width: 100%;
	height: 44px;
	padding: 0 46px 0 18px;
	border: 1px solid #ececec;
	border-radius: 999px;
	background-color: var(--fs-weiss);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 16 10'%3E%3Cpath d='M1.5 1.5L8 8l6.5-6.5' fill='none' stroke='%23535353' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-position: right 16px center;
	background-repeat: no-repeat;
	background-size: 16px 10px;
	appearance: none;
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 300;
	line-height: 1.35;
	color: #8f8f8f;
}

.fs-ref-archive-filter-select:focus {
	outline: none;
	border-color: #c8c8c8;
}

.fs-ref-archive-grid {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 15px;
}

.fs-ref-archive-card {
	overflow: hidden;
	border-radius: 8px;
	box-shadow: var(--fs-shadow-card);
}

.fs-ref-archive-card .wp-block-cover__inner-container {
	height: 100%;
}

.fs-ref-archive-card__content {
	height: 100%;
	padding: 0 28px 24px !important;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}

.fs-ref-archive-card__title {
	margin: 0 0 14px !important;
	font-family: var(--fs-font-open);
	font-size: 36px;
	font-weight: 700;
	line-height: 1.15;
	color: var(--fs-weiss);
}

.fs-ref-archive-card__more {
	margin: 0 !important;
	display: flex;
	justify-content: flex-end;
}

.fs-ref-archive-card__more a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 126px;
	padding: 5px 18px 6px;
	border: 1px solid rgba(255, 255, 255, 0.75);
	border-radius: 20px;
	font-family: var(--fs-font-open);
	font-size: 16px;
	font-weight: 300;
	line-height: 1.2;
	color: var(--fs-weiss);
	text-decoration: none;
}

.fs-ref-archive-loadmore {
	margin-top: 75px !important;
}

.fs-ref-archive-loadmore .wp-block-button__link {
	min-width: 233px;
}

.fs-ref-btn .wp-block-button__link {
	min-width: 132px;
}

.fs-referenz-detail-hero {
	padding-top: 90px !important;
	padding-bottom: 140px !important;
}

.fs-referenz-detail-hero__subline {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 35px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-detail-hero__title {
	margin: 10px 0 0 !important;
	font-family: var(--fs-font-open);
	font-size: 50px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-detail-meta {
	padding: 26px 0 42px !important;
}

.fs-referenz-detail-meta__row {
	gap: 20px;
}

.fs-referenz-detail-meta__breadcrumb {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 300;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-detail-meta__actions {
	gap: 16px;
}

.fs-referenz-detail-overview {
	padding-bottom: 86px !important;
}

.fs-referenz-detail-overview__columns {
	align-items: flex-start !important;
	gap: 145px !important;
}

.fs-referenz-detail-overview__label {
	margin: 0 0 35px !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-rot);
}

.fs-referenz-detail-overview__text {
	margin: 0 0 34px !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-detail-overview__main-image {
	margin: 0 !important;
	border-radius: 4px;
	overflow: hidden;
}

.fs-referenz-detail-overview__main-link {
	display: block;
	position: relative;
}

.fs-referenz-detail-overview__main-image img {
	display: block;
	width: 100%;
	height: auto;
}

.fs-referenz-detail-overview__gallery-controls {
	margin-top: 22px !important;
	gap: 16px;
}

.fs-referenz-detail-overview__gallery-arrow {
	margin: 0 !important;
	width: 39px;
	height: 39px;
	border: 0;
	border-radius: 50%;
	background: #F0F0F0;
	color: var(--fs-dunkelgrau);
	font-size: 28px;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.fs-referenz-detail-overview__gallery-count {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-detail-overview__caption {
	margin: 6px 0 0 !important;
	font-family: var(--fs-font-open);
	font-size: 16px;
	font-weight: 300;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-gallery.is-single-image .fs-referenz-detail-overview__gallery-controls {
	display: none !important;
}

.fs-referenz-detail-description {
	padding: 78px 0 120px !important;
	border-top: 1px solid #D8D8D8;
}

.fs-referenz-detail-description__columns {
	align-items: flex-start !important;
	gap: 102px !important;
}

.fs-referenz-detail-description__label {
	margin: 0 0 36px !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-rot);
}

.fs-referenz-detail-description__text {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-referenz-detail-description__text p:first-child {
	margin-top: 0;
}

.fs-referenz-detail-description__text p:last-child {
	margin-bottom: 0;
}

.fs-referenz-detail-description__actions {
	margin-top: 74px !important;
	gap: 16px;
}

.fs-referenz-detail__thumb-grid {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 260px));
	column-gap: 16px;
	row-gap: 22px;
}

.fs-referenz-detail__thumb-card {
	width: 260px;
	height: 149px;
	overflow: hidden;
	border-radius: 4px;
	padding: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
}

.fs-referenz-detail__thumb-image {
	margin: 0 !important;
}

.fs-referenz-detail__thumb-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.fs-referenz-detail__thumb-card.is-active {
	outline: 2px solid var(--fs-rot);
	outline-offset: 1px;
}

.fs-referenz-image-with-logo {
	position: relative;
}

.fs-referenz-image-with-logo::after {
	content: "";
	position: absolute;
	top: 20px;
	left: 20px;
	width: 104px;
	height: 24px;
	background: url("../img/logo-sailer.svg") center/contain no-repeat;
	filter: brightness(0) invert(1);
	opacity: 0.95;
	pointer-events: none;
}

@media (max-width: 1200px) {
	.fs-ref-archive-hero__subline {
		font-size: 38px;
	}

	.fs-ref-archive-hero__title {
		font-size: 52px;
	}

	.fs-referenz-detail-overview__columns,
	.fs-referenz-detail-description__columns {
		gap: 40px !important;
	}
}

@media (max-width: 980px) {
	.fs-ref-archive-hero {
		padding-top: 72px !important;
		padding-bottom: 120px !important;
	}

	.fs-ref-archive-main {
		margin-top: -64px !important;
	}

	.fs-ref-archive-hero__subline {
		font-size: 30px;
	}

	.fs-ref-archive-hero__title {
		font-size: 40px;
	}

	.fs-ref-archive-filters {
		padding: 20px 18px !important;
	}

	.fs-ref-archive-grid {
		grid-template-columns: 1fr;
	}

	.fs-ref-archive-card__title {
		font-size: 30px;
	}

	.fs-referenz-detail-hero {
		padding-top: 72px !important;
		padding-bottom: 72px !important;
	}

	.fs-referenz-detail-hero__subline {
		font-size: 27px;
	}

	.fs-referenz-detail-hero__title {
		font-size: 38px;
	}

	.fs-referenz-detail-meta__row,
	.fs-referenz-detail-overview__columns,
	.fs-referenz-detail-description__columns {
		flex-direction: column !important;
	}

	.fs-referenz-detail-overview__text-col,
	.fs-referenz-detail-overview__media-col,
	.fs-referenz-detail-description__text-col,
	.fs-referenz-detail-description__gallery-col {
		flex-basis: 100% !important;
		width: 100%;
	}

	.fs-referenz-detail-description__actions {
		margin-top: 40px !important;
	}

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

	.fs-referenz-detail__thumb-card {
		width: 100%;
		height: auto;
	}

	.fs-referenz-detail__thumb-image img {
		aspect-ratio: 260 / 149;
		height: auto;
	}
}

@media (max-width: 700px) {
	.fs-ref-archive-hero__subline,
	.fs-referenz-detail-hero__subline {
		font-size: 24px;
	}

	.fs-ref-archive-hero__title,
	.fs-referenz-detail-hero__title {
		font-size: 31px;
	}

	.fs-ref-chip {
		font-size: 13px;
	}

	.fs-ref-archive-filter-select-wrap {
		display: block;
	}

	.fs-ref-archive-filters {
		display: none !important;
	}

	.fs-ref-archive-card {
		min-height: 360px !important;
	}

	.fs-ref-archive-card__title {
		font-size: 26px;
	}

	.fs-ref-archive-card__more {
		justify-content: flex-start;
	}

	.fs-referenz-detail__thumb-grid {
		grid-template-columns: 1fr;
	}

	.fs-referenz-detail-overview__gallery-controls {
		gap: 10px;
	}

	.fs-referenz-detail-overview__gallery-arrow {
		width: 34px;
		height: 34px;
		font-size: 24px;
	}

	.fs-referenz-detail-meta__actions,
	.fs-referenz-detail-description__actions {
		flex-wrap: wrap !important;
	}
}

/* ============================================================
   04.03 Geschichte
   ============================================================ */

.fs-history-hero {
	padding-top: 84px !important;
	padding-bottom: 36px !important;
}

.fs-history-hero__inner,
.fs-history-main__inner {
	max-width: min(100%, var(--wp--style--global--content-size, 1364px)) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-history-hero__subline {
	margin: 0 0 8px !important;
	font-family: var(--fs-font-open);
	font-size: 35px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-history-hero__title {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 50px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--fs-dunkelgrau);
}

.fs-history-hero__media {
	margin: 34px 0 14px !important;
	border-radius: 6px;
	overflow: hidden;
	box-shadow: var(--fs-shadow-card);
}

.fs-history-hero__media img {
	display: block;
	width: 100%;
	height: auto;
}

.fs-history-hero__breadcrumb {
	margin: 0 !important;
	font-family: var(--fs-font-open);
	font-size: 13px;
	font-weight: 300;
	line-height: 1.4;
	color: var(--fs-mittelgrau);
}

.fs-history-main {
	padding: 26px 0 0 !important;
}

.fs-history-intro {
	margin: 0 auto 24px !important;
	max-width: 760px;
	font-family: var(--fs-font-open);
	font-size: 49px;
	font-weight: 400;
	line-height: 1.22;
	color: var(--fs-dunkelgrau);
}

.fs-history-intro strong {
	font-weight: 700;
}

.fs-history-filters {
	gap: 10px !important;
	margin: 0 auto 38px !important;
	max-width: 760px;
}

.fs-history-filter-select-wrap {
	display: none;
	margin: 0 auto 26px !important;
	max-width: 520px;
}

.fs-history-filter-select {
	display: block;
	width: 100%;
	height: 44px;
	padding: 0 46px 0 18px;
	border: 1px solid #ececec;
	border-radius: 999px;
	background-color: var(--fs-weiss);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 16 10'%3E%3Cpath d='M1.5 1.5L8 8l6.5-6.5' fill='none' stroke='%23535353' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-position: right 16px center;
	background-repeat: no-repeat;
	background-size: 16px 10px;
	appearance: none;
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 300;
	line-height: 1.35;
	color: #8f8f8f;
}

.fs-history-chip {
	margin: 0 !important;
	appearance: none;
	border: 1px solid var(--fs-mittelgrau);
	border-radius: 20px;
	padding: 3px 16px 4px;
	background: var(--fs-weiss);
	color: var(--fs-dunkelgrau);
	font-family: var(--fs-font-open);
	font-size: 14px;
	font-weight: 300;
	line-height: 1.35;
	cursor: pointer;
	transition: var(--fs-transition);
}

.fs-history-chip:hover {
	border-color: var(--fs-dunkelgrau);
}

.fs-history-chip.is-active {
	font-weight: 700;
}

.fs-history-era {
	display: none;
}

.fs-history-era.is-active {
	display: block;
}

.fs-history-era__year {
	margin: 0 auto 18px !important;
	display: inline-block;
	border: 1px solid var(--fs-mittelgrau);
	border-radius: 16px;
	padding: 3px 12px;
	font-family: var(--fs-font-open);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
	color: var(--fs-dunkelgrau);
	background: var(--fs-weiss);
}

.fs-history-era__columns {
	gap: 15px !important;
	align-items: stretch !important;
	margin-bottom: 0 !important;
}

.fs-history-era__image {
	margin: 0 !important;
	border-radius: 4px;
	overflow: hidden;
	box-shadow: var(--fs-shadow-card);
}

.fs-history-era__image img {
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

.fs-history-era__text {
	margin: 30px auto 0 !important;
	max-width: 820px;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 300;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

@media (max-width: 1200px) {
	.fs-history-hero__subline {
		font-size: 30px;
	}

	.fs-history-hero__title {
		font-size: 42px;
	}

	.fs-history-intro {
		font-size: 40px;
	}
}

@media (max-width: 980px) {
	.fs-history-hero {
		padding-top: 72px !important;
	}

	.fs-history-hero__subline {
		font-size: 26px;
	}

	.fs-history-hero__title {
		font-size: 34px;
		line-height: 1.25;
	}

	.fs-history-intro {
		font-size: 31px;
	}

	.fs-history-era__columns {
		flex-direction: column !important;
	}

	.fs-history-era__columns > .wp-block-column {
		flex-basis: 100% !important;
	}
}

@media (max-width: 700px) {
	.fs-history-hero__subline {
		font-size: 24px;
	}

	.fs-history-hero__title {
		font-size: 30px;
	}

	.fs-history-intro {
		font-size: 26px;
	}

	.fs-history-chip {
		font-size: 13px;
	}

	.fs-history-filter-select-wrap {
		display: block;
	}

	.fs-history-filters {
		display: none !important;
	}

	.fs-history-era.is-active {
		display: flex;
		flex-direction: column;
	}

	.fs-history-era__columns {
		order: 1;
	}

	.fs-history-era__year {
		order: 3;
		margin: 10px 0 0 !important;
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: var(--fs-rot);
		font-size: 26px;
		font-weight: 700;
		line-height: 1.15;
		display: block;
		text-align: center;
	}

	.fs-history-era__dots {
		order: 2;
		display: flex;
		justify-content: center;
		gap: 10px;
		margin: 12px 0 0;
	}

	.fs-history-era__dot {
		width: 10px;
		height: 10px;
		border: 0;
		border-radius: 50%;
		background: #d9d9d9;
		padding: 0;
	}

	.fs-history-era__dot.is-active {
		background: #b0b0b0;
	}

	.fs-history-era__columns.is-mobile-slider {
		display: block !important;
	}

	.fs-history-era__columns.is-mobile-slider > .wp-block-column {
		display: none;
	}

	.fs-history-era__columns.is-mobile-slider > .wp-block-column.is-active {
		display: block;
	}

	.fs-history-era__columns.is-mobile-slider .fs-history-era__image img {
		aspect-ratio: 320 / 180;
	}

	.fs-history-era__text {
		order: 4;
		margin-top: 14px !important;
	}
}

/* ============================================================
   04.04 Unsere Prinzipien
   ============================================================ */

.fs-principles-hero {
	padding-bottom: 0 !important;
}

.fs-principles-intro__text {
	max-width: 980px;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-principles-boxed__card {
	max-width: 1640px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	box-shadow: var(--fs-shadow-card);
}

.fs-principles-boxed__headline {
	max-width: 620px;
}

.fs-principles-row__columns {
	align-items: center !important;
	justify-content: space-between;
	gap: 46px !important;
}

.fs-principles-row__image {
	margin: 0 !important;
}

.fs-principles-row__image img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 4px;
}

.fs-principles-row__text-col {
	justify-content: center;
}

@media (max-width: 1200px) {
	.fs-principles-intro__text {
		font-size: 40px !important;
	}

	.fs-principles-boxed__headline {
		font-size: 44px !important;
	}
}

@media (max-width: 980px) {
	.fs-principles-intro__text {
		font-size: 31px !important;
	}

	.fs-principles-boxed__card {
		padding: 36px 22px !important;
	}

	.fs-principles-row__columns {
		flex-direction: column !important;
		gap: 24px !important;
	}

	.fs-principles-row__image-col,
	.fs-principles-row__text-col {
		flex-basis: 100% !important;
		width: 100%;
	}

	.fs-principles-row__body {
		margin-bottom: 18px !important;
	}
}

@media (max-width: 700px) {
	.fs-principles-intro__text {
		font-size: 26px !important;
	}

	.fs-principles-boxed__headline {
		font-size: 34px !important;
	}
}

/* ============================================================
   04.05 Downloads
   ============================================================ */

.fs-downloads-hero {
	padding-bottom: 64px !important;
}

.fs-downloads-hero__inner,
.fs-downloads-main {
	max-width: min(100%, var(--wp--style--global--content-size, 1364px)) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-downloads-filter-row {
	gap: 12px;
	align-items: center !important;
}

.fs-downloads-filters {
	gap: 8px !important;
}

.fs-downloads-filter .wp-block-button__link {
	appearance: none;
	cursor: pointer;
}

.fs-downloads-filter.is-active .wp-block-button__link {
	font-weight: 700;
}

.fs-downloads-accordion {
	margin: 0 0 18px !important;
	border: 1px solid #e4e4e4;
	background: var(--fs-weiss);
	box-shadow: var(--fs-shadow-card);
	padding: 0 !important;
}

.fs-downloads-accordion summary {
	list-style: none;
	cursor: pointer;
	font-family: var(--fs-font-open);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
	padding: 28px 34px;
	position: relative;
}

.fs-downloads-accordion summary::-webkit-details-marker {
	display: none;
}

.fs-downloads-accordion summary::after {
	content: '';
	position: absolute;
	right: 34px;
	top: 50%;
	width: 10px;
	height: 10px;
	border-right: 2px solid #707070;
	border-bottom: 2px solid #707070;
	transform: translateY(-58%) rotate(45deg);
	transition: transform var(--fs-transition);
}

.fs-downloads-accordion[open] summary::after {
	transform: translateY(-38%) rotate(-135deg);
}

.fs-downloads-accordion > :not(summary) {
	padding: 0 0 28px !important;
}

.fs-downloads-card {
	margin: 0 34px 18px !important;
	border: 1px solid #ebebeb;
	background: #fafafa;
}

.fs-downloads-card:last-child {
	margin-bottom: 0 !important;
}

.fs-downloads-card__columns {
	gap: 0 !important;
	align-items: stretch !important;
	margin-bottom: 0 !important;
}

.fs-downloads-card__cover-col,
.fs-downloads-card__text-col,
.fs-downloads-card__action-col {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.fs-downloads-card__cover-col {
	padding: 34px;
	border-right: 1px solid #ebebeb;
}

.fs-downloads-card__cover {
	margin: 0 !important;
	max-width: 168px;
}

.fs-downloads-card__cover img {
	display: block;
	width: 100%;
	height: auto;
}

.fs-downloads-card__text-col {
	padding: 34px 30px;
}

.fs-downloads-card__action-col {
	padding: 34px;
	align-items: flex-end;
}

.fs-downloads-download-btn .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	border: 1px solid var(--fs-rot);
	border-radius: 20px;
	padding: 5px 16px;
	font-family: var(--fs-font-open);
	font-size: 16px;
	font-weight: 300;
	line-height: 1.3;
	text-decoration: none;
	background: transparent;
	color: var(--fs-rot);
	transition: var(--fs-transition);
}

.fs-downloads-download-btn .wp-block-button__link::after {
	content: '↓';
	font-size: 14px;
	line-height: 1;
}

.fs-downloads-download-btn .wp-block-button__link:hover {
	background: var(--fs-rot);
	color: var(--fs-weiss);
}

.fs-downloads-download-btn .wp-block-button__link:hover::after {
	color: var(--fs-weiss);
}

.fs-downloads-placeholder {
	padding: 0 34px;
	margin: 0 !important;
}

.fs-downloads-card.is-hidden,
.fs-downloads-accordion.is-hidden {
	display: none;
}

@media (max-width: 1200px) {
	.fs-downloads-hero__subline {
		font-size: 38px !important;
	}

	.fs-downloads-hero__title {
		font-size: 52px !important;
	}
}

@media (max-width: 980px) {
	.fs-downloads-hero {
		padding-top: 72px !important;
		padding-bottom: 54px !important;
	}

	.fs-downloads-hero__subline {
		font-size: 30px !important;
	}

	.fs-downloads-hero__title {
		font-size: 40px !important;
	}

	.fs-downloads-card {
		margin: 0 16px 14px !important;
	}

	.fs-downloads-card__columns {
		flex-direction: column !important;
	}

	.fs-downloads-card__cover-col,
	.fs-downloads-card__text-col,
	.fs-downloads-card__action-col {
		flex-basis: 100% !important;
		width: 100%;
	}

	.fs-downloads-card__cover-col {
		border-right: 0;
		padding-bottom: 0;
	}

	.fs-downloads-card__action-col {
		align-items: flex-start;
		padding-top: 0;
	}
}

@media (max-width: 700px) {
	.fs-downloads-hero__subline {
		font-size: 24px !important;
	}

	.fs-downloads-hero__title {
		font-size: 31px !important;
	}

	.fs-downloads-accordion summary {
		padding: 22px 20px;
		font-size: 16px;
	}

	.fs-downloads-accordion summary::after {
		right: 20px;
	}

	.fs-downloads-card {
		margin: 0 10px 14px !important;
	}

	.fs-downloads-card__cover-col,
	.fs-downloads-card__text-col,
	.fs-downloads-card__action-col {
		padding-left: 20px;
		padding-right: 20px;
	}
}

/* ============================================================
   04.06 Kontakt + Dankeseite
   ============================================================ */

.fs-contact-page-hero {
	padding-bottom: 88px !important;
}

.fs-contact-page-hero__inner,
.fs-contact-page-main,
.fs-contact-thanks-main {
	max-width: min(100%, var(--wp--style--global--content-size, 1364px)) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-contact-page-card,
.fs-contact-thanks-card {
	background: var(--fs-weiss);
	box-shadow: var(--fs-shadow-card);
}

.fs-contact-page-columns,
.fs-contact-thanks-columns {
	align-items: flex-start !important;
	gap: 74px !important;
	margin-bottom: 0 !important;
}

.fs-contact-page-form-col,
.fs-contact-page-info-col,
.fs-contact-thanks-text-col,
.fs-contact-thanks-image-col {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fs-contact-page-form-col {
	padding-right: 8px;
}

.fs-contact-page-info {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.36;
	color: var(--fs-dunkelgrau);
}

.fs-contact-page-info p {
	margin: 0 0 18px;
}

.fs-contact-page-info p:last-child {
	margin-bottom: 0;
}

.fs-contact-page-info strong {
	font-weight: 700;
}

.fs-contact-thanks-card {
	padding: 0 !important;
	overflow: hidden;
}

.fs-contact-thanks-text-col {
	justify-content: center;
	padding: 72px 78px;
}

.fs-contact-thanks-label {
	margin: 0 0 38px !important;
}

.fs-contact-thanks-copy {
	margin: 0 0 36px !important;
}

.fs-contact-thanks-actions {
	gap: 16px !important;
}

.fs-contact-thanks-actions .wp-block-button__link {
	white-space: nowrap;
}

.fs-contact-thanks-image,
.fs-contact-thanks-image img {
	display: block;
	width: 100%;
	height: 100%;
}

.fs-contact-thanks-image {
	margin: 0 !important;
	min-height: 430px;
}

.fs-contact-thanks-image img {
	object-fit: cover;
}

@media (max-width: 1200px) {
	.fs-contact-page-hero .fs-about-hero__subline {
		font-size: 30px !important;
	}

	.fs-contact-page-hero .fs-about-hero__title {
		font-size: 42px !important;
	}
}

@media (max-width: 980px) {
	.fs-contact-page-hero {
		padding-top: 72px !important;
		padding-bottom: 54px !important;
	}

	.fs-contact-page-hero .fs-about-hero__subline {
		font-size: 26px !important;
	}

	.fs-contact-page-hero .fs-about-hero__title {
		font-size: 34px !important;
	}

	.fs-contact-page-columns,
	.fs-contact-thanks-columns {
		flex-direction: column !important;
		gap: 30px !important;
	}

	.fs-contact-page-form-col,
	.fs-contact-page-info-col,
	.fs-contact-thanks-text-col,
	.fs-contact-thanks-image-col {
		flex-basis: 100% !important;
		width: 100%;
	}

	.fs-contact-thanks-text-col {
		padding: 36px 24px;
	}

	.fs-contact-thanks-image {
		min-height: 300px;
	}
}

@media (max-width: 700px) {
	.fs-contact-page-hero .fs-about-hero__subline {
		font-size: 24px !important;
	}

	.fs-contact-page-hero .fs-about-hero__title {
		font-size: 30px !important;
	}

	.fs-contact-page-main,
	.fs-contact-thanks-main {
		padding-left: 14px !important;
		padding-right: 14px !important;
	}
}

/* ============================================================
   Schnellbewerbung 2026
   ============================================================ */

.fs-quickapply-shell {
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

.fs-quickapply-intro {
	text-align: center;
}

.fs-quickapply-intro__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 240px;
	padding: 8px 24px;
	border-radius: 999px;
	background: linear-gradient(180deg, #e30613 0%, #9f0009 100%);
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.04em;
}

.fs-quickapply-intro__title {
	margin: 28px 0 8px;
	color: #e30613;
	font-size: 60px;
	font-weight: 700;
	line-height: 1.1;
	text-transform: uppercase;
}

.fs-quickapply-intro__subtitle {
	margin: 0;
	color: #e30613;
	font-size: 34px;
	font-weight: 300;
	line-height: 1.2;
	text-transform: uppercase;
}

.fs-quickapply-intro__title--neutral {
	color: var(--fs-dunkelgrau);
	font-size: 50px;
}

.fs-quickapply-intro__subtitle--neutral {
	color: #7a7a7a;
	font-size: 22px;
	text-transform: none;
}

.fs-kontakt-form--quickapply {
	max-width: 760px;
	margin: 0 auto;
}

.fs-quickapply-form-inner {
	width: min(100%, 760px);
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

.fs-quickapply-form-wrap {
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

.fs-quickapply-shell > .fs-quickapply-form-wrap {
	max-width: 760px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-quickapply-shell > .fs-quickapply-form-wrap > .fs-kontakt-form--quickapply {
	width: min(100%, 760px);
	max-width: 760px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.fs-kontakt-form--quickapply .fs-kontakt-form__status {
	margin-bottom: 24px;
}

.fs-quickapply-form__section-title {
	margin: 0 0 16px;
	color: var(--fs-dunkelgrau);
	font-size: 33px;
	font-weight: 700;
	line-height: 1.24;
}

.fs-quickapply-form__section-title small {
	font-size: 18px;
	font-weight: 400;
}

.fs-quickapply-form__section-title--spaced {
	margin-top: 52px;
}

.fs-kontakt-form--quickapply .fs-kontakt-form__grid {
	grid-template-columns: 1fr;
	row-gap: 22px;
}

.fs-kontakt-form--quickapply .fs-form-field {
	margin: 0;
}

.fs-kontakt-form--quickapply input,
.fs-kontakt-form--quickapply textarea {
	font-size: 28px;
	padding-bottom: 12px;
}

.fs-kontakt-form--quickapply textarea {
	min-height: 170px;
	padding: 14px;
}

.fs-kontakt-form--quickapply input::placeholder,
.fs-kontakt-form--quickapply textarea::placeholder {
	color: #8e8e8e;
}

.fs-form-field--wide {
	max-width: 100%;
}

.fs-kontakt-form--quickapply .fs-form-field--upload input[type="file"] {
	font-size: 22px;
}

.fs-quickapply-form__upload-hint {
	margin: 8px 0 0;
	font-size: 14px;
	color: #7a7a7a;
}

.fs-kontakt-form--quickapply .fs-kontakt-form__consent-row {
	margin-top: 34px;
}

.fs-kontakt-form--quickapply .fs-form-consent-text {
	font-size: 13px;
}

.fs-quickapply-form__captcha-row {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-top: 18px;
}

.fs-quickapply-form__captcha-row input {
	max-width: 280px;
	border-radius: 999px;
	border: 1px solid #a8a8a8;
	padding: 8px 16px;
	font-size: 16px;
}

.fs-quickapply-form__required-hint {
	font-size: 14px;
	color: #7a7a7a;
}

.fs-kontakt-form--quickapply .fs-quick-application__actions {
	display: flex;
	justify-content: flex-end;
	gap: 16px;
	margin-top: 50px;
}

.fs-quickapply-shell--thanks {
	min-height: 68vh;
}

.fs-quickapply-intro--thanks .fs-quickapply-intro__badge {
	min-width: 0;
	font-size: 13px;
	padding: 7px 18px;
}

.fs-quickapply-intro--thanks .fs-quickapply-intro__title {
	margin-top: 22px;
}

.fs-quickapply-thanks__body {
	margin-top: 68px;
	text-align: center;
}

.fs-quickapply-thanks__body p {
	margin: 0;
	color: var(--fs-dunkelgrau);
	font-size: 28px;
	font-weight: 700;
	line-height: 1.36;
}

.fs-quickapply-thanks__home {
	margin-top: 34px;
}

@media (max-width: 980px) {
	.fs-quickapply-intro__title,
	.fs-quickapply-intro__title--neutral {
		font-size: 44px;
	}

	.fs-quickapply-intro__subtitle {
		font-size: 26px;
	}

	.fs-quickapply-thanks__body {
		margin-top: 54px;
	}

	.fs-quickapply-thanks__body p {
		font-size: 22px;
	}
}

@media (max-width: 700px) {
	.fs-quickapply-shell,
	.fs-quickapply-shell--thanks {
		padding-left: 14px !important;
		padding-right: 14px !important;
	}

	.fs-quickapply-intro__badge {
		font-size: 13px;
		padding: 7px 16px;
		min-width: 0;
	}

	.fs-quickapply-intro__title,
	.fs-quickapply-intro__title--neutral {
		font-size: 34px;
		margin-top: 20px;
	}

	.fs-quickapply-intro__subtitle {
		font-size: 20px;
	}

	.fs-kontakt-form--quickapply .fs-quick-application__actions {
		justify-content: flex-start;
	}

	.fs-quickapply-thanks__body p {
		font-size: 19px;
	}
}

/* ============================================================
   Anfragekorb 2026
   ============================================================ */

.fs-anfragekorb__header {
	padding: 72px 0 48px;
}

.fs-anfragekorb__kicker {
	margin: 0 0 4px;
	font-size: 50px;
	font-weight: 400;
	line-height: 1.2;
	color: #535353;
}

.fs-anfragekorb__title {
	margin: 0;
	font-size: 72px;
	font-weight: 700;
	line-height: 1.1;
	color: #535353;
}

.fs-anfragekorb__items {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.fs-anfragekorb__item {
	display: grid;
	grid-template-columns: 92px 1fr;
	gap: 24px;
	padding: 24px 26px;
	background: #fff;
	border: 1px solid #ebebeb;
	border-radius: 8px;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}

.fs-anfragekorb__thumb-image {
	display: block;
	width: 100%;
	height: 90px;
	object-fit: cover;
	border-radius: 6px;
}

.fs-anfragekorb__topline {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.fs-anfragekorb__item-title {
	margin: 0;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.2;
}

.fs-anfragekorb__item-title a {
	color: var(--fs-dunkelgrau);
	text-decoration: none;
}

.fs-anfragekorb__item-sku,
.fs-anfragekorb__item-meta {
	margin: 6px 0 0;
	font-size: 18px;
	line-height: 1.35;
	color: #555;
}

.fs-anfragekorb__top-actions {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-shrink: 0;
}

.fs-anfragekorb__qty-inline {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.fs-anfragekorb__qty-inline span {
	font-size: 16px;
	font-weight: 700;
	color: #535353;
}

.fs-anfragekorb__qty-inline input {
	width: 60px;
	border: 1px solid #d2d2d2;
	border-radius: 999px;
	padding: 4px 10px;
	font-size: 16px;
	text-align: center;
}

.fs-anfragekorb__remove {
	color: #8b8b8b;
	font-size: 34px;
	text-decoration: none;
	line-height: 1;
}

.fs-anfragekorb__item textarea,
.fs-anfragekorb__footer textarea {
	width: 100%;
	border: 1px solid #d5d5d5;
	border-radius: 4px;
	padding: 12px;
	margin-top: 14px;
	font-size: 17px;
	line-height: 1.4;
	color: #5a5a5a;
}

.fs-anfragekorb__footer {
	margin-top: 42px;
}

.fs-anfragekorb__actions {
	display: flex;
	justify-content: flex-end;
	gap: 14px;
	margin-top: 18px;
}

.fs-anfragekorb__empty {
	padding: 40px 0;
}

@media (max-width: 980px) {
	.fs-anfragekorb__item {
		grid-template-columns: 76px 1fr;
		gap: 16px;
		padding: 18px;
	}

	.fs-anfragekorb__item-title {
		font-size: 20px;
	}
}

@media (max-width: 700px) {
	.fs-anfragekorb__kicker {
		font-size: 34px;
	}

	.fs-anfragekorb__title {
		font-size: 48px;
	}

	.fs-anfragekorb__item {
		grid-template-columns: 1fr;
	}

	.fs-anfragekorb__thumb {
		width: 90px;
	}

	.fs-anfragekorb__topline {
		align-items: flex-start;
		flex-direction: column;
	}

	.fs-anfragekorb__top-actions {
		width: 100%;
		justify-content: space-between;
	}

	.fs-anfragekorb__actions {
		flex-wrap: wrap;
		justify-content: flex-start;
	}
}

/* ============================================================
   Karriere 2026 (Page + Stelle Detail)
   ============================================================ */

.fs-karriere-hero {
	background: linear-gradient(180deg, var(--fs-hellgrau) 0%, var(--fs-hellgrau) 80%, var(--fs-weiss) 80%, var(--fs-weiss) 100%);
}

.fs-karriere-hero__columns,
.fs-karriere-intro__columns,
.fs-karriere-openings__layout,
.fs-karriere-detail-hero__columns,
.fs-karriere-detail-intro__columns,
.fs-karriere-detail-tasks__columns,
.fs-karriere-detail-gallery__top,
.fs-karriere-benefits {
	gap: 32px;
}

.fs-karriere-hero__image,
.fs-karriere-intro__image,
.fs-karriere-media__video-poster,
.fs-karriere-detail-hero__image,
.fs-karriere-detail-gallery .wp-block-image {
	margin: 0;
}

.fs-karriere-hero__image img,
.fs-karriere-intro__image img,
.fs-karriere-media__video-poster img,
.fs-karriere-detail-hero__image img,
.fs-karriere-detail-gallery .wp-block-image img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: 8px;
}

.fs-karriere-intro__image img {
	min-height: 390px;
}

.fs-karriere-media__video-poster {
	max-width: 1087px;
	margin-left: auto;
	margin-right: auto;
}

.fs-karriere-benefit-card {
	background: linear-gradient(135deg, #e30613 0%, #9f0009 100%);
	padding: 34px 28px 28px;
	min-height: 359px;
	box-shadow: var(--fs-shadow-card);
}

.fs-karriere-benefit-card__icon {
	margin: 0 0 22px;
	width: 84px;
}

.fs-karriere-benefit-card__icon img {
	width: 84px;
	height: 84px;
	object-fit: contain;
}

.fs-karriere-benefit-card .wp-block-heading {
	margin: 0 0 10px;
}

.fs-karriere-benefit-card p {
	margin: 0;
}

.fs-karriere-openings__jobs .wp-block-buttons {
	margin: 0;
}

.fs-karriere-openings__list {
	display: flex;
	flex-direction: column;
	row-gap: 14px;
}

.fs-karriere-openings__group {
	margin-bottom: 64px;
}

.fs-karriere-openings__group-title {
	position: relative;
	padding-left: 30px;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--fs-dunkelgrau);
	margin: 0 0 18px;
}

.fs-karriere-openings__group-title::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 16px;
	border: 1.5px solid #e30613;
	border-radius: 50%;
	box-sizing: border-box;
}

.fs-karriere-openings__group-title::after {
	content: "";
	position: absolute;
	left: 4px;
	top: 50%;
	width: 8px;
	height: 1.5px;
	background: #e30613;
	transform: translateY(-50%);
}

.is-style-fs-career-job-row {
	display: block;
	width: 100%;
	margin: 0 !important;
}

.is-style-fs-career-job-row .wp-block-button__link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	width: 100%;
	min-height: 50px;
	padding: 10px 18px;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(180deg, #e30613 0%, #9f0009 100%);
	color: #fff;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.3;
	text-align: left;
	text-decoration: none;
}

.is-style-fs-career-job-row .wp-block-button__link span {
	display: block;
	font-size: 13px;
	font-weight: 300;
	opacity: 0.95;
}

.is-style-fs-career-job-row .wp-block-button__link em {
	font-style: normal;
	font-size: 14px;
	font-weight: 300;
	border: 1px solid rgba(255, 255, 255, 0.8);
	border-radius: 999px;
	padding: 4px 12px;
	white-space: nowrap;
}

.is-style-fs-career-job-row .wp-block-button__link:hover {
	filter: brightness(1.05);
}

.fs-karriere-openings__initiative {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	column-gap: 28px;
	row-gap: 12px;
	max-width: 760px;
	margin-top: 8px;
}

.fs-karriere-openings__initiative .fs-karriere-openings__group-title {
	grid-column: 1 / -1;
	margin-bottom: 2px;
}

.fs-karriere-openings__initiative > .wp-block-paragraph:not(.fs-karriere-openings__group-title) {
	margin: 0;
	max-width: 430px;
}

.fs-karriere-openings__initiative > .wp-block-button {
	align-self: end;
	margin: 0;
}

.fs-karriere-contact-card,
.fs-karriere-info-card {
	background: var(--fs-hellgrau);
	border-radius: 20px;
	padding: 24px;
}

.fs-karriere-contact-card {
	max-width: 398px;
	margin-left: auto;
}

.fs-karriere-contact-card__avatar {
	width: 84px;
	margin: 0 0 14px;
}

.fs-karriere-contact-card__avatar img {
	display: block;
	width: 84px;
	height: 84px;
	object-fit: cover;
	border-radius: 50%;
}

.fs-karriere-contact-card__label {
	font-size: 14px;
	font-weight: 300;
	line-height: 1.36;
	margin: 0;
	color: var(--fs-dunkelgrau);
}

.fs-karriere-contact-card__name {
	font-size: 22px;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 8px;
	color: var(--fs-dunkelgrau);
}

.fs-karriere-contact-card p {
	font-size: 16px;
	line-height: 1.4;
	margin: 0;
	color: var(--fs-dunkelgrau);
}

.fs-karriere-contact-card a,
.fs-karriere-info-card a {
	color: inherit;
	text-decoration: none;
}

.fs-karriere-info-card {
	max-width: 398px;
	margin-left: auto;
}

.fs-karriere-info-card__label {
	font-size: 14px;
	font-weight: 300;
	line-height: 1.36;
	margin: 0 0 8px;
	color: var(--fs-dunkelgrau);
}

.fs-karriere-info-card p {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	margin: 0;
	color: var(--fs-dunkelgrau);
}

.is-style-fs-career-apply .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 398px;
	min-height: 50px;
	margin-top: 22px;
	border-radius: 999px;
	border: 0;
	background: linear-gradient(180deg, #e30613 0%, #9f0009 100%);
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
}

.is-style-fs-career-apply .wp-block-button__link:hover {
	filter: brightness(1.06);
}

.fs-karriere-detail-back {
	display: flex;
	justify-content: flex-end;
}

.fs-karriere-task-list {
	margin: 0;
	padding-left: 20px;
}

.fs-karriere-task-list .wp-block-list-item {
	font-size: 18px;
	line-height: 1.5;
	margin-bottom: 12px;
	color: var(--fs-dunkelgrau);
}

.fs-karriere-contact-card--detail {
	max-width: 398px;
}

@media (max-width: 1200px) {
	.fs-karriere-openings__layout,
	.fs-karriere-detail-intro__columns,
	.fs-karriere-detail-tasks__columns {
		flex-direction: column !important;
	}

	.fs-karriere-contact-card,
	.fs-karriere-info-card,
	.is-style-fs-career-apply .wp-block-button__link {
		max-width: 100%;
		margin-left: 0;
	}
}

@media (max-width: 992px) {
	.fs-karriere-hero__columns,
	.fs-karriere-intro__columns,
	.fs-karriere-detail-hero__columns,
	.fs-karriere-detail-gallery__top,
	.fs-karriere-benefits {
		flex-direction: column !important;
	}

	.fs-karriere-hero__title {
		font-size: 44px !important;
	}

	.fs-karriere-intro__image img {
		min-height: 0;
	}

	.is-style-fs-career-job-row .wp-block-button__link {
		font-size: 16px;
	}
}

@media (max-width: 768px) {
	.fs-karriere-hero,
	.fs-karriere-detail-hero {
		padding-top: 70px !important;
	}

	.fs-karriere-hero__title,
	.fs-karriere-detail-hero .fs-about-hero__title {
		font-size: 34px !important;
	}

	.fs-karriere-openings__group-title {
		font-size: 20px;
	}

	.fs-karriere-intro .wp-block-buttons {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 10px !important;
	}

	.fs-karriere-intro .wp-block-buttons .wp-block-button,
	.fs-karriere-intro .wp-block-buttons .wp-block-button__link {
		width: 100%;
		max-width: 280px;
	}

	.is-style-fs-career-job-row .wp-block-button__link {
		flex-direction: column;
		align-items: flex-start;
		justify-content: center;
		gap: 8px;
		padding: 12px 14px;
		border-radius: 8px;
		min-height: 116px;
	}

	.is-style-fs-career-job-row .wp-block-button__link em {
		align-self: flex-end;
		padding: 3px 10px;
		font-size: 0;
		line-height: 1;
	}

	.is-style-fs-career-job-row .wp-block-button__link em::before {
		content: attr(data-mobile-label);
		font-size: 13px;
	}

	.is-style-fs-career-job-row .wp-block-button__link span {
		width: 100%;
		text-align: left;
	}

	.fs-karriere-openings__initiative {
		grid-template-columns: 1fr;
	}

	.fs-karriere-openings__initiative > .wp-block-button {
		justify-self: start;
	}
}

/* ==========================================================================
   Kompetenzen (Übersicht + Bereichsseiten)
   ========================================================================== */

.fs-kompetenzen-overview {
	padding: 34px 0 96px;
}

.fs-kompetenzen-overview__cards {
	max-width: 1364px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
}

.fs-kompetenzen-overview__card {
	background: #fff;
	box-shadow: var(--fs-shadow-card);
	border-radius: 8px;
	overflow: hidden;
}

.fs-kompetenzen-overview__card-image {
	margin: 0;
	aspect-ratio: 16 / 9;
}

.fs-kompetenzen-overview__card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.fs-kompetenzen-overview__card-body {
	padding: 20px 24px 22px;
}

.fs-kompetenzen-overview__card-title {
	margin: 0 0 14px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-rot);
}

.fs-kompetenzen-overview__card-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.fs-kompetenzen-overview__card-list a {
	color: var(--fs-dunkelgrau);
	text-decoration: none;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.36;
	transition: color var(--fs-transition);
}

.fs-kompetenzen-overview__card-list a:hover {
	color: var(--fs-rot);
}

.fs-kompetenz-area-page {
	padding: 74px 0 110px;
}

.fs-kompetenz-area-hero {
	max-width: 1364px;
	margin: 0 auto;
}

.fs-kompetenz-area-hero__label {
	margin: 0 0 8px;
	font-size: 35px;
	font-weight: 400;
	line-height: 1.2;
	color: #707070;
}

.fs-kompetenz-area-hero__title {
	margin: 0 0 26px;
	font-size: 62px;
	font-weight: 700;
	line-height: 1.08;
	color: #535353;
}

.fs-kompetenz-area-hero__image {
	margin: 0;
}

.fs-kompetenz-area-hero__image img {
	display: block;
	width: 100%;
	height: 520px;
	object-fit: cover;
	border-radius: 0;
}

.fs-kompetenz-area-hero__breadcrumb {
	margin: 12px 0 0;
	font-size: 10px;
	font-weight: 400;
	line-height: 1.3;
	color: #b3b3b3;
}

.fs-kompetenz-detail__inner {
	max-width: 1364px;
	margin: 22px auto 0;
	display: grid;
	grid-template-columns: 320px minmax(0, 1fr);
	gap: 72px;
}

.fs-kompetenz-sidebar__group + .fs-kompetenz-sidebar__group {
	margin-top: 32px;
}

.fs-kompetenz-sidebar__group-title {
	margin: 0 0 12px;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.12;
	color: var(--fs-rot);
}

.fs-kompetenz-sidebar__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.fs-kompetenz-sidebar__link {
	display: inline-block;
	width: 100%;
	border-radius: 999px;
	background: #e0e0e0;
	padding: 9px 16px;
	color: var(--fs-dunkelgrau);
	text-decoration: none;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.25;
	transition: background-color var(--fs-transition), color var(--fs-transition);
}

.fs-kompetenz-sidebar__link:hover {
	background: #d2d2d2;
}

.fs-kompetenz-sidebar__link.is-active {
	background: #cfcfcf;
	color: #4a4a4a;
	font-weight: 700;
}

.fs-kompetenz-detail__title {
	margin: 2px 0 18px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.36;
	color: var(--fs-rot);
}

.fs-kompetenz-detail__text {
	max-width: 640px;
	font-size: 16px;
	line-height: 1.42;
	color: var(--fs-dunkelgrau);
}

.fs-kompetenz-area-page__extras {
	margin-top: 72px;
}

/* Figma behavior: headline + description keep a fixed vertical anchor on all area pages. */
.fs-kompetenz-detail__content {
	padding-top: 68px;
}

.fs-kompetenz-detail__fallback {
	margin: 0;
}

@media (max-width: 1200px) {
	.fs-kompetenzen-overview__cards {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.fs-kompetenz-detail__inner {
		grid-template-columns: 280px minmax(0, 1fr);
		gap: 40px;
	}

	.fs-kompetenz-sidebar__group-title {
		font-size: 28px;
	}

	.fs-kompetenz-sidebar__link {
		font-size: 16px;
	}
}

@media (max-width: 920px) {
	.fs-kompetenzen-overview {
		padding-top: 20px;
	}

	.fs-kompetenzen-overview__cards {
		grid-template-columns: 1fr;
	}

	.fs-kompetenz-area-page {
		padding: 46px 0 76px;
	}

	.fs-kompetenz-detail__inner {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.fs-kompetenz-detail__content {
		padding-top: 0;
	}

	.fs-kompetenz-area-hero__label {
		font-size: 24px;
	}

	.fs-kompetenz-area-hero__title {
		font-size: 38px;
	}

	.fs-kompetenz-area-hero__image img {
		height: 300px;
	}
}
