/* =========================================================
   M35 - Insights & Innovationen (heller Abschnitt, zweispaltig)
   Links: News (Featured + 2 kompakt). Rechts: Podcast + 2 Veranstaltungen.
   Tokens: hell #f4f5f2 | weiss #fff | Rahmen #d2cdcb | braun #685a51 | dunkel #271b11 | orange #f48520
   Font-Sizes in rem, Spacing in px.
   ========================================================= */

section.m35_insights {
	background-color: #fff;
}

/* ---------- Header ---------- */
section.m35_insights .m35_header {
	margin-bottom: 51px;
}
section.m35_insights .m35_topline {
	display: block;
	margin-bottom: 2px;
	font-size: 1.0625rem;   /* 17px */
	font-weight: 800;
	text-transform: uppercase;
	color: #f48520;
}
section.m35_insights .m35_titel,
section.m35_insights .m35_titel * {
	margin: 0;
	font-size: 2.8125rem;   /* 45px */
	line-height: 50px;
	font-weight: 900;
	text-transform: uppercase;
	color: #271b11;
}

/* ---------- Grid ---------- */
section.m35_insights .m35_grid {
	display: flex;
	align-items: stretch;
}
section.m35_insights .m35_col {
	flex: 1 1 0;
	min-width: 0;
}
section.m35_insights .m35_news {
	padding-right: 90px;
}
section.m35_insights .m35_divider {
	flex: 0 0 1px;
	width: 1px;
	background-color: #d2cdcb;
	align-self: stretch;
}
section.m35_insights .m35_side {
	padding-left: 90px;
	display: flex;
	flex-direction: column;
	gap: 51px;   /* groesserer Abstand Podcast <-> Veranstaltungen */
}
section.m35_insights .m35_podcast_group {
	display: flex;
	flex-direction: column;
	gap: 22px;   /* Karte <-> „Weitere Folgen"-Link */
}

/* ---------- Gemeinsame Elemente ---------- */
section.m35_insights .m35_date_badge {
	position: absolute;
	top: 20px;
	right: 20px;
	z-index: 2;
	padding: 5px 10px;
	background-color: #f48520;
	color: #fff;
	font-size: 0.9375rem;   /* 15px */
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
}
section.m35_insights .m35_arrow {
	flex: 0 0 auto;
}
section.m35_insights .m35_more {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 1.0625rem;   /* 17px */
	font-weight: 600;
	color: #685a51;
	text-decoration: none;
	margin-top: 17px;
}
section.m35_insights .m35_more_muted {
	color: rgba(104, 90, 81, 0.5);
}
section.m35_insights .m35_more:hover {
	color: #f48520;
	text-decoration: none;   /* nur Farbwechsel, keine Unterstreichung */
}

/* ---------- News ---------- */
section.m35_insights .m35_news_title,
section.m35_insights .m35_news_title * {
	margin: 0;
	font-size: 1.375rem;   /* 22px */
	line-height: 25px;
	font-weight: 900;
	text-transform: uppercase;
	color: #685a51;
}
section.m35_insights .m35_news_title a,
section.m35_insights .m35_news_title a:hover,
section.m35_insights .m35_news_title a:focus {
	color: inherit;
	text-decoration: none;
}

/* Featured */
section.m35_insights .m35_news_media {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 634 / 272;
	overflow: hidden;
	margin-bottom: 28px;
}
section.m35_insights .m35_news_media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
section.m35_insights .m35_news_featured .m35_news_excerpt {
	margin: 12px 0 26px;   /* mehr Abstand zum „News lesen"-Link (Figma) */
	font-size: 1.0625rem;   /* 17px */
	line-height: 25px;
	color: #685a51;
}

/* Kompakt */
section.m35_insights .m35_news_compact {
	display: flex;
	gap: 28px;
	align-items: stretch;   /* Bildspalte waechst auf Texthoehe -> unten buendig mit „News lesen" */
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid #d2cdcb;
}
/* Erstes kompaktes News-Element: etwas mehr Abstand zur Featured-News (Figma) */
section.m35_insights .m35_news_featured + .m35_news_compact {
	margin-top: 31px;
}
/* Datum-Pille der kompakten News: grau hinterlegt, brauner Text, oben im Textbereich (Figma) */
section.m35_insights .m35_date_pill {
	align-self: flex-start;
	padding: 5px 10px;
	background-color: #f4f5f2;
	color: #685a51;
	font-size: 0.9375rem;   /* 15px */
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
}
section.m35_insights .m35_news_thumb {
	position: relative;
	flex: 0 0 143px;
	width: 143px;
	min-height: 143px;   /* Quadrat als Minimum; waechst per stretch auf Texthoehe */
	overflow: hidden;
	background: rgba(104, 90, 81, 0.06);
}
section.m35_insights .m35_news_thumb img {
	position: absolute;   /* bestimmt die Hoehe NICHT selbst -> Spalte stretcht auf Texthoehe */
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
section.m35_insights .m35_news_compact_body {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
/* Mehr Abstand zwischen Titel und „News lesen" (Figma) */
section.m35_insights .m35_news_compact_body .m35_more {
	margin-top: 14px;
}

/* „Zum Newsroom"-Button (per functions.php injiziert) */
section.m35_insights .m35_news_cta {
	margin-top: 59px;
}

/* ---------- Podcast ---------- */
section.m35_insights .m35_podcast {
	background-color: #fff;
}
section.m35_insights .m35_podcast_player {
	position: relative;
	z-index: 2;   /* damit der ueberstehende Play-Button ueber dem Body liegt */
	width: 100%;
	aspect-ratio: 634 / 272;
	/* kein overflow:hidden -> der Play-Button darf ueber die untere Kante ragen (Figma) */
}
/* Cover/Player-Inhalt sauber an der Box clippen, aber den Button NICHT */
section.m35_insights .m35_podcast_cover,
section.m35_insights .m35_podcast_player iframe {
	border-radius: inherit;
}
section.m35_insights .m35_podcast_embed {
	position: absolute;
	inset: 0;
	z-index: 1;
}
/* Das von der Spotify-API erzeugte iframe ersetzt das obige div -> direkt positionieren,
   damit es unsichtbar hinter dem Cover liegt (Cover hat z-index 2). */
section.m35_insights .m35_podcast_player iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	z-index: 1;
	display: block;
}
section.m35_insights .m35_podcast_cover {
	position: absolute;
	inset: 0;
	z-index: 2;
	background-size: cover;
	background-position: center;
	background-color: #f4f5f2;
}
/* Cover bleibt sichtbar – der Spotify-Player spielt unsichtbar dahinter. */
section.m35_insights .m35_badge_neu {
	position: absolute;
	top: 20px;
	left: 20px;
	padding: 5px 12px;
	background-color: #f48520;
	color: #fff;
	font-size: 0.9375rem;   /* 15px */
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
}
section.m35_insights .m35_play {
	position: absolute;
	right: 30px;
	bottom: -30px;   /* ueberlappt die untere Cover-Kante mittig (Figma) */
	width: 60px;
	height: 60px;
	border: 0;
	border-radius: 50%;
	background-color: #f48520;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: transform 0.2s ease, background-color 0.2s ease;
}
/* Icon-Groesse fix erzwingen (globale svg-Resets ueberschreiben das width-Attribut) */
section.m35_insights .m35_play svg {
	display: block;
	max-width: none;
}
section.m35_insights .m35_play_ico--play svg {
	width: 40px;
	height: 27px;
}
section.m35_insights .m35_play_ico--pause svg {
	width: 24px;
	height: 24px;
}
section.m35_insights .m35_play:hover {
	transform: scale(1.08);
	background-color: #e0760f;
}
section.m35_insights .m35_play_ico {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
}
/* Beim Abspielen: Cover + Play-Button ausblenden, YouTube-iframe fuellt den Player */
section.m35_insights .m35_podcast.is-playing .m35_podcast_cover {
	display: none;
}
section.m35_insights .m35_podcast_iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}
section.m35_insights .m35_podcast_body {
	padding: 32px 35px 35px;
	/* Rahmen nur um den Textbereich, ohne obere Kante (Figma) */
	border: 1px solid #d2cdcb;
	border-top: 0;
}
section.m35_insights .m35_podcast_title {
	margin: 0 0 12px;
	font-size: 1.375rem;   /* 22px */
	line-height: 28px;
	font-weight: 900;
	text-transform: uppercase;
	color: #685a51;
}
section.m35_insights .m35_podcast_desc {
	margin: 0;
	font-size: 1.0625rem;   /* 17px */
	line-height: 25px;
	color: #685a51;
}

/* ---------- Veranstaltungen ---------- */
section.m35_insights .m35_events {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
section.m35_insights .m35_event {
	display: flex;
	gap: 22px;
	padding: 17px;
	background-color: #fff;
	border: 1px solid #d2cdcb;
	text-decoration: none;
}
section.m35_insights a.m35_event:hover {
	border-color: #f48520;
}
section.m35_insights .m35_event_date {
	flex: 0 0 147px;
	width: 147px;
	height: 147px;
	box-sizing: border-box;
	padding: 11px;
	background-color: #f4f5f2;
	display: flex;
	flex-direction: column;
	align-items: center;
}
section.m35_insights .m35_event_day {
	width: 100%;
	height: 80px;
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.8125rem;   /* 45px */
	line-height: 1;
	font-weight: 800;
	color: #685a51;
}
section.m35_insights .m35_event_month {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.375rem;   /* 22px */
	font-weight: 600;
	text-transform: uppercase;
	color: #685a51;
}
section.m35_insights .m35_event_body {
	min-width: 0;
	align-self: center;
}
section.m35_insights .m35_event_title {
	margin: 0 0 12px;
	font-size: 1.375rem;   /* 22px */
	line-height: 25px;
	font-weight: 900;
	text-transform: uppercase;
	color: #685a51;
}
section.m35_insights .m35_event_desc {
	margin: 0;
	font-size: 1.0625rem;   /* 17px */
	line-height: 25px;
	color: #685a51;
}
section.m35_insights .m35_events .m35_more {
	margin-top: 4px;
}

/* =========================================================
   Responsive
   ========================================================= */
@media screen and (max-width: 991px) {
	section.m35_insights .m35_grid {
		flex-direction: column;
	}
	section.m35_insights .m35_news {
		padding-right: 0;
		margin-bottom: 48px;
	}
	section.m35_insights .m35_divider {
		display: none;
	}
	section.m35_insights .m35_side {
		padding-left: 0;
	}
	section.m35_insights .m35_header {
		margin-bottom: 32px;
	}
	section.m35_insights .m35_titel,
	section.m35_insights .m35_titel * {
		font-size: 2.25rem;   /* 36px */
		line-height: 1.15;
	}
}

@media screen and (max-width: 600px) {
	/* Kompakte News: Bild ueber den Text (Nebeneinander wird sonst zu eng) */
	section.m35_insights .m35_news_compact {
		flex-direction: column;
		align-items: stretch;
		gap: 16px;
	}
	section.m35_insights .m35_news_thumb {
		flex: 0 0 auto;
		width: 100%;
		min-height: 0;
		aspect-ratio: 16 / 9;
	}
	section.m35_insights .m35_news_compact_body .m35_more {
		margin-top: 6px;
	}
	section.m35_insights .m35_event {
		flex-direction: column;
		gap: 18px;
	}
	section.m35_insights .m35_podcast_body {
		padding: 24px;
	}
}
