/* ============================================
	 STARTSEITE – DIV um einzelne Auszeichnungen
============================================ */
/* Grundlayout Portfolio */
.portfolio {
	display: flex;
	flex-wrap: wrap;
	gap: 30px 20px;
	justify-content: flex-start;
	margin: 2.5em auto 2em auto;
	width: 95%;
}

@media only screen and (min-width: 1200px) {
	.portfolio { width: 100%; }
}

/* Jedes Portfolio-Item gleich groß */
.portfolio-item {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	flex: 0 0 300px;
	box-sizing: border-box;
	background-color-X: #fff;
	padding: 0 0 1em 0;
}

@media only screen and (max-width: 599px) {
	.portfolio-item { flex-basis: 100%; }
}
@media only screen and (min-width: 600px) and (max-width: 991px) {
	.portfolio-item { flex-basis: calc(50% - 10px); }
}
@media only screen and (min-width: 992px) {
	.portfolio-item { flex-basis: calc(33% - 11px); }
}

/* EINHEITLICHER Mediarahmen */
.portfolio-item-media {
	aspect-ratio: 3 / 2;
	width: 100%;
	position: relative;
	overflow: hidden;
	margin-bottom: 1em;
	background: #000; /* fallback */
}

.portfolio-item-media img,
.portfolio-item-media video,
.portfolio-item-media iframe,
.portfolio-item-media .portfolio-item-img-content,
.portfolio-item-media #viewer {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	object-fit: cover;
}

/* Headlinebox auf gleicher Höhe */
.headlinebox {
	text-align: center;
	margin-bottom: 1em;
}
.headlinebox-inner h3 { margin: 0; }

/* Text wächst gleichmäßig */
.portfolio p {
	flex-grow: 1;
	margin: 0 1em 1em 1em;
}

/* Button unten */
.portfolio .more {
	margin-top: auto;
	text-align: center;
	color: #282830 !important;
}





/* ============================================
	 STARTSEITE – DIV um Auszeichnungen
============================================ */
.award {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 30px 20px;
	justify-content: flex-start;
	margin: 2.5em auto 2em auto;
	width: 95%;
}

@media only screen and (min-width: 1200px) {
	.award {
		width: 100%;
	}
}

.award-item {
	display: flex;
	flex: 0 0 300px;
	flex-direction: column;
	padding-bottom: 1em;
	position: relative;
	text-align: center;
}

@media only screen and (max-width: 599px) {
	.award-item {
		flex-basis: 100%;
	}
}

@media only screen and (min-width: 600px) and (max-width: 991px) {
 .award-item {
		flex-basis: calc(50% - 10px);
	}
}

@media only screen and (min-width: 992px) {
	.award-item {
		flex-basis: calc(33% - 11px);
	}
}

/* Figure-Container anpassen */
.award-item-figure {
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.award-item-figure img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 4px; /* optional */
}

/* Caption */
.award-item-figure figcaption {
	margin-top: 0.5em;
	font-size: 0.95rem;
	color: inherit;
	line-height: 1.3;
	display: block !important;
}





/* ============================================
	 STARTSEITE – DIV um Auszeichnungen
============================================ */

#partner {
	display: flex;
	flex-wrap: wrap;
}


.partner {
	display: flex;
	flex-direction: column;
	background-color: #fff;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	border: 1px solid silver;
	aspect-ratio: 3 / 1;
	flex: 0 0 100%;
	text-align: center;
	padding: 10px;
}

/* Responsive Verhalten */
@media only screen and (max-width: 599px) {
	.partner { flex-basis: 95%; margin: 0 auto; }
}

@media only screen and (min-width: 600px) and (max-width: 991px) {
	.partner { flex: 0 0 calc((100% - 20px) / 3); }
}

@media only screen and (min-width: 992px) {
	.partner { flex: 0 0 calc((100% - 30px) / 4); }
}

.partner figure {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	width: 100%;
	margin: 0;
}

.partner figure a {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1;
	width: 100%;
	text-decoration: none;
	position: relative;
}

/* Bild + Stern zentriert */
.partner-logo-image {
	max-width: 200px;
	height: auto;
	object-fit: contain;
	display: block;
	margin: 0 auto;
}

/* Stern (das <p> im <a>) soll korrekt sitzen */
.partner figure a p {
	position: absolute;
	bottom: 10px;
	right: 10px;
	margin: 0;
	color: black;
	font-size: 1rem;
}

/* Caption unten */
.partner figcaption {
	margin-top: 0rem;
	font-size: 0.9rem;
	line-height: 1.2;
	color: black;
}

/* Mobile Optimierung */
@media only screen and (max-width: 768px) {
	.partner-logo-image {
		max-width: 200px;
	}
}