/* =========================================================
   WGRR / BASIS
   Porto-kompatible Basisdatei
   Namensraum: wgrr-
   Schrift: Dax, ersatzweise Arial/Helvetica
   Hinweise:
   - Mobile First
   - barrierearm
   - sticky Header
   - Porto-freundlich
   - bereinigt und konsolidiert
========================================================= */

:root {
	--wgrr-color-green-dark: rgb(45 90 55);
	--wgrr-color-green-light: rgb(210 225 159);
	--wgrr-color-green-mid: rgb(157 197 57);
	--wgrr-color-yellow: rgb(253 249 161);

	--wgrr-color-white: #ffffff;
	--wgrr-color-black: #111111;
	--wgrr-color-text: #222222;
	--wgrr-color-body: #ececec;
	--wgrr-color-panel: #d7dfad;
	--wgrr-color-card: #d6dfa1;
	--wgrr-color-soft: #ffffff;
	/*--wgrr-color-soft: #f8f6df;*/
	--wgrr-color-border: #d7ce52;
	--wgrr-color-alert: #c61d14;
	--wgrr-color-muted: #4b4b4b;

	--wgrr-font-sans: "daxproregular", Arial, Helvetica, sans-serif;
	--wgrr-font-sans-bold: "daxprobold", Arial, Helvetica, sans-serif;
	--wgrr-font-sans-black: "daxproblack", Arial, Helvetica, sans-serif;
	--wgrr-font-sans-medium: "daxpromedium", Arial, Helvetica, sans-serif;

	--wgrr-radius-xs: clamp(0.18rem, 0.16rem + 0.06vw, 0.26rem);
	--wgrr-radius-s: clamp(0.35rem, 0.31rem + 0.12vw, 0.5rem);
	--wgrr-radius-m: clamp(0.6rem, 0.5rem + 0.22vw, 0.8rem);
	--wgrr-radius-pill: 999rem;

	--wgrr-space-2xs: clamp(0.25rem, 0.23rem + 0.06vw, 0.32rem);
	--wgrr-space-xs: clamp(0.42rem, 0.39rem + 0.1vw, 0.55rem);
	--wgrr-space-s: clamp(0.68rem, 0.62rem + 0.16vw, 0.85rem);
	--wgrr-space-m: clamp(0.95rem, 0.88rem + 0.22vw, 1.15rem);
	--wgrr-space-l: clamp(1.2rem, 1.06rem + 0.42vw, 1.55rem);
	--wgrr-space-xl: clamp(1.65rem, 1.35rem + 0.9vw, 2.3rem);
	--wgrr-space-2xl: clamp(2.15rem, 1.75rem + 1.2vw, 3.05rem);
	--wgrr-space-3xl: clamp(2.8rem, 2.1rem + 1.9vw, 4.2rem);

	--wgrr-text-xs: clamp(0.8rem, 0.78rem + 0.06vw, 0.875rem);
	--wgrr-text-s: clamp(0.9rem, 0.86rem + 0.1vw, 1rem);
	--wgrr-text-m: clamp(0.98rem, 0.95rem + 0.08vw, 1.05rem);
	--wgrr-text-l: clamp(1.08rem, 1rem + 0.25vw, 1.28rem);
	--wgrr-text-xl: clamp(1.45rem, 1.14rem + 0.9vw, 2.1rem);
	--wgrr-text-2xl: clamp(1.8rem, 1.35rem + 1.5vw, 2.95rem);

	--wgrr-container: min(100% - 2rem, 68rem);
	--wgrr-header-max-width: min(100% - 0.75rem, 120rem);

	--wgrr-header-height-normal: clamp(7.4rem, 6.6rem + 2.6vw, 10.6rem);
	--wgrr-header-height-scrolled: clamp(5.6rem, 5.1rem + 1.45vw, 7.4rem);
	--wgrr-header-pad-top: clamp(0.55rem, 0.5rem + 0.2vw, 0.8rem);
	--wgrr-header-pad-bottom: clamp(0.8rem, 0.72rem + 0.25vw, 1rem);

	--wgrr-claim-size: clamp(1.65rem, 1.35rem + 1.75vw, 3.4375rem);
	--wgrr-claim-lineheight: 1.05;
	--wgrr-claim-letterspacing: 0;

	--wgrr-nav-btn-height: clamp(2.05rem, 1.98rem + 0.25vw, 2.35rem);
	--wgrr-nav-btn-font: clamp(0.9rem, 0.86rem + 0.1vw, 0.98rem);

	--wgrr-company-font: clamp(0.8rem, 0.74rem + 0.24vw, 1rem);
	--wgrr-company-font-shrink: clamp(0.75rem, 0.72rem + 0.08vw, 0.82rem);
	--wgrr-meta-font: clamp(0.9rem, 0.82rem + 0.34vw, 1.15rem);
	--wgrr-meta-font-shrink: clamp(0.8rem, 0.76rem + 0.1vw, 0.9rem);

	--wgrr-hero-height: clamp(19rem, 18rem + 24vw, 43rem);

	--wgrr-shadow-soft: 0 0.25rem 1rem rgb(0 0 0 / 0.08);
	--wgrr-shadow-header: 0 0.3rem 1rem rgb(0 0 0 / 0.12);

	--wgrr-left-wave-width: min(512px, 46vw);
	--wgrr-left-wave-width-scrolled: min(390px, 35vw);
	--wgrr-right-wave-width: min(449px, 42vw);
	--wgrr-right-wave-width-scrolled: min(342px, 31vw);
	--wgrr-wave-overhang: 1.875rem;
	--wgrr-wave-overhang-scrolled: 1.35rem;

	--wgrr-transition: 180ms ease;
}

/* =========================================================
   BASIS
========================================================= */

html {
	box-sizing: border-box;
	scroll-behavior: smooth;
}

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

body {
	font-family: var(--wgrr-font-sans);
	font-size: 1rem;
	line-height: 1.5;
	background: #ffffff;
	color: var(--wgrr-color-text);
}

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

.wgrr-site {
	overflow-x: clip;
}

.wgrr-site .container {
	width: var(--wgrr-container);
	margin-inline: auto;
	position: relative;
}

.wgrr-site .container-fluid {
	position: relative;
}

.wgrr-site .section {
	background: transparent;
}

.wgrr-site .row {
	margin-bottom: 0;
}

.wgrr-site h1,
.wgrr-site h2,
.wgrr-site h3,
.wgrr-site h4,
.wgrr-site h5,
.wgrr-site h6,
.wgrr-site p {
	margin-top: 0;
}

.wgrr-site a {
	/*text-decoration-thickness: 0.08em;
	text-underline-offset: 0.1em;*/
	text-decoration: none!important;
}

.nav-link:hover {
  color: var(--wgrr-color-green-dark);
}


.wgrr-site .h-100 {
	height: 100%;
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
	}
}

.visually-hidden {
	position: absolute;
	width: 0.0625rem;
	height: 0.0625rem;
	padding: 0;
	margin: -0.0625rem;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* =========================================================
   BARRIEREARMUT / FOKUS
========================================================= */

.wgrr-skip-link {
	position: absolute;
	inset-inline-start: 1rem;
	inset-block-start: -10rem;
	z-index: 5000;
	padding: 0.7rem 1rem;
	background: var(--wgrr-color-green-dark);
	color: var(--wgrr-color-white);
	text-decoration: none;
	font-weight: 700;
	border-radius: var(--wgrr-radius-s);
}

.wgrr-skip-link:focus {
	inset-block-start: 1rem;
}

.wgrr-site a:focus-visible,
.wgrr-site button:focus-visible,
.wgrr-site summary:focus-visible {
	outline: 0.2rem solid var(--wgrr-color-yellow);
	outline-offset: 0.2rem;
}

/* =========================================================
   HEADER
========================================================= */

.wgrr-header {
	position: fixed;
	top: 1.875rem;
	left: 0;
	z-index: 1000;
	width: 100%;
	min-height: var(--wgrr-header-height-normal);
	padding-block: var(--wgrr-header-pad-top) var(--wgrr-header-pad-bottom);
	background: rgb(255 255 255 / 0.96);
	box-shadow: var(--wgrr-shadow-header);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	isolation: isolate;
	overflow: visible;
	transition:
		top var(--wgrr-transition),
		min-height var(--wgrr-transition),
		padding var(--wgrr-transition),
		background-color var(--wgrr-transition),
		box-shadow var(--wgrr-transition);
}

.wgrr-header__inner {
	width: var(--wgrr-header-max-width);
	min-height: calc(var(--wgrr-header-height-normal) - var(--wgrr-header-pad-top) - var(--wgrr-header-pad-bottom));
	margin-inline: auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	grid-template-areas: "brand middle contact";
	align-items: start;
	gap: clamp(0.8rem, 1.5vw, 2rem);
	transition: min-height var(--wgrr-transition);
}

.wgrr-header__brand,
.wgrr-header__middle,
.wgrr-header__contact {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	text-align: center;
}

.wgrr-header__brand {
	grid-area: brand;
	justify-self: start;
	align-self: start;
	align-items: flex-start;
	text-align: left;
}

.wgrr-header__middle {
	grid-area: middle;
	justify-self: center;
	align-self: start;
	align-items: center;
	width: max-content;
	max-width: min(100%, 44rem);
	z-index: 3;
}

.wgrr-header__contact {
	grid-area: contact;
	justify-self: end;
	align-self: start;
	align-items: flex-end;
	margin-top: 0;
	padding-top: 0;
	text-align: right;
}

.wgrr-header__contact > * {
	margin-top: 0;
}

.wgrr-header__logo-link {
	display: inline-block;
	text-decoration: none;
}

.wgrr-header__logo {
	width: clamp(6.7rem, 6.2rem + 3.8vw, 10.4rem);
	height: auto;
	transition:
		width var(--wgrr-transition),
		margin-top var(--wgrr-transition);
}

.wgrr-header__claim {
	margin: 0 0 1rem;
	font-family: var(--wgrr-font-sans-bold);
	font-size: var(--wgrr-claim-size);
	font-weight: normal;
	line-height: var(--wgrr-claim-lineheight);
	letter-spacing: var(--wgrr-claim-letterspacing);
	color: var(--wgrr-color-green-mid);
	text-align: center;
	text-wrap: balance;
	white-space: nowrap;
	transition: font-size var(--wgrr-transition);
}

.wgrr-header__company {
	margin: 0 0 clamp(0rem, 0.8vw, 1.2rem);
	max-width: 19rem;
	font-size: var(--wgrr-company-font);
	font-weight: 700;
	line-height: 1.2;
	color: #2d2d2d;
	transition:
		font-size var(--wgrr-transition),
		line-height var(--wgrr-transition),
		margin-bottom var(--wgrr-transition);
}

.wgrr-header__meta,
.wgrr-mainnav__list,
.wgrr-footer__list,
.wgrr-mobilemenu__nav-list,
.wgrr-mobilemenu__links,
.wgrr-mobilemenu__meta {
	list-style: none;
	margin: 0;
	padding: 0;
}

.wgrr-header__meta {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.3rem 0.85rem;
	margin-top: 0.25rem;
	transition:
		gap var(--wgrr-transition),
		margin-top var(--wgrr-transition);
}

.wgrr-header__meta-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: var(--wgrr-meta-font);
	font-weight: 800;
	line-height: 1.15;
	color: #0d6b46;
	text-decoration: none;
	transition:
		font-size var(--wgrr-transition),
		gap var(--wgrr-transition),
		line-height var(--wgrr-transition),
		color var(--wgrr-transition);
}

.wgrr-header__meta-link:hover,
.wgrr-header__meta-link:focus-visible {
	color: var(--wgrr-color-green-dark);
}

.wgrr-header__meta-icon {
	display: inline-block;
	flex: 0 0 auto;
	width: 1.125rem;
	height: 1.125rem;
	background-color: var(--wgrr-color-green-dark);
	vertical-align: -0.12em;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-size: contain;
	mask-size: contain;
}

.wgrr-header__meta-icon--phone {
	-webkit-mask-image: url("../img/wgr-img/wgr-icons/wgr-phone-icon.svg");
	mask-image: url("../img/wgr-img/wgr-icons/wgr-phone-icon.svg");
}

.wgrr-header__meta-icon--mail {
	-webkit-mask-image: url("../img/wgr-img/wgr-icons/wgr-mail-icon.svg");
	mask-image: url("../img/wgr-img/wgr-icons/wgr-mail-icon.svg");
}

.wgrr-header__decor {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	overflow: visible;
}

.wgrr-header__wave {
	position: absolute;
	bottom: 0;
	display: block;
	height: auto;
	max-width: none;
	pointer-events: none;
	user-select: none;
	transform: translateY(var(--wgrr-wave-overhang));
	transition:
		width var(--wgrr-transition),
		transform var(--wgrr-transition);
}

.wgrr-header__wave--left {
	left: 0;
	width: var(--wgrr-left-wave-width);
}

.wgrr-header__wave--right {
	right: 0;
	width: var(--wgrr-right-wave-width);
}

/* Zustand: Header geschrumpft */
.wgrr-header.is-scrolled,
.wgrr-header.is-shrunk,
.wgrr-header.wgrr-header--shrink {
	top: 0;
	min-height: var(--wgrr-header-height-scrolled);
	padding-block: 0.45rem 0.6rem;
}

.wgrr-header.is-scrolled .wgrr-header__inner,
.wgrr-header.is-shrunk .wgrr-header__inner,
.wgrr-header.wgrr-header--shrink .wgrr-header__inner {
	min-height: calc(var(--wgrr-header-height-scrolled) - 1.05rem);
	align-items: start;
	padding-top: 0.35rem;
}

.wgrr-header.is-scrolled .wgrr-header__brand,
.wgrr-header.is-scrolled .wgrr-header__middle,
.wgrr-header.is-scrolled .wgrr-header__contact,
.wgrr-header.is-shrunk .wgrr-header__brand,
.wgrr-header.is-shrunk .wgrr-header__middle,
.wgrr-header.is-shrunk .wgrr-header__contact,
.wgrr-header.wgrr-header--shrink .wgrr-header__brand,
.wgrr-header.wgrr-header--shrink .wgrr-header__middle,
.wgrr-header.wgrr-header--shrink .wgrr-header__contact {
	align-self: start;
}

.wgrr-header.is-scrolled .wgrr-header__logo,
.wgrr-header.is-shrunk .wgrr-header__logo,
.wgrr-header.wgrr-header--shrink .wgrr-header__logo {
	width: clamp(5.7rem, 5.4rem + 2vw, 7.8rem);
	margin-top: 0;
}

.wgrr-header.is-scrolled .wgrr-header__claim,
.wgrr-header.is-shrunk .wgrr-header__claim,
.wgrr-header.wgrr-header--shrink .wgrr-header__claim {
	font-size: clamp(1.2rem, 0.98rem + 1vw, 2.1rem);
}

.wgrr-header.is-scrolled .wgrr-header__contact,
.wgrr-header.is-shrunk .wgrr-header__contact,
.wgrr-header.wgrr-header--shrink .wgrr-header__contact {
	margin-top: 0;
	padding-top: 0;
	line-height: 1.12;
}

.wgrr-header.is-scrolled .wgrr-header__company,
.wgrr-header.is-shrunk .wgrr-header__company,
.wgrr-header.wgrr-header--shrink .wgrr-header__company {
	margin-bottom: clamp(0rem, 0.25vw, 0.35rem);
	font-size: var(--wgrr-company-font-shrink);
	line-height: 1.1;
}

.wgrr-header.is-scrolled .wgrr-header__meta,
.wgrr-header.is-shrunk .wgrr-header__meta,
.wgrr-header.wgrr-header--shrink .wgrr-header__meta {
	gap: 0.14rem 0.58rem;
	margin-top: 0.12rem;
}

.wgrr-header.is-scrolled .wgrr-header__meta-link,
.wgrr-header.is-shrunk .wgrr-header__meta-link,
.wgrr-header.wgrr-header--shrink .wgrr-header__meta-link {
	gap: 0.28rem;
	font-size: var(--wgrr-meta-font-shrink);
	line-height: 1;
}

.wgrr-header.is-scrolled .wgrr-header__wave,
.wgrr-header.is-shrunk .wgrr-header__wave,
.wgrr-header.wgrr-header--shrink .wgrr-header__wave {
	transform: translateY(var(--wgrr-wave-overhang-scrolled));
}

.wgrr-header.is-scrolled .wgrr-header__wave--left,
.wgrr-header.is-shrunk .wgrr-header__wave--left,
.wgrr-header.wgrr-header--shrink .wgrr-header__wave--left {
	width: var(--wgrr-left-wave-width-scrolled);
}

.wgrr-header.is-scrolled .wgrr-header__wave--right,
.wgrr-header.is-shrunk .wgrr-header__wave--right,
.wgrr-header.wgrr-header--shrink .wgrr-header__wave--right {
	width: var(--wgrr-right-wave-width-scrolled);
}

/* =========================================================
   HAUPTNAVIGATION
========================================================= */

.wgrr-nav-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.85rem;
	min-height: 2.75rem;
	margin-top: var(--wgrr-space-xs);
	padding: 0.65rem 0.95rem;
	border: 0.125rem solid var(--wgrr-color-green-dark);
	border-radius: var(--wgrr-radius-pill);
	background: var(--wgrr-color-white);
	color: var(--wgrr-color-green-dark);
	font: inherit;
	font-weight: 800;
	cursor: pointer;
}

.wgrr-nav-toggle__label {
	font-size: var(--wgrr-text-s);
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.wgrr-nav-toggle__icon {
	display: inline-grid;
	gap: 0.22rem;
}

.wgrr-nav-toggle__icon span {
	display: block;
	width: 1.2rem;
	height: 0.12rem;
	background: currentColor;
	border-radius: 999rem;
}

.wgrr-mainnav {
	display: none;
	width: 100%;
	margin-top: 0.15rem;
	margin-inline: auto;
}

.wgrr-mainnav.is-open {
	display: block;
}

.wgrr-mainnav__list {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
}

.wgrr-mainnav__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 12rem;
	min-height: var(--wgrr-nav-btn-height);
	padding: 0.45rem 1.1rem;
	border-radius: 0.55rem;
	background: #0a7443;
	color: var(--wgrr-color-white);
	font-size: var(--wgrr-nav-btn-font);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: 0.03em;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	box-shadow: inset 0 -0.08rem 0 rgb(0 0 0 / 0.12);
	transition:
		transform var(--wgrr-transition),
		background-color var(--wgrr-transition);
}

.wgrr-mainnav__link:hover,
.wgrr-mainnav__link:focus-visible {
	background: var(--wgrr-color-green-dark);
	color: var(--wgrr-color-white);
	text-decoration: none !important;
	transform: translateY(-0.0625rem);
}

/* =========================================================
   MOBILE-FLYOUT: GRUNDZUSTAND
========================================================= */

.wgrr-mobile-toggle,
.wgrr-mobilemenu {
	display: none;
}


/* =========================================================
   FOOTER
========================================================= */

.wgrr-footer {
	padding-top: 0.8rem;
	padding-bottom: var(--wgrr-space-l);
}

.wgrr-footer__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.25rem 0.7rem;
	font-size: 0.9rem;
	line-height: 1.4;
}

.wgrr-footer__list li {
	position: relative;
}

/*.wgrr-footer__list li:not(:last-child)::after {
	content: "...";
	margin-inline-start: 0.7rem;
	color: #444444;
}*/

.wgrr-footer__list a {
	color: var(--wgrr-color-black);
	text-decoration: none;
}

.wgrr-footer__list a:hover,
.wgrr-footer__list a:focus-visible {
	text-decoration: underline;
	text-underline-offset: 0.1em;
}

/* =========================================================
   PORTO SCROLL-TO-TOP
========================================================= */

html body .scroll-to-top {
	position: fixed;
	right: 0.625rem;
	bottom: 0;
	z-index: 3000;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 3.125rem;
	min-height: 2.75rem;
	padding: 1.25rem 0;
	border-top: 0.0625rem solid var(--wgrr-color-white);
	border-right: 0.0625rem solid var(--wgrr-color-white);
	border-bottom: 0;
	border-left: 0.0625rem solid var(--wgrr-color-white);
	border-radius: 50% 50% 0 0;
	background: var(--wgrr-color-green-mid);
	color: var(--wgrr-color-white) !important;
	font-size: 1rem;
	line-height: 1;
	text-decoration: none !important;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition:
		opacity 0.3s ease,
		visibility 0.3s ease,
		background-color 0.3s ease;
}

html body .scroll-to-top.visible {
	display: flex !important;
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

html body .scroll-to-top:hover,
html body .scroll-to-top:focus-visible {
	background-color: var(--wgrr-color-green-dark);
	color: var(--wgrr-color-white) !important;
	text-decoration: none !important;
}

html body .scroll-to-top:focus-visible {
	outline: 0.1875rem solid var(--wgrr-color-white);
	outline-offset: 0.1875rem;
}

html body .scroll-to-top i,
html body .scroll-to-top svg,
html body .scroll-to-top::before {
	color: var(--wgrr-color-white) !important;
	fill: var(--wgrr-color-white) !important;
}


/* =========================================================
   TABLET AB 768PX
========================================================= */

@media (min-width: 48rem) {
	.wgrr-header__inner {
		grid-template-columns: 10.5rem 1fr 17rem;
		gap: 0.8rem 1rem;
		align-items: start;
	}

	.wgrr-header__brand {
		justify-content: flex-start;
		padding-top: 0.15rem;
	}

	.wgrr-header__middle {
		justify-content: flex-start;
	}

	.wgrr-header__contact {
		justify-content: flex-start;
		padding-top: 0.2rem;
	}

	.wgrr-nav-toggle {
		display: none;
	}

	.wgrr-mainnav {
		display: block;
		width: auto;
	}

	.wgrr-mainnav__list {
		flex-direction: row;
		flex-wrap: nowrap;
		gap: 0.55rem;
	}

	.wgrr-mainnav__link {
		min-width: 0;
		padding-inline: 1.2rem;
	}
}

/* =========================================================
   IPAD / TABLET BIS 1194PX
========================================================= */

@media (min-width: 48rem) and (max-width: 74.625rem) {
	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__company {
		font-size: clamp(0.76rem, 0.72rem + 0.12vw, 0.86rem);
		line-height: 1.2;
		margin-bottom: clamp(0.14rem, 0.2vw, 0.3rem);
	}

	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__meta {
		gap: 0.08rem 0.36rem;
		margin-top: 0.04rem;
	}

	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__meta-link {
		gap: 0.22rem;
		font-size: clamp(0.82rem, 0.78rem + 0.12vw, 0.92rem);
		line-height: 1.18;
	}

	.wgrr-header.is-scrolled .wgrr-header__company,
	.wgrr-header.is-shrunk .wgrr-header__company,
	.wgrr-header.wgrr-header--shrink .wgrr-header__company {
		font-size: clamp(0.74rem, 0.7rem + 0.1vw, 0.82rem);
		line-height: 1.18;
		margin-bottom: 0.16rem;
	}

	.wgrr-header.is-scrolled .wgrr-header__meta,
	.wgrr-header.is-shrunk .wgrr-header__meta,
	.wgrr-header.wgrr-header--shrink .wgrr-header__meta {
		gap: 0.08rem 0.36rem;
		margin-top: 0.02rem;
	}

	.wgrr-header.is-scrolled .wgrr-header__meta-link,
	.wgrr-header.is-shrunk .wgrr-header__meta-link,
	.wgrr-header.wgrr-header--shrink .wgrr-header__meta-link {
		gap: 0.22rem;
		font-size: clamp(0.8rem, 0.76rem + 0.1vw, 0.88rem);
		line-height: 1.16;
	}

	.wgrr-header__wave--left {
		width: calc(var(--wgrr-left-wave-width) * 0.65);
	}

	.wgrr-header__wave--right {
		width: calc(var(--wgrr-right-wave-width) * 0.65);
	}

	.wgrr-header.is-scrolled .wgrr-header__wave--left,
	.wgrr-header.is-shrunk .wgrr-header__wave--left,
	.wgrr-header.wgrr-header--shrink .wgrr-header__wave--left {
		width: calc(var(--wgrr-left-wave-width-scrolled) * 0.65);
	}

	.wgrr-header.is-scrolled .wgrr-header__wave--right,
	.wgrr-header.is-shrunk .wgrr-header__wave--right,
	.wgrr-header.wgrr-header--shrink .wgrr-header__wave--right {
		width: calc(var(--wgrr-right-wave-width-scrolled) * 0.65);
	}
}


/* =========================================================
   DESKTOP AB 1024PX
========================================================= */

@media (min-width: 64rem) {
	.wgrr-header__inner {
		grid-template-columns: 12rem minmax(30rem, 1fr) 20.5rem;
		padding-top: clamp(0.45rem, 0.35rem + 0.25vw, 0.75rem);
	}

	.wgrr-header__logo {
		width: clamp(7.8rem, 8.5rem + 4vw, 12rem);
		margin-top: -1rem;
	}

	.wgrr-header__claim {
		font-size: clamp(2rem, 1.45rem + 1.55vw, 3.15rem);
	}

	.wgrr-mainnav__list {
		gap: 0.7rem;
	}

	.wgrr-mainnav__link {
		min-height: 2.2rem;
		padding-inline: 1.45rem;
		border-radius: 0.5rem;
		font-size: 1.375rem;
	}
}

/* =========================================================
   DESKTOP AB 1440PX
========================================================= */

@media (min-width: 90rem) {
	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__company {
		font-size: clamp(0.76rem, 0.7rem + 0.18vw, 0.92rem);
		line-height: 1.14;
		margin-bottom: clamp(0.28rem, 0.34vw, 0.62rem);
	}

	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__meta {
		gap: 0.14rem 0.58rem;
		margin-top: 0.08rem;
	}

	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__meta-link {
		gap: 0.3rem;
		font-size: clamp(0.82rem, 0.76rem + 0.2vw, 1rem);
		line-height: 1.05;
	}

	.wgrr-header.is-scrolled .wgrr-header__company,
	.wgrr-header.is-shrunk .wgrr-header__company,
	.wgrr-header.wgrr-header--shrink .wgrr-header__company {
		font-size: clamp(0.76rem, 0.72rem + 0.1vw, 0.86rem);
		line-height: 1.18;
		margin-bottom: 0.18rem;
	}

	.wgrr-header.is-scrolled .wgrr-header__meta,
	.wgrr-header.is-shrunk .wgrr-header__meta,
	.wgrr-header.wgrr-header--shrink .wgrr-header__meta {
		gap: 0.1rem 0.42rem;
		margin-top: 0.02rem;
	}

	.wgrr-header.is-scrolled .wgrr-header__meta-link,
	.wgrr-header.is-shrunk .wgrr-header__meta-link,
	.wgrr-header.wgrr-header--shrink .wgrr-header__meta-link {
		gap: 0.24rem;
		font-size: clamp(0.82rem, 0.78rem + 0.12vw, 0.92rem);
		line-height: 1.16;
	}
}


/* =========================================================
   GROSSE DESKTOPS AB 1280PX
========================================================= */

@media (min-width: 80rem) {
	.wgrr-header__inner {
		grid-template-columns: 12.5rem minmax(34rem, 1fr) 21rem;
	}
}

/* =========================================================
   MOBILE BIS 767PX
========================================================= */

@media (max-width: 47.99875rem) {
	/* Header läuft auf Phones normal mit der Seite mit. */
	.wgrr-header,
	.wgrr-header.is-scrolled,
	.wgrr-header.is-shrunk,
	.wgrr-header.wgrr-header--shrink {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
		width: 100%;
		min-height: auto;
		transform: none !important;
		box-shadow: var(--wgrr-shadow-header);
		overflow: visible !important;
	}

	.wgrr-header.is-scrolled,
	.wgrr-header.is-shrunk,
	.wgrr-header.wgrr-header--shrink {
		padding-block: var(--wgrr-header-pad-top) var(--wgrr-header-pad-bottom);
	}

	body {
		padding-top: 0 !important;
	}

	.wgrr-header__inner,
	.wgrr-header.is-scrolled .wgrr-header__inner,
	.wgrr-header.is-shrunk .wgrr-header__inner,
	.wgrr-header.wgrr-header--shrink .wgrr-header__inner {
		width: min(100% - 1.5rem, 48rem);
		min-height: 0;
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-areas:
			"brand toggle"
			"middle middle";
		align-items: start;
		justify-items: stretch;
		gap: 0.4rem 0.8rem;
		padding-top: 0;
	}

	.wgrr-header__brand,
	.wgrr-header.is-scrolled .wgrr-header__brand,
	.wgrr-header.is-shrunk .wgrr-header__brand,
	.wgrr-header.wgrr-header--shrink .wgrr-header__brand {
		grid-area: brand;
		justify-self: start;
		align-self: start;
		align-items: flex-start;
		text-align: left;
	}

	.wgrr-header__middle,
	.wgrr-header.is-scrolled .wgrr-header__middle,
	.wgrr-header.is-shrunk .wgrr-header__middle,
	.wgrr-header.wgrr-header--shrink .wgrr-header__middle {
		grid-area: middle;
		justify-self: center;
		align-self: start;
		width: 100%;
		max-width: 100%;
	}

	.wgrr-header__contact,
	.wgrr-header__decor,
	.wgrr-mainnav,
	.wgrr-nav-toggle,
	.wgrr-header__wave {
		display: none !important;
	}

	.wgrr-header__logo,
	.wgrr-header.is-scrolled .wgrr-header__logo,
	.wgrr-header.is-shrunk .wgrr-header__logo,
	.wgrr-header.wgrr-header--shrink .wgrr-header__logo {
		width: clamp(8.2rem, 7.8rem + 2vw, 10.5rem);
		height: auto;
		margin-top: 0;
	}

	.wgrr-header__claim,
	.wgrr-header.is-scrolled .wgrr-header__claim,
	.wgrr-header.is-shrunk .wgrr-header__claim,
	.wgrr-header.wgrr-header--shrink .wgrr-header__claim {
		margin: 0;
		font-size: clamp(1.5rem, 1.3rem + 0.9vw, 2.05rem);
		line-height: 1.08;
		text-align: center;
		color: var(--wgrr-color-green-mid);
		text-wrap: balance;
		white-space: normal;
	}

	.wgrr-mobile-toggle {
		grid-area: toggle;
		justify-self: end;
		align-self: start;
		display: inline-block;
		width: 2.75rem;
		height: 2.75rem;
		margin: clamp(0.45rem, 0.35rem + 0.4vw, 0.75rem) 0.6rem 0 0;
		padding: 0;
		border: 0;
		background-color: transparent;
		background-image: url("../img/wgr-img/wgr-icons/hamburger-icon.svg") !important;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: contain;
		box-shadow: none;
		appearance: none;
		-webkit-appearance: none;
		cursor: pointer;
		-webkit-mask: none !important;
		mask: none !important;
	}

	.wgrr-mobile-toggle:hover,
	.wgrr-mobile-toggle:focus,
	.wgrr-mobile-toggle:active {
		border: 0;
		background-color: transparent;
		box-shadow: none;
	}

	/* Wichtig: global ist .wgrr-mobilemenu auf display:none gesetzt.
	   Auf Phones muss das Menü im geöffneten Zustand wieder sichtbar werden. */
	.wgrr-mobilemenu {
		position: fixed;
		inset: 0;
		z-index: 3000;
		display: block;
		width: 100%;
		height: 100vh;
		height: 100dvh;
		max-height: 100vh;
		max-height: 100dvh;
		overflow-y: auto;
		background: var(--wgrr-color-white);
		-webkit-overflow-scrolling: touch;
	}

	.wgrr-mobilemenu[hidden],
	.wgrr-mobilemenu[aria-hidden="true"] {
		display: none !important;
	}

	.wgrr-mobilemenu__dialog {
		display: flex;
		flex-direction: column;
		min-height: 100vh;
		min-height: 100dvh;
		padding:
			max(1rem, env(safe-area-inset-top))
			1.5rem
			max(1rem, env(safe-area-inset-bottom))
			1.5rem;
		box-sizing: border-box;
	}

	.wgrr-mobilemenu__top {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
		gap: 1rem;
	}

	.wgrr-mobilemenu__logo-link {
		display: inline-block;
		text-decoration: none;
	}

	.wgrr-mobilemenu__logo {
		width: clamp(8.5rem, 8rem + 2vw, 10.8rem);
		height: auto;
	}

	.wgrr-mobilemenu__close {
		flex: 0 0 auto;
		display: block;
		width: 2.75rem;
		height: 2.75rem;
		margin: clamp(0.25rem, 0.2rem + 0.3vw, 0.5rem) 0.6rem 0 auto;
		padding: 0;
		border: 0;
		line-height: 1;
		background-color: transparent;
		background-image: url("../img/wgr-img/wgr-icons/close-icon.svg") !important;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: contain;
		box-shadow: none;
		appearance: none;
		-webkit-appearance: none;
		cursor: pointer;
		-webkit-mask: none !important;
		mask: none !important;
	}

	.wgrr-mobilemenu__close:hover,
	.wgrr-mobilemenu__close:focus,
	.wgrr-mobilemenu__close:active {
		border: 0;
		background-color: transparent;
		box-shadow: none;
	}

	.wgrr-mobilemenu__claim {
		margin: clamp(0.7rem, 0.62rem + 0.4vw, 1rem) 0 0;
		font-family: var(--wgrr-font-sans-bold);
		font-size: clamp(1.45rem, 1.25rem + 0.9vw, 2rem);
		font-weight: normal;
		line-height: 1.12;
		text-align: center;
		color: var(--wgrr-color-green-mid);
		text-wrap: balance;
	}

	.wgrr-mobilemenu__nav {
		margin-top: clamp(1.6rem, 1.4rem + 1vw, 2.2rem);
	}

	.wgrr-mobilemenu__nav-list {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 1rem;
		width: 100%;
	}

	.wgrr-mobilemenu__nav-list li {
		width: min(80%, 28rem);
	}

	.wgrr-mobilemenu__nav-link {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		min-height: clamp(3.5rem, 3.2rem + 1vw, 4rem);
		padding: 0.8rem 1rem;
		border-radius: 1rem;
		background: #0d7c47;
		color: var(--wgrr-color-white);
		font-family: var(--wgrr-font-sans);
		font-size: clamp(1.35rem, 1.2rem + 0.6vw, 1.75rem);
		font-weight: normal;
		line-height: 1.18;
		letter-spacing: 0.01em;
		text-align: center;
		text-decoration: none !important;
		text-transform: uppercase;
	}

	.wgrr-mobilemenu__nav-link:hover,
	.wgrr-mobilemenu__nav-link:focus-visible {
		background: var(--wgrr-color-green-dark);
		color: var(--wgrr-color-white);
		text-decoration: none !important;
	}

	.wgrr-mobilemenu__links {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: clamp(0.9rem, 0.8rem + 0.5vw, 1.2rem);
		margin-top: clamp(1.8rem, 1.6rem + 1vw, 2.4rem);
		text-align: center;
	}

	.wgrr-mobilemenu__links a {
		color: #0d7c47;
		font-size: clamp(1.05rem, 0.98rem + 0.45vw, 1.35rem);
		font-weight: 400;
		line-height: 1.35;
		text-decoration: none;
	}

	.wgrr-mobilemenu__links a:hover,
	.wgrr-mobilemenu__links a:focus-visible {
		text-decoration: underline;
		text-underline-offset: 0.12em;
	}

	.wgrr-mobilemenu__contact {
		margin-top: auto;
		padding-top: 2rem;
		text-align: center;
	}

	.wgrr-mobilemenu__address {
		margin: 0 0 1rem;
		font-family: var(--wgrr-font-sans-bold);
		font-size: clamp(0.98rem, 0.92rem + 0.25vw, 1.15rem);
		font-weight: normal;
		line-height: 1.3;
		color: var(--wgrr-color-black);
	}

	.wgrr-mobilemenu__meta {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 0.75rem 1.2rem;
	}

	.wgrr-mobilemenu__meta a {
		display: inline-flex;
		align-items: center;
		gap: 0.45rem;
		color: #0d7c47;
		font-family: var(--wgrr-font-sans-bold);
		font-size: clamp(0.95rem, 0.88rem + 0.3vw, 1.1rem);
		font-weight: normal;
		line-height: 1.25;
		text-decoration: none;
	}

	.wgrr-mobilemenu__meta img {
		width: 1.6rem;
		height: 1.6rem;
	}

	body.wgrr-mobilemenu-open {
		overflow: hidden;
	}
}


/* =========================================================
   ZUSATZ: ZUGAENGLICHKEIT / RESPONSIVE FEINABSTIMMUNG
========================================================= */

@media (max-width: 47.99875rem) {
	.wgrr-mobile-toggle,
	.wgrr-mobilemenu__close,
	html body .scroll-to-top {
		min-width: 2.75rem;
		min-height: 2.75rem;
	}

	.wgrr-mobilemenu__nav-link {
		min-height: 3.25rem;
	}
}

@media (forced-colors: active) {
	.wgrr-site a:focus-visible,
	.wgrr-site button:focus-visible,
	.wgrr-site summary:focus-visible,
	html body .scroll-to-top:focus-visible {
		outline: 0.2rem solid CanvasText;
		outline-offset: 0.2rem;
	}
}


/* =========================================================
   HEADER-FEINSCHLIFF
   zentrierter Mittelbereich, kleinere Wellen, iPad-Claim
========================================================= */

@media (min-width: 64rem) {
	.wgrr-header__inner,
	.wgrr-header.is-scrolled .wgrr-header__inner,
	.wgrr-header.is-shrunk .wgrr-header__inner,
	.wgrr-header.wgrr-header--shrink .wgrr-header__inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) max-content minmax(0, 1fr);
		grid-template-areas: "brand middle contact";
		align-items: start;
		width: var(--wgrr-header-max-width);
		margin-inline: auto;
	}

	.wgrr-header__brand,
	.wgrr-header.is-scrolled .wgrr-header__brand,
	.wgrr-header.is-shrunk .wgrr-header__brand,
	.wgrr-header.wgrr-header--shrink .wgrr-header__brand {
		grid-area: brand;
		justify-self: start;
		align-self: start;
	}

	.wgrr-header__contact,
	.wgrr-header.is-scrolled .wgrr-header__contact,
	.wgrr-header.is-shrunk .wgrr-header__contact,
	.wgrr-header.wgrr-header--shrink .wgrr-header__contact {
		grid-area: contact;
		justify-self: end;
		align-self: start;
	}

	.wgrr-header__middle,
	.wgrr-header.is-scrolled .wgrr-header__middle,
	.wgrr-header.is-shrunk .wgrr-header__middle,
	.wgrr-header.wgrr-header--shrink .wgrr-header__middle {
		grid-area: middle;
		position: relative;
		inset: auto;
		transform: none;
		justify-self: center;
		align-self: start;
		display: flex;
		flex-direction: column;
		align-items: center;
		width: max-content;
		max-width: min(58vw, 56rem);
		text-align: center;
	}

	.wgrr-header__claim,
	.wgrr-header.is-scrolled .wgrr-header__claim,
	.wgrr-header.is-shrunk .wgrr-header__claim,
	.wgrr-header.wgrr-header--shrink .wgrr-header__claim {
		display: block;
		width: 100%;
		margin-inline: auto;
		text-align: center;
		white-space: nowrap;
	}

	.wgrr-mainnav,
	.wgrr-header.is-scrolled .wgrr-mainnav,
	.wgrr-header.is-shrunk .wgrr-mainnav,
	.wgrr-header.wgrr-header--shrink .wgrr-mainnav {
		display: flex;
		justify-content: center;
		width: 100%;
		margin-inline: auto;
	}

	.wgrr-mainnav__list {
		display: flex;
		align-items: center;
		justify-content: center;
		width: auto;
		margin-inline: auto;
	}
}

/* Bogen-SVGs im Header dezent verkleinern. */
.wgrr-header__wave--left {
	width: calc(var(--wgrr-left-wave-width) * 0.8);
}

.wgrr-header__wave--right {
	width: calc(var(--wgrr-right-wave-width) * 0.8);
}

.wgrr-header.is-scrolled .wgrr-header__wave--left,
.wgrr-header.is-shrunk .wgrr-header__wave--left,
.wgrr-header.wgrr-header--shrink .wgrr-header__wave--left {
	width: calc(var(--wgrr-left-wave-width-scrolled) * 0.7);
}

.wgrr-header.is-scrolled .wgrr-header__wave--right,
.wgrr-header.is-shrunk .wgrr-header__wave--right,
.wgrr-header.wgrr-header--shrink .wgrr-header__wave--right {
	width: calc(var(--wgrr-right-wave-width-scrolled) * 0.7);
}

/* iPad bis 1180px: Claim im normalen Header reduziert. */
@media (min-width: 48rem) and (max-width: 73.75rem) {
	.wgrr-header:not(.is-scrolled):not(.is-shrunk):not(.wgrr-header--shrink) .wgrr-header__claim {
		font-size: clamp(1.24rem, 1.01rem + 1.31vw, 2.58rem);
		line-height: 1.08;
	}
}



/* =========================================================
   MOBILE TYPOGRAFIE BASIS
   Nur Schriftgroessen und Zeilenhoehen bis 767px
========================================================= */

@media (max-width: 47.99875rem) {
	body {
		font-size: 1rem;
		line-height: 1.5;
	}

	.wgrr-header__claim,
	.wgrr-header.is-scrolled .wgrr-header__claim,
	.wgrr-header.is-shrunk .wgrr-header__claim,
	.wgrr-header.wgrr-header--shrink .wgrr-header__claim {
		font-size: 1.24rem;
		line-height: 1.1;
		margin-top:0.9rem;
	}

	.wgrr-mobilemenu__claim {
		font-size: 1.24rem;
		line-height: 1.1;
	}

	.wgrr-mobilemenu__nav-link {
		font-size: clamp(1.18rem, 1.05rem + 0.55vw, 1.5rem);
		line-height: 1.2;
		font-family: var(--wgrr-font-sans-medium);
		font-weight: normal;
	}

	.wgrr-mobilemenu__links a {
		font-size: clamp(1rem, 0.94rem + 0.3vw, 1.18rem);
		line-height: 1.35;
	}

	.wgrr-mobilemenu__address {
		font-size: clamp(0.95rem, 0.9rem + 0.22vw, 1.08rem);
		line-height: 1.32;
	}

	.wgrr-mobilemenu__meta a {
		font-size: clamp(0.92rem, 0.86rem + 0.25vw, 1.02rem);
		line-height: 1.28;
	}

	.wgrr-footer__list {
		font-size: clamp(0.9rem, 0.86rem + 0.2vw, 0.98rem);
		line-height: 1.45;
	}
}

/* =========================================================
   WGRR CONTENT-LINKS
   Porto-/Bootstrap-Linkzustände zentral überschreiben
========================================================= */

.main a:visited,
.main a:focus,
.main a:focus-visible,
.main a:active {
	color: inherit !important;
	background-color: transparent;
}