










@font-face {
	font-family: "GT-America-Condensed-Bold";
	src: url("/assets/fonts/GT-America-Condensed-Bold.woff2") format("woff2");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "GT-America-Condensed-Bold-Italic";
	src: url("/assets/fonts/GT-America-Condensed-Bold-Italic.woff2") format("woff2");
	font-weight: 700;
	font-style: italic;
	font-display: swap;
}

@font-face {
	font-family: "GT-America-Standard-Medium";
	src: url("/assets/fonts/GT-America-Standard-Medium.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "GT-America-Standard-Regular";
	src: url("/assets/fonts/GT-America-Standard-Regular.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "GT-America-Standard-Italic";
	src: url("/assets/fonts/GT-America-Standard-Regular-Italic.woff2") format("woff2");
	font-weight: 400;
	font-style: italic;
	font-display: swap;
}






:root {


	--black: #000000;
	--white: #FFFFFF;
	--blue: #2200FF;
	--orange: #FF5000;
	--green: #53FE7A;
	--pink: #FCBAFC;


	--regular: "GT-America-Standard-Regular";
	--italic: "GT-America-Standard-Italic";
	--medium: "GT-America-Standard-Medium";
	--condensed: "GT-America-Condensed-Bold";
	--condensed-italic: "GT-America-Condensed-Bold-Italic";


	--xxl: 3rem;
	--xl: 1.75rem;
	--l: 1.5rem;
	--m: 1.25rem;
	--s: 0.9375rem;



	--u-stroke: 3;
	--u-gap: 22;
	--u-color: currentColor;

}

	@media (min-width: 1000px) {

		:root  {
			--xxl: 5rem;
			--xl: 5rem;
			--l: 3rem;
			--m: 1.5rem;
		}

	}






html, body {
  overscroll-behavior: none;
}

body {
	font-family: var(--regular);
	font-size: 1.25rem;
	line-height: 1.25;
	color: var(--blue);
	background-color: var(--white);
	overflow-x: hidden;
}

:focus,
:focus-visible {
	outline: none;
}

::selection {
	background: var(--blue);
	color: var(--white);
}


i, em {
	font-style: italic;
}

b, strong {
	font-family: var(--condensed);
}





.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	z-index: 100;
	padding: 20px 20px 20px 16px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background-color: var(--white);
}

@media (min-width: 1000px) {

	.site-header {
		padding: 20px 60px 20px 40px;
	}

}



.site-header::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	height: 100%;
	background: linear-gradient(
		to bottom,
		var(--white) 0%,
		transparent 100%
	);
	pointer-events: none;
}

@media (min-width: 1000px) {

.site-header::after {
	top: 100%;
	height: 30%;
}

}



.site-header__logo {
	transform: rotate(0);
	transition: transform 0.5s ease-in-out;
}

.site-header__logo:hover {
	transform: rotate(-360deg);
}

.site-header__logo svg {
	display: block;
	height: 48px;
	width: auto;
}

@media (min-width: 1000px) {

	.site-header__logo svg {
		height: 64px;
	}

}


.site-header__logo svg path {
	fill: var(--orange);
}



.site-header__actions {
	display: flex;
	justify-content: flex-end;
	gap: 20px;
}

@media (min-width: 1000px) {

	.site-header__actions {
		gap: 40px;
	}

}



.site-header__button {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transform: rotate(0);
	transition: transform 0.5s ease-in-out;
}

.site-header__button:hover {
	transform: rotate(-360deg);
}



.site-header__button svg {
	display: block;
	height: 32px;
	width: auto;
}

@media (min-width: 1000px) {

	.site-header__button svg {
		height: 36px;
	}

}

.site-header__button svg .st1,
.site-header__button svg path {
	fill: var(--orange);
}





.site-menu {
  width: calc(100vw - 40px);

  height: 100vh;

  height: 100dvh;
  background-color: var(--orange);
  z-index: 150;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 0;
  font-family: var(--condensed);
  font-size: var(--xxl);
  color: var(--white);
  margin-left: 40px;
  padding: 70px 30px 30px 30px;
  transform: translateX(100%);
  transition: transform 0.5s ease-in-out !important;
  will-change: transform;
  pointer-events: none;
}

@media (min-width: 600px) {
	.site-menu {
		width: 75vw;
		margin-left: 25vw;
	}
}

@media (min-width: 720px) {
	.site-menu {
		width: 50vw;
		margin-left: 50vw;
	}
}

@media (min-width: 1500px) {
	.site-menu {
		width: 25vw;
		margin-left: 75vw;
	}
}

.site-menu.is-open {
  transform: translateX(0);
  pointer-events: auto;
}

.is-locked {
  overflow: hidden;
  touch-action: none;
}



.site-menu__close {
	position: absolute;
	top: 20px;
	right: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transform: rotate(0);
	transition: transform 0.5s ease-in-out;
}

.site-menu__close svg {
  display: block;
  height: 32px;
  width: auto;
  color: var(--white);
}

.site-menu__close svg path {
  fill: none;
  stroke: currentColor;
  stroke-width: 3.5px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-menu__close:hover {
	transform: rotate(-360deg);
}



.site-menu__nav {
	list-style: none;
	padding: 0;
	margin-inline: 0;
}



.site-menu__item {
	font-size: var(--xxl);
	padding: 0 0 26px 0;
	color: var(--white);
}

@media (min-width: 1000px) {

	.site-menu__item {
		font-size: var(--l);
	}

}

.site-menu__link {
	position: relative;
	display: inline-block;
	text-decoration: none;
	color: var(--white);
	left: 0;
	transition: left 0.25s ease-in-out;
}

.site-menu__link:hover {
	cursor: pointer;
	left: 20px;
}



.site-menu__link svg,
.site-menu__link img {
	height: 40px;
	width: auto;
	display: inline-block;
	position: relative;
	top: 5px;
	padding: 0 4px 0 0;
}



.site-menu__social-list {
	display: flex;
	align-items: center;
	gap: 20px;
	list-style: none;
	margin: 0;
	padding: 0;

}

.site-menu__social-item {
	transform: rotate(0);
	transition: transform 0.5s ease-in-out;
}


.site-menu__social-item:hover {
	transform: rotate(-360deg);
}

.site-menu__social-list svg {
	display: flex;
	align-items: center;
	gap: 24px;
	width: auto;
	height: 35px;
}



.site-menu :focus-visible {
	
}





.site-main {
	padding: 151px 20px 52px 20px;
	min-height: calc(100vh - 309px);
}

@media (min-width: 1000px) {

	.site-main {
		padding: 180px 60px 52px 60px;
		min-height: calc(100vh - 198px);
	}

}

.site-main--home {
	padding: 60px 20px 40px 20px;
}

@media (min-width: 1000px) {

	.site-main--home {
		padding: 60px 60px 52px 60px;
	}

}

.site-main--about-us {
	padding: 151px 20px 0 20px;
}

@media (min-width: 1000px) {

	.site-main--about-us {
		padding: 180px 60px 0 60px;
	}

}

.site-main--topics  {
	padding: 151px 20px 0 20px;
}

@media (min-width: 1000px) {

	.site-main--topics  {
		padding: 180px 20px 0 20px;
	}

}

.site-main--topics_article {
	padding: 160px 20px 52px 20px;
}

@media (min-width: 1000px) {

	.site-main--topics_article {
		padding: 130px 60px 70px 60px;
	}

}

.site-main--activities {
	background-color: var(--blue);
}

@media (min-width: 1000px) {

	.site-main--activities  {
		padding: 180px 60px 0 60px;
	}

}

.site-main--activities_activity {
	padding: 160px 20px 52px 20px;
}

@media (min-width: 1000px) {

	.site-main--activities_activity {
		padding: 130px 60px 52px 60px;
	}

}

.site-main--participate {
	padding: 151px 20px 0 20px;
	background-color: var(--green);
}

@media (min-width: 1000px) {

	.site-main--participate {
		padding: 180px 0 0 0;
	}

}

.site-main--search {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

@media (min-width: 1000px) {

	.site-main--search {
		padding: 180px 0 52px 0;
	}

}

.site-main--legal {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

@media (min-width: 1000px) {

	.site-main--legal {
		padding: 180px 0 52px 0;
	}

}

.site-main--contact {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

@media (min-width: 1000px) {

	.site-main--contact {
		padding: 180px 0 52px 0;
	}

}





.site-footer {
	padding: 30px 20px 30px 20px;
	background-color: var(--orange);
}

@media (min-width: 1200px) {

	.site-footer {
		padding: 30px 60px 30px 60px;
		background-color: var(--orange);
		display: flex;
		gap: 248px;
		align-items: center;
	}

}

.site-footer__heading {
	text-transform: uppercase;
	font-size: var(--s);
	color: var(--white);
	padding: 0 0 29px 0;
}



.site-footer__social-list {
	display: flex;
	align-items: center;
	gap: 20px;
	list-style: none;
	padding: 0 0 30px 0;
}

.site-footer__social-item {
	display: flex;
	align-items: center;
	gap: 24px;
	width: auto;
	height: 35px;
	transform: rotate(0);
	transition: transform 0.5s ease-in-out;
}

.site-footer__social-item:hover {
	transform: rotate(-360deg);
}

.site-footer__social-link {}

.site-footer__social-link:hover,
.site-footer__social-link:focus-visible {}
.site-footer__social-link svg {}



.site-footer__legal-list {

	list-style: none;
	font-family: var(--regular);
	font-size: var(--s);


	--u-color: var(--white);
	--u-stroke: 2;
	--u-gap: 14;

}

.site-footer__legal-item {
	padding: 0 0 5px 0;
	position: relative;
	left: 0;
	transition: left 0.5s ease-in-out;
}

.site-footer__legal-item:hover {
	left: 10px;
}

.site-footer__legal-link {
	color: var(--white);
}

.site-footer__legal-link:hover,
.site-footer__legal-link:focus-visible {
	
}

@media (min-width: 1200px) {
	
	.site-footer {
		display: grid;
		grid-template-columns: 1fr 3fr;
		grid-template-areas:
			"heading heading" 
			"social legal";
		column-gap: 80px;
		row-gap: 24px;
		align-items: start;
		padding: 60px 60px 60px 60px;
		background-color: var(--orange);
	}

	.site-footer__heading      { grid-area: heading; }
	.site-footer__social-list  { grid-area: social; }
	.site-footer__legal-list   { grid-area: legal; }

	.site-footer__social-link svg,
	.footer__social-link svg {
		height: 32px;
		width: auto;
		display: block;
		color: currentColor;
	}

	.site-footer__social-list {
		display: flex;
		gap: 20px;
		align-items: center;
	}

	.site-footer__legal-list {
		font-family: var(--regular);
		font-size: var(--s);
	}

}


























.intro {
	padding: 0 0 45px 0;
}

.intro--about-us {
	padding: 0 0 68px 0;
}

.intro--mission {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 20px;
	padding: 0 0 60px 0;
}

@media (min-width: 1000px) {
	.intro--mission {
		grid-template-columns: repeat(3, 1fr);
	}
}

.intro--activities {
	padding: 0 0 50px 0;
	color: var(--white);
}

@media(min-width: 1000px) {

	.intro--activities {
		margin: 0 auto 0 auto;
	}

}

.intro--participate {
	padding: 0 0 60px 0;
}

.intro--topics {
	padding: 0 0 60px 0;
}

.intro--article {
	margin: 0 -20px 0 -20px;
	padding: 0 0 60px 0;
}

.intro__page-title {
	font-family: var(--condensed);
	font-size: var(--xxl);
	line-height: 1.1;
	color: var(--blue);
	text-align: center;
	padding: 0 0 56px 0;
}

@media (min-width: 1000px) {

	.intro__page-title {
		max-width: 1000px;
		margin: 0 auto 0 auto;
	}

}

.intro__page-title--activities {
	color: var(--white);
}

.intro__page-title--topics {
	padding: 0 20px 0 20px;
}

.intro__page-title--article {
	padding: 0 20px 25px 20px;
}

.intro__standfirst {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0 20px 25px 20px;
}

.intro__meta {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0 20px 0 20px;
	font-size: var(--s);
}

.intro__hero {
	margin: 0 -20px 0 -20px;
	padding: 0 0 60px 0;
}

@media (min-width: 1000px) {

	.intro__hero {
		margin: 0 0 0 0;
	}

}

@media (min-width: 1440px) {

	.intro__hero {
		margin: 0 120px 0 120px;
	}

}

@media (min-width: 1000px) {

	.intro__hero--topics {
		padding: 15px 0 60px 0; 
	}

}

.intro__hero picture img {
	width: 100%;
}

.intro__caption {

	padding: 7px 0 0 40px;
	font-size: var(--s);

	--u-color: var(--orange);
	--u-stroke: 2;
	--u-gap: 14;
}

@media (min-width: 1000px) {

	.intro__caption {
		padding: 7px 0 0 0;
	}

}

.intro__headline {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	font-family: var(--condensed);
	font-size: var(--l);
	padding: 0 0 20px 0;
}

.intro__headline--topics {
	padding: 0 20px 20px 20px;
}

.intro__text {
	max-width: 1000px;
	margin: 0 auto 0 auto;


	--u-color: currentColor;
	--u-stroke: 3;
	--u-gap: 18;
}

@media (min-width: 1000px) {

	.intro__text {
		padding: 0 0 20px 0;
	}

}

.intro__text--activities {
	color: var(--white);


	--u-color: var(--white);
	--u-stroke: 3;
	--u-gap: 18;
}

.intro__text--topics {
	padding: 0 0 30px 0;
}

.intro__text h3 {
	font-family: var(--condensed);
	font-size: var(--l);
	padding: 0 0 20px 0;
}

.intro__text p {
	padding: 0 0 20px 0;
	transform: color 0.5s ease-in-out;
}

.intro__text p:last-of-type {
	padding: 0 0 0 0;
}

.intro__text p a:hover {
	color: var(--orange);
}

.intro__text ul {
	list-style: disc outside;
	margin: 0;
	padding: 0 0 20px 1em;
}


.intro__text li > p {
	margin: 0;
	padding: 0 !important;
}

.intro__blocks {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

.intro__footnotes {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	font-size: var(--s);
	padding: 20px 0 0 0;

	--u-color: var(--orange);
}

.intro__link {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	font-family: var(--condensed);
	font-size: var(--l);
}

.intro__link--activities,
.intro__link--participate {

	--u-color: var(--orange);

}



.intro__statements {
	padding: 85px 0 60px 0;
	font-family: var(--condensed);
	font-size: clamp(60px, 12vw, 600px);
	line-height: 1.0;
	text-align: center;
	text-transform: uppercase;
	color: var(--orange);
}

.intro__statement {

}

.intro__statement--1 {

}

.intro__statement--2 {

}








.intro__statement-arrow {
	display: flex;
	justify-content: center;
	width: 100%;
	padding: 30px 0;
	contain: layout paint;
	color: var(--orange);
}



.intro__statement-arrow svg {
	display: block;
	height: clamp(90px, 18vw, 900px);
	width: auto;
	transform: rotate(0deg);
	transform-box: fill-box;
	transform-origin: center;
	transition: transform 0.3s ease-in-out !important;
	cursor: ns-resize;
}



.intro__statement-arrow svg path,
.intro__statement-arrow svg polyline {
	fill: none;
	stroke: currentColor;
	stroke-width: 3px;
	stroke-linecap: round;
	stroke-linejoin: round;
}



@media (hover: hover) {
	.intro__statement-arrow svg:hover  {
		transform: rotate(180deg);
		cursor: ns-resize;
	}
}



@media (hover: none) {
	.intro__statement-arrow svg {
		cursor: default;
	}
}



.intro__fonpost {
	background-color: var(--green);
	margin: 0 -20px 0 -20px;
}

@media (min-width: 1000px) {

	.intro__fonpost {
		background-color: var(--green);
		margin: 0 -60px 0 -60px;
	}

}

.intro__fonpost-inner {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 30px 20px 40px 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

@media (min-width: 900px) {

	.intro__fonpost-inner {
		padding: 30px 0 40px 0;
		gap: 60px;
	}
}

.intro__fonpost-text {
	grid-column: 1 / span 2;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.intro__fonpost-image {
	grid-column: 3 / span 1;
}

.intro__fonpost-link {
	grid-column: 1 / span 3;
	font-family: var(--condensed);
	font-size: var(--l);
	color: var(--white);
	background-color: var(--orange);
	padding: 30px 30px 30px 30px;
	border-radius: 10px;
	text-decoration: none;
	text-align: center;
}

@media (min-width: 1000px) {

	.intro__fonpost-link {
		font-size: var(--m);
	}

}

.intro__fonpost-link--mobile {
	display: none;
	margin: 0 50px 0 0;
}

.intro__fonpost-link--desktop {
	display: block;
}

@media (min-width: 1000px) {

    .intro__fonpost-link--mobile {
		display: block;
    }

    .intro__fonpost-link--desktop {
		display: none;
    }

}


.intro__fonpost-link:hover {
	background-color: var(--blue);
}







.image-slider {
	padding: 0 0 21px 0;
}

.image-slider--home {
	padding: 0 0 60px 0;
}

@media (min-width: 1440px) {

	.image-slider--home {
		padding: 0 120px 60px 120px;
	}
	
}

.image-slider--milestone {
	padding: 0 0 12px 0;
	width: 80%;
	margin: 0 0 0 auto;
}

@media (min-width: 1000px) {

	.image-slider--milestone {
		width: 60%;
	}

}

.image-slider picture,
.image-slider img {
  display:block;
  width:100%;
  height:auto;
}

.image-slider--multi {}
.image-slider--single {}

.image-slider__single-image {
	padding-bottom: 7px;
}

.image-slider__wrapper {
	overflow: hidden;
	position: relative;
	cursor: pointer;
}

.image-slider__wrapper::before,
.image-slider__wrapper::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 50%;
	z-index: 1;
}

.image-slider__wrapper::before {
	left: 0;
	cursor: w-resize;
}

.image-slider__wrapper::after {
	right: 0;
	cursor: e-resize;
}

.image-slider__track {
	display: flex;
	width: 100%;
	transition: transform 0.5s ease-in-out;
}

.image-slider__track picture,
.image-slider__track img {
	width: 100%;
	height: auto;
	display: block;
}

.image-slider__track > div {
	width: 100%;
	flex-shrink: 0;
	user-select: none;
	pointer-events: none;
}

.image-slider__dots {
	display: flex;
	gap: 6px;
	padding: 10px 0 0 0;
}

.image-slider__dot {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	border: none;
	cursor: pointer;
	padding: 0;
	background-color: var(--blue);
	opacity: 20%;
}

.image-slider__dot.is-active {
	opacity: 100%;
}

.image-slider__caption {
	padding: 7px 0 0 0;
	font-size: var(--s);
	color: var(--orange);

	--u-color: var(--orange);
	--u-stroke: 2;
	--u-gap: 14;
}

.image-slider__caption--home {
	display: none;
	pointer-events: none;
}

.image-slider__caption--home:hover {
	color: var(--blue);
}

.image-slider__caption.is-active {
	display: flex;
	align-items: center;
	gap: 10px;
	pointer-events: auto;
}


.image-slider__caption svg {
  display: inline-block;
  width: 10px;
  vertical-align: -1px;
}

@media (min-width: 1000px) {
	
	.image-slider__caption svg {
		width: 14px;
		vertical-align: -1px;
		}

}






.participate {
	margin: 0 -20px 0 -20px;

	--u-color: var(--orange);
}

.participate--home {
	margin: 0 0 0 0;
	font-family: var(--condensed);
	font-size: var(--l);
	--u-gap: 18;
	background-color: var(--white);
}

.participate__title {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	font-size: var(--xxl);
	line-height: 1.1;
	text-align: center;
	padding: 64px 0 64px 0;
}

.participate__fonpost {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 30px 20px 60px 20px;
	background-color: var(--green);
}

.participate__fonpost--home {

	padding: 30px 0 60px 0;
	background-color: var(--white);
}

.participate__media {

}

.participate__eyebrow {

}

.participate__heading {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0 0 21px 0;
	font-family: var(--condensed);
	font-size: var(--l);
}

.participate__heading--home {
	padding: 0 0 50px 0;
}

.participate__text {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0 0 45px 0;
}

.participate__blocks {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0 0 30px 0;
	--u-color: var(--orange);
}

.participate__blocks div {
	padding: 0 0 20px 0;
}


.participate__blocks p {
	font-family: var(--regular);
}

.participate__link-wrapper {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

.participate__link {
	display: block;
	transition: color 0.5s ease-in-out;
	font-family: var(--condensed);
	font-size: var(--l);
	color: var(--white) !important;
	background-color: var(--orange);
	margin: 0 auto 0 auto;
	padding: 30px 30px 30px 30px;
	border-radius: 10px;
	text-decoration: none;
	text-align: center;
	transition: background-color 0.5s ease-in-out !important;
}

@media (min-width: 1000px) {

	.participate__link {
		font-size: var(--m);
		width: 66.66%;
		margin: 0 auto 0 auto;
	}

}

.participate__link:hover {
	background-color: var(--blue);
	color: white;
}

.participate__link--donate:hover {
	background-color: var(--pink);
}

.participate__donate {
	padding: 30px 20px 60px 20px;
	background-color: var(--blue);
	color: var(--white);
}

.participate__donate--home {
	background-color: var(--white);
	color: var(--blue)
}

.participate__contact {
	padding: 30px 20px 60px 20px;
	background-color: var(--pink);
}

.participate__contact--home {
	background-color: var(--white);
}

.participate__fonpost picture,
.participate__fonpost img,
.participate__donate picture,
.participate__donate img,
.participate__contact picture,
.participate__contact img {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	width: 100%;
	height: auto;
	display: block;
	padding: 0 0 20px 0;
}





.mission {
	padding: 30px 20px 30px 20px;
	height: fit-content;
}

.mission--blue {
	color: var(--white);
	background-color: var(--blue);
}

.mission--green {
	color: var(--blue);
	background-color: var(--green);
}

.mission--orange {
	color: var(--white);
	background-color: var(--orange);
}

.mission__heading {
	font-family: var(--condensed);
	font-size: var(--l);
	padding: 0 0 30px 0;
}

.mission__text {

}

.timeline {

	max-width: 1000px;
	margin: 0 auto 0 auto;
	position: relative;


	--u-stroke: 3;
	--u-gap: 18;
	--u-color: currentColor;


	--timeline-rail-width: 10px;   /* WIDTH OF RIGHT RAIL STRIP */
	--timeline-rail-gap: 30px;     /* GAP BETWEEN CONTENT AND RAIL */
	--timeline-rail-color: var(--blue);
	--timeline-dot-size: 24px;     /* DIAMETER OF DOTS */


	padding-right: calc(var(--timeline-rail-width) + var(--timeline-rail-gap));
}

@media (min-width: 1000px) {

	.timeline {
		--timeline-rail-gap: 60px;     /* GAP BETWEEN CONTENT AND RAIL */
		--timeline-dot-size: 32px;
	}
	
}

.timeline__title {
	font-family: var(--condensed);
	font-size: var(--xxl);
	line-height: 1.1;
	color: var(--blue);
	text-align: center;
	padding: 0 0 60px 0;
	margin-right: -40px;
}





.timeline__rail {

	position: absolute;
	top: 130px;
	right: 7px;
	bottom: 0;
	width: var(--timeline-rail-width);


	pointer-events: none;
	display: flex;
	justify-content: center;


	z-index: 1;
}

@media (min-width: 1000px) {

	.timeline__rail {
		top: 180px;
	}

}

.timeline__rail-svg {
	height: 100%;
	display: block;
}

.timeline__rail-svg :is(line, path) {
  vector-effect: non-scaling-stroke;
  stroke: var(--timeline-rail-color);
  stroke-width: 3px;
  stroke-linecap: round;
}






.timespan {

}

.timespan__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.timespan__item {
	position: relative;
	padding: 0 0 50px 0;
}

.timespan__title {
	font-family: var(--condensed);
	font-size: var(--xxl);
	line-height: 1.1;
	color: var(--blue);
	text-align: right;
	padding: 0 0 20px 0;
}

.timespan__heading {
	padding: 0 0 20px 0;
	font-family: var(--condensed);
	text-align: right;
	font-size: var(--l);
	line-height: 1.1;
	color: var(--blue);
}

.timespan__text {
	padding: 0 0 20px 0;
	text-align: right;
}


/* .timespan__item + .timespan__item {
	margin-top: 24px;
} */





.timespan__row {
	position: relative;
}


.timespan__marker,
.milestone__marker {
	position: absolute;
	top: 0px;
	right: -40px;
	width: var(--timeline-dot-size);
	height: var(--timeline-dot-size);
	display: block;

	z-index: 2;
}

@media (min-width: 1000px) {

	.timespan__marker,
	.milestone__marker {
		right: -74px;
	}
	
}

.timespan__marker {
	top: 13px;
}

@media (min-width: 1000px) {

	.timespan__marker {
		top: 27px;
	}

}

.milestone__marker {
	top: 3px;
}

@media (min-width: 1000px) {

	.milestone__marker {
		top: 15px;
	}

}


.timespan__dot,
.milestone__dot {
	width: 100%;
	height: 100%;
	display: block;
}


.timespan__dot,
.milestone__dot {
	color: var(--timeline-rail-color); /* steuert currentColor */
}


.timespan__dot path,
.milestone__dot path {
	fill: currentColor;
}









/* .activities {
	color: var(--white);
}

.activities__list {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

@media (min-width: 1000px) {

	.activities__list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 32px;
	}

}

.activities__item {
	padding: 0 0 50px 0;
}

.activities__item:last-of-type {
	padding: 0 0 0 0;
}

.activities__heading {
	font-size: var(--s);
	padding: 0 0 2px 0;
}

.activities__partner {
	font-family: var(--condensed);
	font-size: var(--l);
	padding: 0 0 12px 0;
}


.activities__media {
	padding: 0 0 12px 0;
}

.activities__media * {
	width: 100%;
}

.activities__text {

} */





.activities {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

.activities--feature {
	padding: 0 0 50px 0;
}

.activities:last-of-type {
	padding: 0 0 0 0;
}

.activities__title {
	font-family: var(--condensed);
	font-size: var(--l);
	line-height: 1.1;
	color: var(--white);
	text-align: center;
	padding: 0 0 50px 0;
}

.activities__list { }

@media (min-width: 1000px) {

	.activities__list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 60px;
  }

}

.activities__item {
	color: var(--white);
	padding: 0 0 50px 0;
	transform: rotate(0);
	transition: transform 0.25s ease-in-out;
}

.activities__item:hover {
	transform: rotate(-5deg);
}

.activities-card {
	display: block;
	text-decoration: none;
	color: inherit;
}

.activities-card__media {
	padding: 0 0 16px 0;
}

.activities-card__image {
	display: block;
	width: 100%;
	height: auto;
}

.activities-card__body {}

.activities-card__heading {
	font-family: var(--condensed);
	font-size: var(--l);
	line-height: 1.1;
	padding: 0 0 24px 0;
}

.activities-card__excerpt {}





.articles {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

.articles--feature {
	padding: 0 0 50px 0;
}

.articles:last-of-type {
	padding: 0 0 0 0;
}

.articles__title {
	font-family: var(--condensed);
	font-size: var(--l);
	line-height: 1.1;
	color: var(--blue);
	text-align: center;
	padding: 0 0 50px 0;
}


.articles__list {}

.articles-card__heading,
.articles-card__excerpt {
	overflow-wrap: anywhere;
}

@media (min-width: 1000px) {

	.articles__list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 60px;
		padding: 0 0 20px 0;
	}

}

.articles__item {
	padding: 0 0 50px 0;
	transform: rotate(0);
	transition: transform 0.25s ease-in-out;
}

.articles__item:hover {
	transform: rotate(-5deg)
}



.articles-card {
	display: block;
	text-decoration: none;
	color: inherit;
}

.articles-card__media {
	padding: 0 0 16px 0;
}

.articles-card__image {
	display: block;
	width: 100%;
	height: auto;
}

.articles-card__body {
}

.articles-card__category {
	font-size: var(--s);
	padding: 0 0 2px 0;
}

.articles-card__heading {
	font-family: var(--condensed);
	font-size: var(--l);
	line-height: 1.1;
	color: var(--blue);
	padding: 0 0 24px 0;
}

.articles-card__excerpt {

}

.archive {
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0 0 60px 0;
	display: flex;
	justify-content: center;
}

.archive,
.archive svg path {
	transition: color fill 0.25s ease-in-out !important;
}


.archive:hover,
.archive:hover svg path {
	color: var(--orange);
	fill: var(--orange);
}

.archive__inner {
	display: flex;
	gap: 5px;
	align-items: center;
	font-family: var(--condensed);
	font-size: var(--l);
	transform: rotate(0);
}

@media (min-width: 1000px) {

.archive__inner {
	font-size: var(--m);
}

}

.archive__icon {
	padding: 2px 0 0 0;
}

.archive__link {}





.taxonomy {}
.taxonomy__block {}
.taxonomy__block--categories {}
.taxonomy__block--tags {}
.taxonomy__block--roles {}
.taxonomy__block--names {}





.archive {}

.archive-list {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

.archive-list__items {}
.archive-list__item {}



.tags {
	text-align: center;
	max-width: 1500px;
	margin: 0 auto 0 auto;
	padding: 0 0 50px 0;
}

.tags__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.tags__item {}

.tags__chip {
	display: inline-block;
	font-family: var(--condensed);
	font-size: var(--m);
	color: var(--orange);
	border: 2px solid var(--orange);
	padding: 5px 10px;
	text-decoration: none;
	transition: background-color color 0.5s ease-in-out;
}

.tags__chip:hover {
	background-color: var(--orange);
	color: var(--white);
}

.tags__chip.is-active {
	background-color: var(--orange);
	color: var(--white);
}







.meta {}

.meta--category {}

.meta--date {}

.meta--byline {}

.meta--tags {}

.tag {}

.article-content {
	max-width: 600px;
	margin: 0 auto 0 auto;
	padding: 0 0 30px 0;
}

@media (min-width: 1000px) {
	.article-content {
		padding: 0 0 60px 0;
	}
}

.article-extra {}
.article-extra__title {}
.article-extra__body {}

.article-nav {
	max-width: 600px;
	margin: 0 auto 0 auto;
	padding: 0 0 60px 0;
}

@media (min-width: 1000px) {
	.article-nav  {
		padding: 0 0 120px 0;
	}
}

.article-nav__list {
	width: 100%;
	display: flex;
	justify-content: space-between;
	font-family: var(--condensed);
	font-size: var(--m);
	color: var(--orange);
}

.article-nav__item {
	display: flex;
	align-items: center;
	gap: 10px;
}

.article-nav__item:hover {
	color: var(--blue);
	fill: var(--blue);
}

.button {
	display: flex;
	gap: 5px;
	align-items: center;
}

@media (min-width: 1000px) {
	
	.button svg {
		height: 30px;
		width: auto;
	}

}

.button svg path {
	transition: stroke 0.5s ease-in-out;
}

.article-nav__item:hover .button svg path {
	stroke: var(--blue);
}

.related {
	max-width: 1000px;
	margin: 0 auto 0 auto;
}

.related__title {
	font-family: var(--condensed);
	font-size: var(--l);
	line-height: 1.1;
	color: var(--blue);
	text-align: center;
	padding: 0 0 50px 0;
}






.u-icon {
  display: inline-block;
  vertical-align: middle;
  /* width: 1em;
  height: 1em; */
  flex-shrink: 0;
}






.search {

}

.search-form {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 15px;
	padding: 0 0 72px 0;
}

.search-form__label {

}

.search-form__input {

	margin: 0 auto;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 100%;
	border: 2px solid var(--orange);
	border-radius: 0;
	box-shadow: none;
	font-family: var(--regular);
	color: var(--orange);
	line-height: 1.2;
	padding: 10px 12px 10px 12px;
	min-width: 0;

	transition: color .5s ease-in-out, border-color .5s ease-in-out;
}

.search-form__input::-webkit-search-cancel-button,
.search-form__input::-webkit-search-decoration,
.search-form__input::-webkit-search-results-button,
.search-form__input::-webkit-search-results-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

.search-form__input::-ms-clear {
  display: none;
  width: 0;
  height: 0;
}

.search-form__input::placeholder {
	color: var(--orange);
	opacity: 0.5;

	transition: color .5s ease-in-out;
}

.search-form__button {
	display: block;
	background-color: var(--orange);
	padding: 0;
	font-family: var(--condensed);
	color: var(--white);
	line-height: 1.2;
	cursor: pointer;
	padding: 10px 15px 10px 15px;
	transition: background-color .5s ease-in-out;
}

.search-form__button:hover {
	background-color: var(--blue);
}









.search-results__count {
	padding: 0 0 48px 0;
}


.search-results {

}

.search-results__list {
	list-style: none;
	margin: 0;
	padding: 0;
}


.search-results__item {
	padding: 0 0 16px 0;
}

.search-results__item:last-of-type {
	padding: 0 0 0 0;
}


.search-results__card {
	transition: color .5s ease-in-out;
}


.search-results__card:hover {
	color: var(--orange);
}

.search-results__label {
	font-size: var(--s);
	padding: 0 0 2px 0;
}

.search-results__heading {
	font-family: var(--condensed);
	font-size: var(--l);
}

.search-results__byline {
	font-size: var(--s);
	padding: 4px 0 0 0;
}

.search-results__byline-name {

}

.search-results__byline-date {

}



.pagination {

}

.pagination__list {
	list-style: none;
	margin: 0;
	padding: 0;

}

.pagination__item {

}

.pagination__link {

}


.pagination__link[aria-current="page"],
.pagination__link.is-active {

}




.search-form.is-loading {

}

.search-form.has-error  {

}












.legal {





}



.legal--imprint {





}

.legal--privacy {





}

.legal--netiquette {





}

.legal--contact {





}

.legal--accessibility {





}



.legal__page-title {
	font-family: var(--condensed);
	font-size: var(--xxl);
	line-height: 1.1;
	color: var(--blue);
	text-align: center;
}

.legal__text {





}















.block { 

}

.block--text {}
.block--images {}
.block--video {}
.block--quote {}
.block--cta {}
.block--infobox-definitions {}
.block--infobox-fondof {}
.block--infobox-links {}
.block--timeperiod {}






.block-text {

}

.block-text h3 {
	padding: 0 0 20px 0;
}

.block-text p {
	font-family: var(--regular);
	font-size: var(--m);
	padding: 0 0 20px 0;
}

.block-text p:last-of-type {
	padding: 0 0 28px 0;
}

.block-text ul {
	list-style: disc outside;
	margin: 0;
	padding: 0 0 20px 1em;
}



.block-text li > p {
  margin: 0;
  padding: 0 !important;
}





.block-images {





}


.block-images__grid {}
.block-images__item {}
.block-images__image {}
.block-images__caption {}


.block-images--single {}
.block-images--gallery {}


/* ==========================================================================
   BLOCK: VIDEO
   PURPOSE: RESPONSIVE VIMEO/YT EMBEDS WITH ORIENTATION VARIANTS
   ========================================================================== */

.block-video {
	display: block;
	width: 100%;
	padding: 0 0 30px 0;
}



.block-video__wrapper {
	width: 100%;
	aspect-ratio: 16 / 9;
	position: relative;
}

.block-video__iframe {
	display: block;
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;

}

.block-video__caption {
	padding: 7px 0 0 0;
	font-size: var(--s);

	--u-color: var(--orange);
	--u-stroke: 2;
	--u-gap: 14;
}



[data-js-vimeo-embed] iframe[data-vimeo-src] {
	opacity: 0;
	transition: opacity 0.25s ease;
}

[data-js-vimeo-embed].is-hydrated iframe[data-vimeo-src] {
	opacity: 1;
}



[data-js-vimeo-embed] [data-js-vimeo-placeholder] {
	opacity: 1;
	transition: opacity 0.25s ease;
}

[data-js-vimeo-embed].is-hydrated [data-js-vimeo-placeholder] {
	opacity: 0;
	pointer-events: none;
}



.block-video--portrait {
	width: 50%;
	margin: 0 auto 0 auto;
}

.block-video--portrait .block-video__wrapper {
	aspect-ratio: 9 / 16;
}


.block-video--square {
	width: 75%;
	margin: 0 auto 0 auto;
}

.block-video--square .block-video__wrapper {
	aspect-ratio: 1 / 1;
}





.block-quote {
	font-family: var(--condensed);
	font-size: var(--xl);
	padding: 0 0 25px 0;
}

@media (min-width: 1000px) {

	.block-quote {
		position: relative;
		left: 120px;
		font-size: var(--l);
	}

}





.block-footnote {
	font-size: var(--s);
	--u-color: var(--blue);
	--u-stroke: 2;
	--u-gap: 14;
}

.block-footnote p {
	padding: 0 0 20px 0;
}








.block-cta {
	margin: 0 0 35px 0;
}


.block-cta:hover .block-cta__link {
	color: var(--orange);
}


.block-cta__link {
	display: block;
	padding: 25px 25px 25px 25px;
	transition: color 0.5s ease-in-out;
	text-decoration: underline;
	text-decoration-color: red;
	text-decoration-thickness: 2px;
	text-underline-offset: 4px;
}

.block-cta__link p {

}


.block-cta--green {
	background-color: var(--green);
}

.block-cta--pink {
	background-color: var(--pink);
}

.block-cta--blue {
	background-color: var(--blue);
	color: var(--white);
}






.block-infobox-definitions {
	padding: 25px 25px 25px 25px;
	margin: 0 25px 25px 25px;
	border: 2px solid var(--orange);
	color: var(--orange);
}

@media (min-width: 1000px) {

	.block-infobox-definitions {
		position: relative;
		left: 120px;
		margin: 0 0 25px 0;
		
	}

}


.block-infobox-definitions__heading {}
.block-infobox-definitions__list {}

.block-infobox-definitions__item {
	transition: color 0.5s ease-in-out;
}


.block-infobox-definitions__toggle {
	cursor: pointer;
}

.block-infobox-definitions__toggle:hover,
.block-infobox-definitions__toggle:focus {}

.block-infobox-definitions__header {}

.block-infobox-definitions__term {}

.block-infobox-definitions__term:hover {
	color: var(--blue);
}

.block-infobox-definitions__body {}

.block-infobox-definitions__text {
	padding: 15px 0 0 0;
}


.block-infobox-definitions__text ul {
	list-style: disc outside;
	margin: 0;
	padding: 0 0 20px 1em;
}


.block-infobox-definitions__text li > p {
	margin: 0;
	padding: 0 !important;
}


.block-infobox-definitions__body { overflow: visible; }


.block-infobox-definitions__list[data-accordion-ready="true"] .block-infobox-definitions__body {
	overflow: hidden;
	transition: height .25s ease;
}


@media (prefers-reduced-motion: reduce) {
	.block-infobox-definitions__list[data-accordion-ready="true"] .block-infobox-definitions__body {
		transition: none;
	}
}


.block-infobox-definitions__icon {
	display: inline-block;
	margin-right: .5em;       /* SPACING BETWEEN ICON & TERM */
	transition: transform .25s ease;
	transform: rotate(0deg);
	color: currentColor;
}


.block-infobox-definitions__icon path {
	stroke: currentColor !important;
}


.block-infobox-definitions__toggle[aria-expanded="true"] 
	.block-infobox-definitions__icon {
	transform: rotate(180deg);
}


.block-infobox-definitions__term {
  display: flex;
  align-items: center;
  gap: .5rem;
}


.block-infobox-definitions__toggle {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  /* OPTIONAL BUTTON RESET, FALLS NÖTIG:
  background: none;
  border: 0;
  padding: 0;
  */
}


.block-infobox-definitions__icon {
  display: inline-block;
  flex: 0 0 auto;
  vertical-align: middle;
  transition: transform .25s ease;
}


.block-infobox-definitions__item.is-open .block-infobox-definitions__icon {
  transform: rotate(180deg);
}


@media (prefers-reduced-motion: reduce) {
  .block-infobox-definitions__icon { transition: none; }
}








.block-infobox-fondof {
	margin: 0 25px 25px 25px;
	padding: 25px 25px 25px 25px;
	border: 2px solid var(--orange);
	color: var(--orange);
}

@media (min-width: 1000px) {

	.block-infobox-fondof {
		position: relative;
		left: 120px;
		margin: 0 0 25px 0;
	}

}

.block-infobox-fondof__media {
	padding: 0 0 20px 0;
}
.block-infobox-fondof__image {}
.block-infobox-fondof__body {}

.block-infobox-fondof__heading {
	padding: 10px 0 20px 0;
}

.block-infobox-fondof__text {}


.block-infobox-fondof__text ul {
	list-style: disc outside;
	margin: 0;
	padding: 0 0 20px 1em;
}


.block-infobox-fondof__text li > p {
	margin: 0;
	padding: 0 !important;
}

.block-infobox-fondof__cta {}







.block-infobox-links {
	padding: 25px 25px 25px 25px;
	margin: 0 25px 25px 25px;
	border: 2px solid var(--orange);
	color: var(--orange);

	--u-stroke: 3;
	--u-gap: 18;
	--u-color: currentColor;
}

@media (min-width: 1000px) {

	.block-infobox-links {
		position: relative;
		left: 120px;
		margin: 0 0 25px 0;
	}

}

.block-infobox-links__heading {
	font-family: var(--condensed);
}
.block-infobox-links__list {}

.block-infobox-links__item {
	display: flex;
	align-items: center;
	gap: 10px;
}

.block-infobox-links__link {}

.block-infobox-links__text {}






.block-timeperiod {}
.block-timeperiod__title {}
.block-timeperiod__list {}
.block-timeperiod__item {}
.block-timeperiod__heading {}
.block-timeperiod__text {}
.block-timeperiod__media {}
.block-timeperiod__grid {}
.block-timeperiod__grid-item {}
.block-timeperiod__image {}
.block-timeperiod__caption {}


.block-timeperiod--media-single {}
.block-timeperiod--media-gallery {}
























/* ==========================================================================
   UTIL: SHAKE / WAVE ROTATION
   PURPOSE: FUN VIBRATION EFFECT ON HOVER
   ========================================================================== */

@keyframes u-wave {
	0%   { transform: rotate(0deg); }
	20%  { transform: rotate(-5deg); }
	50%  { transform: rotate(5deg); }
	60%  { transform: rotate(-5deg); }
	80%  { transform: rotate(5deg); }
	100% { transform: rotate(0deg); }
}

.u-wave-hover {
	transition: transform 0.5s ease-in-out;
}

.u-wave-hover:hover {
	animation: u-wave 0.5s ease-in-out;
}















.u-underline {
	position: relative;
	display: inline;
	text-decoration: none;
}


.u-underline__box {
	display: inline-block;
	position: relative;
	vertical-align: baseline;
}


.u-underline__line {
	position: absolute;
	pointer-events: none;
}


.u-underline__line use,
.u-underline__svg use {
	fill: none;
	stroke: var(--u-color);
	stroke-width: var(--u-stroke);
	stroke-linecap: round;
	stroke-linejoin: round;
	vector-effect: non-scaling-stroke;
}


.no-underline,
[data-underline="off"] {
	text-decoration: none !important;
}


/* .intro__text {
	--u-color: #0ea5e9;
	--u-stroke: 3;
	--u-gap: 16;
} */













:root{


  --c-color: currentColor;

  --c-stroke: 2.5;                


  --c-pad-b: 1em;
  --c-pad-i: 1em;










  --c-pad-k: .6;                  








  --c-spread: 0px;


  --c-rotate: 0deg;
}


.u-circle{
  position: relative;
  display: inline-block;

}


.u-circle__box {
	position: relative;
	display: inline-block;

	/* PER-SIDE PADDING WITH FALLBACKS:
		SIDE → AXIS → DEFAULT  +  (STROKE × MULTIPLIER SIDE→GLOBAL→0) */
	padding-top: calc(
		var(--c-pad-top, var(--c-pad-b)) +
		(var(--c-stroke) * var(--c-padk-top, var(--c-pad-k, 0)) * 1px)
	);

	padding-right: calc(
		var(--c-pad-right, var(--c-pad-i)) +
		(var(--c-stroke) * var(--c-padk-right, var(--c-pad-k, 0)) * 1px)
	);

	padding-bottom: calc(
		var(--c-pad-bottom, var(--c-pad-b)) +
		(var(--c-stroke) * var(--c-padk-bottom, var(--c-pad-k, 0)) * 1px)
	);

	padding-left: calc(
		var(--c-pad-left, var(--c-pad-i)) +
		(var(--c-stroke) * var(--c-padk-left, var(--c-pad-k, 0)) * 1px)
	);

	z-index: 1;
}


.u-circle__svg{
	position: absolute;
	top: calc(var(--c-spread) * -1);
	left: calc(var(--c-spread) * -1);
	width: calc(100% + var(--c-spread) * 2);
	height: calc(100% + var(--c-spread) * 2);
	pointer-events: none;
	z-index: 0;
	transform: rotate(var(--c-rotate));
	transform-origin: 50% 50%;
}


.u-circle__svg *{
  fill: none;
  stroke: var(--c-color);
  stroke-width: var(--c-stroke);
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}






















:root{

	--f-color: currentColor;

	--f-stroke: 3px;

	--f-pad: .45em .75em;

	--f-edge: calc(var(--f-stroke) * 3);
}



.u-frame {
	position: relative; display: inline-block;
}

.u-frame__box {
	position: relative; display: inline-block; padding: var(--f-pad);
}

.u-frame__edge {
	position: absolute; pointer-events: none;
}



.u-frame__edge--h {
	height: var(--f-edge);
	width: 100%;
	left: 0;
}

.u-frame__edge--top {
	top: 0;
}

.u-frame__edge--bottom {
	bottom: 0;
}



.u-frame__edge--v {
	width: var(--f-edge);
	height: 100%; top: 0;
}

.u-frame__edge--left {
	left: 0;
}

.u-frame__edge--right {
	right: 0;
}



.u-frame__edge use{
  fill: none;
  stroke: var(--f-color);
  stroke-width: var(--f-stroke);
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}



/* .frame--accent {
	--f-color:#ea580c;
	--f-stroke:4px;
} */

/* .frame--soft {
	--f-color:#e11d48;
	--f-stroke:3px;
	--f-pad:.6em 1em;
} */



/* .u-frame--touch .u-frame__edge--h {
	left: -0.5px;
	right: -0.5px
} */

/* .u-frame--touch .u-frame__edge--v {
	top: -0.5px;
	bottom: -0.5px
} */











.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}




@media (prefers-reduced-motion: no-preference) {
	img,
	picture img,
	svg {
		transition: filter .25s ease,
			color .25s ease,
			fill .25s ease,
			stroke .25s ease;
	}
}

body.contrast-mode {
	--blue: #000;
	--orange: #000;
	--green: #000;
	--pink: #000;
}

body.contrast-mode .participate {
	color: var(--white);
	--u-color: currentColor;
}

body.contrast-mode .mission--green {
	color: var(--white);
	--u-color: currentColor;
}

body.contrast-mode .intro__fonpost-text {
	color: var(--white);
	--u-color: currentColor;
}

body.contrast-mode .intro__fonpost-link {
	background-color: var(--white);
	color: var(--black);
	--u-color: currentColor;
}

body.contrast-mode .archive__icon path {
	color: var(--black);
	fill: var(--black);
}

body.contrast-mode .block-infobox-fondof__icon path {
	color: var(--black);
	fill: var(--black);
}

body.contrast-mode .block-infobox-links__item svg path {
	stroke: var(--black);
}

body.contrast-mode iframe {
	filter: grayscale(100%);
}

body.contrast-mode .article-nav__item svg path {
	stroke: var(--black);
}

body.contrast-mode .intro--participate,
body.contrast-mode .intro--participate .intro__page-title {
	color: var(--white);
}

body.contrast-mode .participate__link {
	background-color: var(--white);
	color: var(--black) !important;
}

body.contrast-mode .participate__link--home {
	background-color: var(--black);
	color: var(--white) !important;
}

body.contrast-mode .participate--home {
	color: var(--black);
	--u-color: currentColor;
}

body.contrast-mode img,
body.contrast-mode picture img {
	filter: grayscale(100%);
}

.no-contrast,
.no-contrast img,
.no-contrast picture img {
	filter: none !important;
}






body:not(.js-contrast-ready) img,
body:not(.js-contrast-ready) picture img,
body:not(.js-contrast-ready) svg,
body:not(.js-contrast-ready) svg * {
	transition: none !important;
}


body.js-contrast-ready img,
body.js-contrast-ready picture img,
body.js-contrast-ready svg,
body.js-contrast-ready svg * {
	transition: filter .5s ease-in-out,
		fill .5s ease-in-out,
		stroke .5s ease-in-out;
}



.u-contrast-animate p,
.u-contrast-animate h1,
.u-contrast-animate h2,
.u-contrast-animate h3,
.u-contrast-animate h4,
.u-contrast-animate h5,
.u-contrast-animate h6,
.u-contrast-animate a,
.u-contrast-animate button,
.u-contrast-animate [role="button"] {
	transition: color .5s ease-in-out,
		background-color .5s ease-in-out,
		border-color .5s ease-in-out;
}

/* ==========================================================================
   INTRO: PAGE-LOAD SLIDE-IN (CSS-ONLY)
   PURPOSE: SEQUENTIAL REVEAL FROM BOTTOM ON FIRST PAINT
   ========================================================================== */

@keyframes intro-slide-up {

	from {

		opacity: 0;


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

}


.intro__statement--1,
.intro__statement-arrow,
.intro__statement--2 {

  will-change: transform, opacity;


  opacity: 0;
  transform: translateY(100px);


  animation-name: intro-slide-up;
  animation-duration: .75s;
  animation-timing-function: cubic-bezier(.22,1,.36,1); /* EASE-OUT */
  animation-fill-mode: both; /* KEEP FINAL STATE */
}



.intro__statement--1 {
	animation-delay: .25s;
}

.intro__statement-arrow {
	animation-delay: .5s;
}

.intro__statement--2 {
	animation-delay: .75s;
}


@media (prefers-reduced-motion: reduce) {

	.intro__statement--1,
	.intro__statement-arrow,
	.intro__statement--2 {
		opacity: 1;
	}

}

/* ==========================================================================
   PAGE TRANSITIONS (GLOBAL)
   PURPOSE: FADE TO WHITE ON LEAVE, FADE IN ON ENTER; MAIN SLIDES UP
   HOOKS: BODY .is-ready / .is-transitioning
   ========================================================================== */

:root {
	--pt-dur: 500ms;
	--pt-ease: ease-in-out;
	--pt-shift: 50px; /* VERTICAL OFFSET FOR .site-main ON ENTER */
}


.pt-overlay {

	position: fixed;
	inset: 0;
	z-index: 9999;

	background: #fff;
	opacity: 1; /* DEFAULT: VISIBLE (PREVENT FLICKER) */
	pointer-events: none; /* NEVER BLOCK CLICKS */

	transition: opacity var(--pt-dur) var(--pt-ease);
}


body.is-ready .pt-overlay {
	opacity: 0;
}


body.is-transitioning .pt-overlay {
	opacity: 1;
}


.site-main {

	opacity: 0;
	transform: translateY(var(--pt-shift));
	transition:
		opacity var(--pt-dur) var(--pt-ease),
		transform var(--pt-dur) var(--pt-ease);
}


body.is-ready .site-main {
	opacity: 1;
	transform: translateY(0);
}


@media (prefers-reduced-motion: reduce) {
	:root { --pt-dur: 1ms; --pt-shift: 0; }
	.site-main { transition: none; opacity: 1; transform: none; }
	.pt-overlay { transition: none; }
}








.consent-banner {
	background-color: var(--orange);
	color: var(--white);
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 9999;
	padding: 15px 20px 15px 20px;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.25s ease, transform 0.25s ease;
	pointer-events: none;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 30px;

	--u-color: currentColor;
	--u-stroke: 3;
	--u-gap: 18;
}

@media (min-width: 640px) {
	.consent-banner {
		flex-direction: row;
		align-items: center;
	}
}

@media (min-width: 1000px) {

	.consent-banner {
		padding: 20px 60px 20px 60px;
	}

}

.consent-banner.is-visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.consent-banner[hidden] {
	display: none;
}





.consent-banner[hidden] {
	display: none;
}

.consent-banner__text {}

.consent-banner__link {
	transition: color 0.5s ease-in-out;
}

.consent-banner__link:hover {
	color: var(--blue);
}

.consent-banner__button {
	display: block;
	height: 100%;
	white-space: nowrap;
	cursor: pointer;
	background-color: var(--white);
	color: var(--orange);
	font-family: var(--condensed);
	padding: 10px 15px 10px 15px;
	border-radius: 5px;
	transform: rotate(0);
	transition: transform 0.5s ease-in-out;
}

.consent-banner__button:hover {
	transform: rotate(-360deg);
}






.block-video__placeholder {
	background-color: var(--orange);
	height: 100%;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 30px 30px 30px 30px;
}

.block-video__placeholder-text {
	text-align: center;
	color: var(--white);
	font-family: var(--condensed);
}

.block-video__placeholder-button {
	white-space: nowrap;
}