/* =========================================================
   TC Reichenstein — Custom Blocks Styling
   Lädt NACH redesign.css + block-adapter.css.
   ========================================================= */

/* =========================================================
   WP ROOT PADDING — seitliche Abstände für normalen Content
   ========================================================= */
:root {
	--wp--style--root--padding-left:  clamp(1rem, 5vw, 2rem);
	--wp--style--root--padding-right: clamp(1rem, 5vw, 2rem);
}
/* Sicherstellen dass entry-content immer seitliche Abstände hat */
.page .entry-content.wp-block-post-content,
.page .wp-block-post-content {
	padding-left:  clamp(1rem, 5vw, 2rem) !important;
	padding-right: clamp(1rem, 5vw, 2rem) !important;
}
/* Fullbleed-Blöcke brechen trotzdem raus */
.page .entry-content > .alignfull,
.page .wp-block-post-content > .alignfull {
	margin-left:  calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	width:        100vw !important;
	max-width:    100vw !important;
}
/* TCR-Custom-Blocks haben eigene Inner-Wrapper mit Padding */
.page .entry-content > .alignfull.tcr-fullbleed,
.page .entry-content > .alignfull[class*="tcr-block-"],
.page .wp-block-post-content > .alignfull.tcr-fullbleed,
.page .wp-block-post-content > .alignfull[class*="tcr-block-"] {
	padding-left: 0 !important;
	padding-right: 0 !important;
}
/* Normale WP-Gruppen-Blocks mit alignfull + Hintergrund brauchen Mobile-Padding,
   damit der Text nicht am Rand klebt. has-global-padding ist gesetzt aber theme.json
   liefert 0 — daher müssen wir hier explizit Mobile-Padding setzen. */
.page .entry-content > .alignfull.has-global-padding:not(.tcr-fullbleed):not([class*="tcr-block-"]),
.page .wp-block-post-content > .alignfull.has-global-padding:not(.tcr-fullbleed):not([class*="tcr-block-"]) {
	padding-left:  clamp(1.25rem, 5vw, 2.5rem) !important;
	padding-right: clamp(1.25rem, 5vw, 2.5rem) !important;
	box-sizing: border-box;
}
/* Startseite (ID:5) soll kein extra Padding bekommen */
.page-id-5 .entry-content.wp-block-post-content,
.home .entry-content.wp-block-post-content {
	padding-left:  0 !important;
	padding-right: 0 !important;
}

/* Wenn die Seite mit einem full-bleed Banner endet, soll kein weißer
   Streifen zwischen Banner und Footer bleiben. */
.page .entry-content.wp-block-post-content:has(> .alignfull:last-child),
.page .wp-block-post-content:has(> .alignfull:last-child) {
	padding-bottom: 0 !important;
}
.page .wp-block-post-content > .alignfull:last-child {
	margin-bottom: 0 !important;
	margin-top: 0 !important;
}

/* =========================================================
   FULL-BLEED 100vw für alle TCR-Blöcke
   Greift unabhängig von der DOM-Tiefe (direkter Child von main
   oder unter wp-block-post-content).
   ========================================================= */
.entry-content > .alignfull.tcr-fullbleed,
.wp-block-post-content > .alignfull.tcr-fullbleed,
main.wp-block-group > .alignfull.tcr-fullbleed,
.alignfull.tcr-fullbleed[class*="tcr-block-"] {
	width: 100vw !important;
	max-width: 100vw !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	box-sizing: border-box;
}

/* =========================================================
   tcr/header
   ========================================================= */
.tcr-block-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(255,255,255,.85);
	backdrop-filter: saturate(180%) blur(14px);
	-webkit-backdrop-filter: saturate(180%) blur(14px);
	border-bottom: 1px solid rgba(220,229,242,.6);
	padding: 1.1rem 2rem !important;
	transition: background 240ms cubic-bezier(.22,.61,.36,1), box-shadow 240ms cubic-bezier(.22,.61,.36,1);
	margin: 0 !important;
}
.tcr-block-header.is-scrolled {
	background: rgba(255,255,255,.96);
	box-shadow: 0 4px 20px -8px rgba(14,58,138,.18);
}
.tcr-header-inner {
	max-width: 1240px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
}

/* Nav-Link Farbe: sicherstellen dass Links dunkel sind (overrides alle WP-Defaults) */
.tcr-block-header .wp-block-navigation-item__content {
	color: #1F2433 !important;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.95rem;
	font-weight: 500;
	letter-spacing: -0.005em;
	padding: 0.4rem 0.6rem;
	border-radius: 6px;
	transition: color 180ms ease, background 180ms ease;
}
.tcr-block-header .wp-block-navigation-item__content:hover {
	color: var(--tcr-primary, #0E3A8A) !important;
	background: rgba(14,58,138,.06);
}
.tcr-block-header .wp-block-navigation .current-menu-item > .wp-block-navigation-item__content {
	color: var(--tcr-primary, #0E3A8A) !important;
	font-weight: 600;
}
/* Submenu dropdown */
.tcr-block-header .wp-block-navigation__submenu-container {
	border-radius: 10px !important;
	border: 1px solid rgba(14,58,138,.12) !important;
	box-shadow: 0 8px 24px rgba(14,58,138,.12) !important;
	padding: 0.4rem !important;
	min-width: 210px !important;
	top: calc(100% + 6px) !important;
}
.tcr-block-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	padding: 0.5rem 0.85rem !important;
	border-radius: 6px;
}
/* CTA "Mitglied werden" bleibt weiss auf blauem BG */
.tcr-block-header .tcr-nav-cta > a.wp-block-navigation-item__content {
	color: #fff !important;
	background: var(--tcr-primary-dark, #06214F) !important;
	padding: 0.6rem 1.25rem !important;
	border-radius: 999px !important;
	font-weight: 600 !important;
}
.tcr-block-header .tcr-nav-cta > a.wp-block-navigation-item__content:hover {
	background: #0E3A8A !important;
	color: #fff !important;
}
.tcr-block-header .tcr-logo {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none;
	line-height: 1;
	margin-left: 1rem;
}
.tcr-block-header .tcr-logo-mark {
	height: 52px;
	width: auto;
	display: block;
	margin-right: 0.75rem;
}
@media (max-width: 600px) {
	.tcr-block-header .tcr-logo-mark {
		margin-right: 0.75rem !important;
	}
	.tcr-block-header .tcr-logo {
		margin-left: 1rem !important;
		margin-right: 0 !important;
	}
}
.tcr-block-header .tcr-logo-wordmark {
	display: flex;
	flex-direction: column;
	line-height: 1.05;
}
.tcr-block-header .tcr-logo-wordmark-top {
	font-family: 'DM Sans', sans-serif;
	font-weight: 500;
	font-size: 0.8rem;
	letter-spacing: 0.06em;
	color: var(--tcr-primary);
	text-transform: none;
}
.tcr-block-header .tcr-logo-wordmark-bottom {
	font-family: 'DM Sans', sans-serif;
	font-weight: 700;
	font-size: 1.25rem;
	letter-spacing: -.015em;
	color: var(--tcr-ink);
}
@media (max-width: 520px) {
	.tcr-block-header .tcr-logo-wordmark { display: none; }
}

/* =========================================================
   tcr/footer
   ========================================================= */
.tcr-block-footer {
	background: var(--tcr-primary-dark);
	color: rgba(255,255,255,.78);
	position: relative;
	overflow: hidden;
	margin: 0 !important;
	padding: 0 !important;
}
.tcr-block-footer::before {
	content: "";
	position: absolute;
	top: -200px; right: -100px;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(46,98,214,.30), transparent 70%);
	filter: blur(40px);
	pointer-events: none;
}
.tcr-block-footer::after {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.15), transparent);
}
.tcr-block-footer .tcr-footer-inner {
	position: relative;
	z-index: 1;
	max-width: 1240px;
	margin: 0 auto;
	padding: clamp(3.5rem, 7vw, 5.5rem) clamp(1.25rem, 4vw, 2.5rem) 1.5rem;
}
.tcr-block-footer .tcr-footer-top {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}
@media (min-width: 900px) {
	.tcr-block-footer .tcr-footer-top {
		grid-template-columns: 1.1fr 1.6fr;
		gap: 4rem;
	}
}
.tcr-block-footer .tcr-footer-logo {
	display: flex;
	align-items: center;
	gap: .9rem;
	margin-bottom: 1.25rem;
}
.tcr-block-footer .tcr-footer-logo img {
	width: 48px;
	height: 48px;
	background: #FFFFFF;
	border-radius: 12px;
	padding: 4px;
}
.tcr-block-footer .tcr-footer-logo > div {
	display: flex;
	flex-direction: column;
	line-height: 1.1;
}
.tcr-block-footer .tcr-footer-brand-top {
	color: rgba(255,255,255,.6);
	font-size: .8rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 500;
}
.tcr-block-footer .tcr-footer-brand-bottom {
	color: #FFFFFF;
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: -.015em;
}
.tcr-block-footer .tcr-footer-tagline {
	color: rgba(255,255,255,.65);
	font-size: .95rem;
	line-height: 1.65;
	margin: 0 0 1.5rem;
	max-width: 38ch;
}
.tcr-block-footer .tcr-footer-cta {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .85rem 1.5rem;
	background: #FFFFFF;
	color: var(--tcr-primary-dark);
	border-radius: 999px;
	font-weight: 700;
	font-size: .92rem;
	text-decoration: none;
	transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-footer .tcr-footer-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 32px rgba(0,0,0,.3);
}
.tcr-block-footer .tcr-footer-nav {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 600px) {
	.tcr-block-footer .tcr-footer-nav {
		grid-template-columns: repeat(3, 1fr);
		gap: 2rem;
	}
}
.tcr-block-footer .tcr-footer-col h4 {
	color: #FFFFFF;
	font-size: .7rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 700;
	margin: 0 0 1.25rem;
	padding-bottom: .8rem;
	border-bottom: 1px solid rgba(255,255,255,.12);
	position: relative;
}
.tcr-block-footer .tcr-footer-col h4::after {
	content: "";
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 28px;
	height: 1px;
	background: #FFFFFF;
}
.tcr-block-footer .tcr-footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: .55rem;
}
.tcr-block-footer .tcr-footer-col ul a {
	color: rgba(255,255,255,.78);
	text-decoration: none;
	font-size: .95rem;
	transition: color 200ms cubic-bezier(.22,.61,.36,1), padding-left 200ms cubic-bezier(.22,.61,.36,1);
	display: inline-block;
}
.tcr-block-footer .tcr-footer-col ul a:hover {
	color: #FFFFFF;
	padding-left: .2rem;
}
.tcr-block-footer address {
	font-style: normal;
	color: rgba(255,255,255,.78);
	font-size: .95rem;
	line-height: 1.7;
}
.tcr-block-footer address p { margin: 0 0 .5rem; }
.tcr-block-footer address a {
	color: #FFFFFF;
	text-decoration: underline;
	text-decoration-color: rgba(255,255,255,.3);
	text-underline-offset: 3px;
}
.tcr-block-footer address a:hover { text-decoration-color: #FFFFFF; }
.tcr-block-footer .tcr-footer-anlage {
	color: rgba(255,255,255,.55);
	font-size: .85rem;
}

/* Footer-Marquee */
.tcr-block-footer .tcr-footer-marquee {
	margin: 3.5rem 0 2rem;
	display: flex;
	gap: 1.5rem;
	white-space: nowrap;
	overflow: hidden;
	font-family: 'DM Sans', sans-serif;
	font-size: clamp(2.4rem, 6vw, 4.2rem);
	font-weight: 800;
	letter-spacing: -.04em;
	user-select: none;
	mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.tcr-block-footer .tcr-footer-marquee-track {
	display: flex;
	gap: 1.5rem;
	white-space: nowrap;
	flex-shrink: 0;
	padding-right: 1.5rem;
	animation: tcrFooterScroll 40s linear infinite;
}
.tcr-block-footer .tcr-footer-marquee-track > span:not(.tcr-footer-marquee-sep) {
	-webkit-text-stroke: 1px rgba(255,255,255,.25);
	color: transparent;
	line-height: 1;
}
.tcr-block-footer .tcr-footer-marquee-sep {
	color: rgba(255,255,255,.45);
	-webkit-text-stroke: 0;
	font-size: 0.35em;
	align-self: center;
}

.tcr-block-footer .tcr-footer-bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255,255,255,.10);
}
.tcr-block-footer .tcr-footer-copy {
	color: rgba(255,255,255,.5);
	font-size: .82rem;
	margin: 0;
}
.tcr-block-footer .tcr-footer-legal {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 1.5rem;
}
.tcr-block-footer .tcr-footer-legal a {
	color: rgba(255,255,255,.55);
	text-decoration: none;
	font-size: .82rem;
	transition: color 200ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-footer .tcr-footer-legal a:hover { color: #FFFFFF; }

/* =========================================================
   tcr/hero
   ========================================================= */
.tcr-block-hero {
	margin: 0 !important;
	display: block;
}
.tcr-block-hero .tcr-hero-wrap {
	position: relative;
	min-height: clamp(580px, 88vh, 840px);
	background: #06214F;
	display: flex;
	align-items: center;
	overflow: hidden;
	isolation: isolate;
}
.tcr-block-hero .tcr-hero-image {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center 55%;
	background-repeat: no-repeat;
	z-index: 1;
	transform: scale(1.02);
	filter: saturate(1.06) contrast(1.03);
	animation: tcrHeroZoom 22s cubic-bezier(.22,.61,.36,1) infinite alternate;
}
.tcr-block-hero .tcr-hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	background:
		linear-gradient(180deg, rgba(6,33,79,.20) 0%, rgba(6,33,79,.55) 55%, rgba(6,33,79,.92) 100%),
		linear-gradient(115deg, rgba(14,58,138,.55) 0%, rgba(6,33,79,0) 60%);
	pointer-events: none;
}
.tcr-block-hero .tcr-hero-inner {
	position: relative;
	z-index: 3;
	padding-top: clamp(2rem, 6vw, 5rem);
	padding-bottom: clamp(2.5rem, 7vw, 5rem);
	padding-left: max(1.5rem, calc((100% - 1240px) / 2));
	padding-right: max(1.5rem, calc((100% - 1240px) / 2));
	width: 100%;
	box-sizing: border-box;
}
.tcr-block-hero .tcr-hero-inner > * { max-width: 900px; }

.tcr-block-hero .tcr-hero-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	padding: .45rem 1.05rem;
	background: rgba(255,255,255,.10);
	border: 1px solid rgba(255,255,255,.22);
	border-radius: 999px;
	font-family: 'DM Sans', sans-serif;
	font-size: .8rem;
	font-weight: 500;
	letter-spacing: .04em;
	color: rgba(255,255,255,.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	margin: 0 0 1.5rem;
	width: auto;
}
.tcr-block-hero .tcr-hero-eyebrow::before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	background: #FFFFFF;
	border-radius: 50%;
	box-shadow: 0 0 12px rgba(255,255,255,.7);
	animation: tcrPulse 2.4s ease-in-out infinite;
}

.tcr-block-hero .tcr-hero-title {
	font-family: 'DM Sans', sans-serif;
	font-size: clamp(2.75rem, 6.5vw, 5rem);
	font-weight: 700;
	line-height: 1.02;
	letter-spacing: -.02em;
	margin: 0 0 1.5rem;
	color: #FFFFFF;
}
.tcr-block-hero .tcr-hero-title em { font-style: normal; }
.tcr-block-hero .tcr-h1-accent {
	position: relative;
	display: inline-block;
	white-space: nowrap;
}
.tcr-block-hero .tcr-h1-accent::after {
	content: "";
	position: absolute;
	left: -2%;
	right: -2%;
	bottom: -.05em;
	height: .12em;
	background: rgba(255,255,255,.95);
	border-radius: 999px;
	transform-origin: left center;
	animation: tcrUnderlineGrow 1800ms 800ms cubic-bezier(.16,1,.3,1) both;
}
@keyframes tcrUnderlineGrow {
	from { transform: scaleX(0); }
	to   { transform: scaleX(1); }
}

.tcr-block-hero .tcr-hero-lead {
	font-size: clamp(1.1rem, 1.5vw, 1.3rem);
	color: rgba(255,255,255,.92);
	line-height: 1.6;
	margin: 0 0 2.25rem;
	max-width: 600px;
}

.tcr-block-hero .tcr-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
}
.tcr-block-hero .tcr-btn {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	padding: .95rem 1.85rem;
	font-family: 'DM Sans', sans-serif;
	font-weight: 600;
	font-size: .95rem;
	border-radius: 999px;
	text-decoration: none;
	border: 2px solid transparent;
	transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms cubic-bezier(.22,.61,.36,1), background 220ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-hero .tcr-btn-primary {
	background: #FFFFFF;
	color: var(--tcr-primary-dark);
}
.tcr-block-hero .tcr-btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(0,0,0,.28);
}
.tcr-block-hero .tcr-btn-ghost {
	background: transparent;
	color: #FFFFFF;
	border-color: rgba(255,255,255,.55);
}
.tcr-block-hero .tcr-btn-ghost:hover {
	background: rgba(255,255,255,.08);
	border-color: #FFFFFF;
	transform: translateY(-2px);
}
.tcr-block-hero .tcr-btn-arrow {
	transition: transform 240ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-hero .tcr-btn:hover .tcr-btn-arrow {
	transform: translateX(4px);
}

.tcr-block-hero .tcr-hero-meta {
	display: flex;
	gap: 2.5rem;
	margin-top: clamp(2.5rem, 5vw, 4rem);
}
.tcr-block-hero .tcr-hero-stat {
	display: flex;
	flex-direction: column;
	gap: .25rem;
}
.tcr-block-hero .tcr-hero-stat-num {
	font-family: 'DM Sans', sans-serif;
	font-size: 1.85rem;
	font-weight: 700;
	color: #FFFFFF;
	line-height: 1;
	letter-spacing: -.02em;
}
.tcr-block-hero .tcr-hero-stat-label {
	font-size: .72rem;
	color: rgba(255,255,255,.7);
	letter-spacing: .14em;
	text-transform: uppercase;
	font-weight: 500;
}
@media (max-width: 720px) {
	.tcr-block-hero .tcr-hero-meta { display: none; }
}

/* =========================================================
   tcr/marquee-stripe
   ========================================================= */
.tcr-block-stripe {
	background: var(--tcr-primary-dark);
	color: #FFFFFF;
	overflow: hidden;
	padding: .85rem 0;
	margin: 0 !important;
}
.tcr-block-stripe .tcr-stripe-track {
	display: flex;
	gap: 2.5rem;
	white-space: nowrap;
	font-family: 'DM Sans', sans-serif;
	font-size: .78rem;
	font-weight: 500;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: rgba(255,255,255,.85);
	animation: tcrMarquee 44s linear infinite;
	will-change: transform;
}
.tcr-block-stripe .tcr-stripe-sep {
	color: rgba(255,255,255,.35);
}

/* =========================================================
   Section-Wrapper (geteilt)
   ========================================================= */
.tcr-block-section-anlage,
.tcr-block-section-angebote,
.tcr-block-section-tradition,
.tcr-block-section-news,
.tcr-block-section-termine {
	padding: clamp(4rem, 7vw, 7rem) 0 !important;
	margin: 0 !important;
	position: relative;
}
.tcr-block-section-news,
.tcr-block-section-termine {
	padding: clamp(3rem, 5vw, 4.5rem) 0 clamp(2rem, 4vw, 3rem) !important;
}
.tcr-block-section-termine {
	padding-bottom: clamp(3rem, 5vw, 4.5rem) !important;
}
.tcr-block-section-angebote {
	background: #ffffff;
}
.tcr-block-section-anlage .tcr-section-inner,
.tcr-block-section-angebote .tcr-section-inner,
.tcr-block-section-tradition .tcr-section-inner,
.tcr-block-section-news .tcr-section-inner,
.tcr-block-section-termine .tcr-section-inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}
.tcr-block-section-anlage .tcr-section-head {
	max-width: 720px;
	margin: 0 auto clamp(2.5rem, 5vw, 4rem);
	text-align: center;
}
.tcr-block-section-angebote .tcr-section-head-split,
.tcr-block-section-news .tcr-section-head-split,
.tcr-block-section-termine .tcr-section-head-split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-bottom: clamp(2rem, 4vw, 3rem);
	align-items: end;
}
@media (min-width: 860px) {
	.tcr-block-section-angebote .tcr-section-head-split,
	.tcr-block-section-news .tcr-section-head-split,
	.tcr-block-section-termine .tcr-section-head-split {
		grid-template-columns: 1.2fr 1fr;
		gap: 3rem;
	}
}

/* Geteilte Section-Elemente */
.tcr-block-section-anlage .tcr-eyebrow,
.tcr-block-section-angebote .tcr-eyebrow,
.tcr-block-section-tradition .tcr-eyebrow,
.tcr-block-section-news .tcr-eyebrow,
.tcr-block-section-termine .tcr-eyebrow,
.tcr-block-section-partners .tcr-eyebrow {
	color: var(--tcr-primary);
	font-size: .74rem;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	margin: 0 0 .9rem;
}
.tcr-block-section-anlage .tcr-eyebrow::before,
.tcr-block-section-angebote .tcr-eyebrow::before,
.tcr-block-section-tradition .tcr-eyebrow::before,
.tcr-block-section-news .tcr-eyebrow::before,
.tcr-block-section-termine .tcr-eyebrow::before,
.tcr-block-section-partners .tcr-eyebrow::before {
	content: "";
	width: 28px;
	height: 1px;
	background: currentColor;
}
.tcr-block-section-anlage .tcr-section-h2,
.tcr-block-section-angebote .tcr-section-h2,
.tcr-block-section-tradition .tcr-section-h2,
.tcr-block-section-news .tcr-section-h2,
.tcr-block-section-termine .tcr-section-h2,
.tcr-block-section-partners .tcr-section-h2 {
	font-size: clamp(2rem, 4vw, 3.2rem);
	font-weight: 700;
	line-height: 1.04;
	letter-spacing: -.025em;
	margin: 0;
	color: var(--tcr-ink);
}
.tcr-block-section-anlage .tcr-lede,
.tcr-block-section-angebote .tcr-lede {
	font-size: clamp(1rem, 1.3vw, 1.15rem);
	color: var(--tcr-muted);
	line-height: 1.65;
	margin: 1rem 0 0;
	max-width: 56ch;
}
.tcr-block-section-anlage .tcr-section-head {
	text-align: center;
}
.tcr-block-section-anlage .tcr-section-head .tcr-eyebrow,
.tcr-block-section-anlage .tcr-section-head .tcr-section-h2 {
	margin-left: auto;
	margin-right: auto;
}
.tcr-block-section-anlage .tcr-section-head .tcr-lede {
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}
.tcr-section-link {
	font-family: 'DM Sans', sans-serif;
	font-weight: 600;
	color: var(--tcr-primary);
	text-decoration: none;
	font-size: .9rem;
	border-bottom: 1px solid currentColor;
	padding-bottom: 2px;
	transition: gap 200ms cubic-bezier(.22,.61,.36,1), color 200ms cubic-bezier(.22,.61,.36,1);
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	justify-self: end;
	align-self: end;
}
.tcr-section-link:hover {
	color: var(--tcr-primary-light);
	gap: .7rem;
}

/* =========================================================
   tcr/showcase-card
   ========================================================= */
.tcr-block-section-anlage .tcr-showcase {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-auto-rows: minmax(260px, auto);
	gap: 1.25rem;
}
@media (min-width: 900px) {
	.tcr-block-section-anlage .tcr-showcase {
		grid-template-columns: repeat(3, 1fr);
		grid-auto-rows: 320px;
		gap: 1.5rem;
	}
}
.tcr-block-showcase-card {
	position: relative;
	margin: 0;
	overflow: hidden;
	border-radius: var(--tcr-radius-lg);
	box-shadow: var(--tcr-shadow-card);
	background: var(--tcr-primary-dark);
	min-height: 320px;
	transition: box-shadow 320ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-showcase-card.tcr-showcase-lg {
	grid-column: span 2;
	grid-row: span 2;
	min-height: 380px;
}
@media (max-width: 899px) {
	.tcr-block-showcase-card.tcr-showcase-lg { grid-row: span 1; }
}
.tcr-block-showcase-card .tcr-showcase-card-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transform: scale(1.02);
	transition: transform 1400ms cubic-bezier(.22,.61,.36,1), filter 600ms cubic-bezier(.22,.61,.36,1);
	z-index: 1;
}
.tcr-block-showcase-card::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	background: linear-gradient(180deg, rgba(6,33,79,0) 30%, rgba(6,33,79,.92) 100%);
	pointer-events: none;
}
.tcr-block-showcase-card .tcr-showcase-card-caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 1.4rem 1.6rem;
	color: #FFFFFF;
	z-index: 3;
	margin: 0;
}
.tcr-block-showcase-card .tcr-tag {
	display: inline-block;
	padding: .25rem .7rem;
	margin-bottom: .55rem;
	background: rgba(255,255,255,.18);
	border: 1px solid rgba(255,255,255,.32);
	border-radius: 999px;
	font-size: .68rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: #FFFFFF;
	backdrop-filter: blur(8px);
}
.tcr-block-showcase-card .tcr-showcase-card-title {
	font-family: 'DM Sans', sans-serif;
	font-size: clamp(1.1rem, 1.6vw, 1.5rem);
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1.15;
	color: #FFFFFF;
	margin: 0;
	text-shadow: 0 2px 12px rgba(6,33,79,.6);
}
.tcr-block-showcase-card .tcr-showcase-card-subtitle {
	font-size: .88rem;
	color: rgba(255,255,255,.85);
	margin: .4rem 0 0;
}
.tcr-block-showcase-card:hover .tcr-showcase-card-img {
	transform: scale(1.08);
	filter: brightness(1.06);
}
.tcr-block-showcase-card:hover {
	box-shadow: var(--tcr-shadow-hover);
}

/* =========================================================
   tcr/angebote-card
   ========================================================= */
.tcr-block-section-angebote .tcr-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.25rem;
}
.tcr-block-angebote-card {
	display: block;
	padding: 1.75rem 1.5rem 1.6rem;
	background: #FFFFFF;
	border: 1px solid #dce5f2;
	border-radius: var(--tcr-radius-md);
	text-decoration: none;
	color: var(--tcr-ink);
	transition:
		transform 300ms cubic-bezier(.22,.61,.36,1),
		box-shadow 300ms cubic-bezier(.22,.61,.36,1),
		border-color 300ms cubic-bezier(.22,.61,.36,1);
	position: relative;
	overflow: hidden;
}
/* top-accent bar — hidden by default */
.tcr-block-angebote-card::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, #1a3a6e 0%, #2E62D6 60%, #5b8ef0 100%);
	opacity: 0;
	transition: opacity 300ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-angebote-card .tcr-card-icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: #eef3fc;
	color: #2E62D6;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: 'DM Sans', sans-serif;
	font-size: 1.05rem;
	font-weight: 700;
	letter-spacing: -.01em;
	margin-bottom: 1.2rem;
	transition:
		transform 300ms cubic-bezier(.22,.61,.36,1),
		background 300ms cubic-bezier(.22,.61,.36,1),
		color 300ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-angebote-card .tcr-card-title {
	font-family: 'DM Sans', sans-serif;
	font-size: 1.18rem;
	font-weight: 700;
	letter-spacing: -.02em;
	margin: 0 0 .45rem;
	color: var(--tcr-ink) !important;
}
.tcr-block-angebote-card .tcr-card-text {
	color: var(--tcr-muted);
	font-size: .94rem;
	line-height: 1.6;
	margin: 0 0 1.15rem;
}
.tcr-block-angebote-card .tcr-card-link {
	color: #2E62D6;
	font-weight: 600;
	font-size: .9rem;
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	transition: gap 220ms cubic-bezier(.22,.61,.36,1), color 220ms;
}
/* ── Hover ── */
.tcr-block-angebote-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 12px 32px -8px rgba(46,98,214,.18), 0 2px 8px -2px rgba(46,98,214,.10);
	border-color: #a8c0f0;
}
.tcr-block-angebote-card:hover::before {
	opacity: 1;
}
.tcr-block-angebote-card:hover .tcr-card-icon {
	background: #2E62D6;
	color: #ffffff;
	transform: scale(1.08);
}
.tcr-block-angebote-card:hover .tcr-card-link {
	gap: .6rem;
	color: #1a3a6e;
}

/* =========================================================
   tcr/section-tradition
   ========================================================= */
.tcr-block-section-tradition .tcr-split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 900px) {
	.tcr-block-section-tradition .tcr-split {
		grid-template-columns: 1fr 1.05fr;
		gap: 4rem;
	}
}
.tcr-block-section-tradition .tcr-split-text p {
	color: var(--tcr-muted);
	font-size: 1.05rem;
	line-height: 1.7;
	margin: 1.25rem 0 0;
}
.tcr-block-section-tradition .tcr-split-text > .tcr-eyebrow {
	margin-bottom: .9rem;
}
.tcr-block-section-tradition .tcr-split-text > .tcr-section-h2 {
	margin: 0 0 1.25rem;
}
.tcr-block-section-tradition .tcr-stats {
	margin-top: 2.5rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--tcr-line);
}
.tcr-block-section-tradition .tcr-stat-num {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: clamp(1.8rem, 3.6vw, 2.6rem);
	font-weight: 700;
	color: var(--tcr-primary);
	line-height: 1;
	letter-spacing: -.03em;
	font-variant-numeric: tabular-nums;
}
.tcr-block-section-tradition .tcr-stat-label {
	display: block;
	margin-top: .4rem;
	font-size: .72rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--tcr-muted);
	font-weight: 600;
}
.tcr-block-section-tradition .tcr-split-media {
	position: relative;
	min-height: 440px;
}
.tcr-block-section-tradition .tcr-split-img {
	position: absolute;
	border-radius: var(--tcr-radius-xl);
	box-shadow: var(--tcr-shadow-card);
	object-fit: cover;
	display: block;
	transition: transform 700ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-section-tradition .tcr-split-img-1 {
	width: 78%;
	height: 80%;
	top: 0;
	right: 0;
	animation: tcrFloatSoft 7s ease-in-out infinite;
}
.tcr-block-section-tradition .tcr-split-img-2 {
	width: 48%;
	height: 48%;
	bottom: -2%;
	left: 0;
	border: 6px solid #FFFFFF;
	animation: tcrFloatSoft 7s ease-in-out infinite reverse;
	animation-delay: -2s;
	z-index: 2;
}
.tcr-block-section-tradition .tcr-split-badge {
	position: absolute;
	bottom: 6%;
	right: -1rem;
	width: 116px;
	height: 116px;
	border-radius: 50%;
	background: var(--tcr-primary);
	color: #FFFFFF;
	display: grid;
	place-items: center;
	text-align: center;
	font-family: 'DM Sans', sans-serif;
	box-shadow: 0 24px 50px -10px rgba(14,58,138,.45);
	z-index: 3;
	animation: tcrSpin 24s linear infinite;
}
.tcr-block-section-tradition .tcr-split-badge-year {
	display: block;
	font-size: .62rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: rgba(255,255,255,.65);
	margin-bottom: .1rem;
}
.tcr-block-section-tradition .tcr-split-badge-num {
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: -.02em;
	color: #FFFFFF;
}

/* =========================================================
   tcr/cta-strip
   ========================================================= */
.tcr-block-cta-strip {
	background:
		radial-gradient(700px 320px at 80% 30%, rgba(255,255,255,.10), transparent 60%),
		linear-gradient(135deg, var(--tcr-primary-dark) 0%, var(--tcr-primary) 60%, var(--tcr-primary-light) 100%);
	color: #FFFFFF;
	position: relative;
	overflow: hidden;
	isolation: isolate;
	margin: 0 !important;
}
.tcr-block-cta-strip::before,
.tcr-block-cta-strip::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	z-index: -1;
}
.tcr-block-cta-strip::before {
	width: 520px;
	height: 520px;
	background: radial-gradient(circle, rgba(255,255,255,.10), transparent 70%);
	top: -180px;
	left: -100px;
	animation: tcrFloat 16s ease-in-out infinite;
}
.tcr-block-cta-strip::after {
	width: 380px;
	height: 380px;
	background: radial-gradient(circle, rgba(255,255,255,.20), transparent 70%);
	bottom: -140px;
	right: -80px;
	animation: tcrFloat 20s ease-in-out infinite reverse;
}
.tcr-block-cta-strip .tcr-cta-strip-inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: clamp(3rem, 6vw, 5rem) clamp(1.25rem, 4vw, 2.5rem);
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 860px) {
	.tcr-block-cta-strip .tcr-cta-strip-inner {
		grid-template-columns: 1.3fr 1fr;
		gap: 4rem;
	}
}
.tcr-block-cta-strip .tcr-eyebrow-light {
	color: rgba(255,255,255,.85);
	font-size: .74rem;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	margin: 0 0 .9rem;
}
.tcr-block-cta-strip .tcr-eyebrow-light::before {
	content: "";
	width: 28px;
	height: 1px;
	background: currentColor;
}
.tcr-block-cta-strip .tcr-cta-strip-title {
	color: #FFFFFF;
	font-family: 'DM Sans', sans-serif;
	font-size: clamp(1.85rem, 3.6vw, 2.85rem);
	font-weight: 700;
	margin: 0 0 1.1rem;
	line-height: 1.05;
	letter-spacing: -.02em;
}
.tcr-block-cta-strip .tcr-cta-strip-lead {
	color: rgba(255,255,255,.88);
	font-size: 1.05rem;
	line-height: 1.6;
	margin: 0;
	max-width: 50ch;
}
.tcr-block-cta-strip .tcr-cta-strip-actions {
	display: flex;
	flex-wrap: wrap;
	gap: .85rem;
	justify-self: end;
}
@media (max-width: 859px) {
	.tcr-block-cta-strip .tcr-cta-strip-actions {
		justify-self: start;
	}
}
.tcr-block-cta-strip .tcr-btn {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	padding: .95rem 1.85rem;
	font-family: 'DM Sans', sans-serif;
	font-weight: 600;
	font-size: .95rem;
	border-radius: 999px;
	text-decoration: none;
	border: 2px solid transparent;
	transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms cubic-bezier(.22,.61,.36,1), background 220ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-cta-strip .tcr-btn-light {
	background: #FFFFFF;
	color: var(--tcr-primary-dark);
	border-color: #FFFFFF;
	box-shadow: 0 12px 28px rgba(0,0,0,.2);
}
.tcr-block-cta-strip .tcr-btn-light:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 36px rgba(0,0,0,.28);
}
.tcr-block-cta-strip .tcr-btn-outline-light {
	background: transparent;
	color: #FFFFFF;
	border-color: rgba(255,255,255,.65);
}
.tcr-block-cta-strip .tcr-btn-outline-light:hover {
	background: rgba(255,255,255,.1);
	border-color: #FFFFFF;
	transform: translateY(-2px);
}
.tcr-block-cta-strip .tcr-btn-arrow {
	transition: transform 240ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-cta-strip .tcr-btn:hover .tcr-btn-arrow {
	transform: translateX(4px);
}

/* =========================================================
   tcr/section-news
   ========================================================= */
.tcr-block-section-news .tcr-news-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
}
.tcr-block-section-news .tcr-news-card {
	background: #FFFFFF;
	border: 1px solid var(--tcr-line);
	border-radius: var(--tcr-radius-md);
	overflow: hidden;
	transition: transform 320ms cubic-bezier(.22,.61,.36,1), box-shadow 320ms cubic-bezier(.22,.61,.36,1);
	display: flex;
	flex-direction: column;
}
.tcr-block-section-news .tcr-news-card-img {
	display: block;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--tcr-primary-50);
}
.tcr-block-section-news .tcr-news-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 700ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-section-news .tcr-news-card-body {
	padding: 1.2rem 1.4rem 1.4rem;
}
.tcr-block-section-news .tcr-news-card-date {
	display: block;
	color: var(--tcr-primary);
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
}
.tcr-block-section-news .tcr-news-card-title {
	margin: .4rem 0 .55rem;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: -.015em;
}
.tcr-block-section-news .tcr-news-card-title a {
	color: var(--tcr-ink);
	text-decoration: none;
	transition: color 200ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-section-news .tcr-news-card-title a:hover { color: var(--tcr-primary); }
.tcr-block-section-news .tcr-news-card-excerpt {
	color: var(--tcr-muted);
	font-size: .95rem;
	line-height: 1.55;
	margin: 0 0 1rem;
}
.tcr-block-section-news .tcr-news-card-link {
	color: var(--tcr-primary);
	font-weight: 600;
	font-size: .88rem;
	text-decoration: none;
}
.tcr-block-section-news .tcr-news-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--tcr-shadow-hover);
}
.tcr-block-section-news .tcr-news-card:hover .tcr-news-card-img img {
	transform: scale(1.05);
}

/* =========================================================
   tcr/section-partners
   ========================================================= */
.tcr-block-section-partners {
	padding: clamp(4rem, 7vw, 7rem) 0 clamp(5rem, 9vw, 8rem);
	background: linear-gradient(180deg, #FFFFFF 0%, var(--tcr-primary-50) 100%);
	margin: 0 !important;
}
.tcr-block-section-partners .tcr-partners-inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 4vw, 2.5rem);
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 900px) {
	.tcr-block-section-partners .tcr-partners-inner {
		grid-template-columns: 1fr 1.4fr;
		gap: 4rem;
	}
}
.tcr-block-section-partners .tcr-partners-intro p {
	color: var(--tcr-muted);
	font-size: 1rem;
	line-height: 1.7;
	margin: 1rem 0 1.5rem;
	max-width: 36ch;
}
.tcr-block-section-partners .tcr-partners-link {
	color: var(--tcr-primary);
	font-weight: 600;
	text-decoration: none;
	font-size: .92rem;
	border-bottom: 1px solid currentColor;
	padding-bottom: 2px;
	display: inline-block;
}
.tcr-block-section-partners .tcr-partners-link:hover { color: var(--tcr-primary-light); }
.tcr-block-section-partners .tcr-partners-logos {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1px;
	background: var(--tcr-line);
	border: 1px solid var(--tcr-line);
	border-radius: var(--tcr-radius-md);
	overflow: hidden;
}
.tcr-block-partner-tile {
	background: #FFFFFF;
	min-height: 160px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 1.5rem 1rem;
	text-decoration: none;
	gap: .8rem;
	transition: background 280ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-partner-tile .tcr-partner-tile-logo {
	max-height: 56px;
	max-width: 70%;
	width: auto;
	height: auto;
	filter: grayscale(1);
	opacity: .65;
	transition: filter 320ms cubic-bezier(.22,.61,.36,1), opacity 320ms cubic-bezier(.22,.61,.36,1), transform 320ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-partner-tile .tcr-partner-tile-name {
	font-size: .72rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--tcr-muted);
	font-weight: 600;
	transition: color 280ms cubic-bezier(.22,.61,.36,1);
}
.tcr-block-partner-tile:hover {
	background: var(--tcr-primary-50);
}
.tcr-block-partner-tile:hover .tcr-partner-tile-logo {
	filter: grayscale(0);
	opacity: 1;
	transform: scale(1.04);
}
.tcr-block-partner-tile:hover .tcr-partner-tile-name {
	color: var(--tcr-primary);
}
.tcr-block-partner-tile.tcr-partner-tile-placeholder {
	background: repeating-linear-gradient(45deg, #FFFFFF, #FFFFFF 6px, var(--tcr-primary-50) 6px, var(--tcr-primary-50) 12px);
}
.tcr-block-partner-tile .tcr-partner-tile-cta {
	color: var(--tcr-primary);
	font-weight: 600;
	font-size: .8rem;
	letter-spacing: .04em;
	text-align: center;
	max-width: 14ch;
}

/* =========================================================
   tcr/page-hero
   ========================================================= */
.tcr-block-page-hero {
	min-height: clamp(280px, 38vh, 420px);
	padding: clamp(5rem, 10vw, 7rem) 0 clamp(2rem, 4vw, 3rem);
	display: flex;
	align-items: flex-end;
	position: relative;
	overflow: hidden;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	margin-block-start: 0 !important;
	background:
		radial-gradient(800px 400px at 80% 0%, rgba(46,98,214,.12), transparent 60%),
		linear-gradient(180deg, var(--tcr-primary-50) 0%, #FFFFFF 100%);
}
/* Full-bleed: left:50%!important aus main.css mit höherer Spezifizität korrigieren.
   Gilt für alle tcr-fullbleed Elemente in main/entry-content (page-hero, archive-hero, etc.) */
main.wp-block-group > .tcr-fullbleed,
.entry-content > .tcr-fullbleed,
.wp-block-post-content > .tcr-fullbleed {
	position: relative !important;
	width: 100vw !important;
	max-width: 100vw !important;
	left: 0 !important;
	right: 0 !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
}
/* alignfull Blöcke im post-content (z.B. cream-BG Sektionen in Seemann-Cup, Tennisschule):
   --wp--style--root--padding-left ist nicht gesetzt, deshalb bricht WP's eigener
   .has-global-padding > .alignfull Mechanismus nicht aus. Wir helfen nach. */
.entry-content > .alignfull,
.wp-block-post-content > .alignfull {
	width: 100vw !important;
	max-width: 100vw !important;
	left: 0 !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
}
.tcr-block-page-hero.tcr-page-hero-image {
	min-height: clamp(380px, 52vh, 560px);
	background: var(--tcr-primary-dark);
}
/* Hero ohne Featured Image: kompakter, solider Hintergrund */
.tcr-block-page-hero.tcr-page-hero-solid {
	min-height: 0 !important;
	padding: clamp(3rem, 6vw, 4.5rem) 0 clamp(1.5rem, 3vw, 2rem) !important;
	background:
		radial-gradient(800px 400px at 80% 0%, rgba(46,98,214,.10), transparent 60%),
		linear-gradient(180deg, var(--tcr-primary-50, #EFF3FC) 0%, #FFFFFF 100%) !important;
}
.tcr-block-page-hero .tcr-page-hero-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center 50%;
	background-repeat: no-repeat;
	z-index: 1;
	transform: scale(1.02);
	filter: saturate(1.05) contrast(1.02);
	animation: tcrHeroZoom 24s cubic-bezier(.22,.61,.36,1) infinite alternate;
}
.tcr-block-page-hero .tcr-page-hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	/* Deutlicherer Gradient: oben leicht, unten kräftig für weissen Text */
	background:
		linear-gradient(180deg,
			rgba(6,33,79,.08) 0%,
			rgba(6,33,79,.35) 50%,
			rgba(6,33,79,.75) 100%);
	pointer-events: none;
}
.tcr-block-page-hero .tcr-page-hero-inner {
	position: relative;
	z-index: 3;
	max-width: 1240px;
	width: 100%;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}
.tcr-block-page-hero .tcr-page-hero-eyebrow {
	color: var(--tcr-primary);
	font-size: .74rem;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	margin: 0;
}
.tcr-block-page-hero .tcr-page-hero-eyebrow::before {
	content: "";
	width: 28px;
	height: 1px;
	background: currentColor;
}
.tcr-block-page-hero .tcr-page-hero-eyebrow-light {
	color: rgba(255,255,255,.85);
}
.tcr-block-page-hero .tcr-page-hero-title {
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.03em;
	color: #1F2433;
	margin: 0.75rem 0 0;
}
.tcr-block-page-hero .tcr-page-hero-title.has-light-color {
	color: #fff;
	text-shadow: 0 2px 16px rgba(6,33,79,.45);
}
.tcr-block-page-hero .tcr-page-hero-eyebrow-light {
	color: rgba(255,255,255,.9);
	text-shadow: 0 1px 8px rgba(6,33,79,.4);
}

/* =========================================================
   TCR Split-Hero
   ========================================================= */
.tcr-block-split-hero { display: block; }
.tcr-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: min(60vh, 520px);
}
@media (max-width: 900px) {
	.tcr-split {
		grid-template-columns: 1fr;
		min-height: unset;
	}
	.tcr-split .tcr-split-image {
		min-height: 300px;
		order: -1;
	}
	.tcr-split.is-reversed .tcr-split-image { order: -1; }
}
.tcr-split-image {
	background-size: cover;
	background-position: center;
	min-height: min(60vh, 520px);
}
.tcr-split.is-reversed .tcr-split-image { order: 1; }
.tcr-split-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(2.5rem, 5vw, 4rem) clamp(2rem, 5vw, 4rem);
	background: #fff;
}
.tcr-split-title {
	font-family: 'DM Sans', sans-serif;
	font-size: clamp(2.25rem, 4.5vw, 3.5rem);
	font-weight: 700;
	line-height: 1.1;
	color: #1F2433;
	margin: 0.5rem 0 1.25rem;
	letter-spacing: -0.025em;
}
.tcr-split-body {
	color: #5B6475;
	font-size: 1.05rem;
	line-height: 1.65;
	margin: 0 0 0.85rem;
}
.tcr-split-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-top: 0.75rem;
}
.tcr-btn {
	display: inline-flex;
	align-items: center;
	padding: 0.85rem 1.6rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	transition: opacity .15s;
}
.tcr-btn:hover { opacity: .85; }
.tcr-btn.is-primary { background: #12224A; color: #fff; }
.tcr-btn.is-outline { border: 2px solid #12224A; color: #12224A; }

/* =========================================================
   TCR Pricing Grid
   ========================================================= */
.tcr-pricing {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 1.25rem;
	margin-top: 1.5rem;
}
.tcr-price-card {
	border: 1px solid #E6E8EF;
	border-radius: 1rem;
	padding: 1.5rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	background: #fff;
}
.tcr-price-card.is-featured {
	background: linear-gradient(135deg, #0E3A8A 0%, #12224A 100%);
	color: #fff;
	border-color: transparent;
}
.tcr-price-tier {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--tcr-primary);
	background: rgba(46,98,214,.08);
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	display: inline-block;
	width: fit-content;
}
.tcr-price-card.is-featured .tcr-price-tier {
	background: rgba(255,255,255,.15);
	color: #fff;
}
.tcr-price-card h3 {
	font-size: 1rem;
	font-weight: 700;
	margin: 0.4rem 0 0;
}
.tcr-price-amount {
	font-size: 2.2rem;
	font-weight: 800;
	line-height: 1;
	margin: 0.5rem 0;
}
.tcr-price-amount sup {
	font-size: 0.85rem;
	font-weight: 600;
	vertical-align: super;
	margin-right: 2px;
}
.tcr-price-amount small {
	font-size: 0.85rem;
	font-weight: 400;
}
.tcr-price-features {
	list-style: none;
	padding: 0;
	margin: 0.5rem 0 0;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.tcr-price-features li {
	font-size: 0.875rem;
	padding-left: 1.1rem;
	position: relative;
}
.tcr-price-features li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--tcr-primary);
	font-size: 0.75rem;
}
.tcr-price-card.is-featured .tcr-price-features li::before { color: rgba(255,255,255,.7); }

/* =========================================================
   TCR Team Stats
   (main.css setzt blauen BG + grid — wir überschreiben mit
   hellem Flex-Layout für den neuen Block)
   ========================================================= */
.tcr-block-team-stats .tcr-teams-stats {
	display: flex !important;
	grid-template-columns: unset !important;
	gap: 2.5rem;
	flex-wrap: wrap;
	margin: 1.5rem 0;
	background: transparent !important;
	color: inherit !important;
}
.tcr-block-team-stats .tcr-teams-stat {
	display: flex;
	flex-direction: column;
	padding: 0 !important;
	border-right: none !important;
	text-align: left !important;
}
.tcr-block-team-stats .tcr-teams-stat-num {
	font-size: 2.8rem;
	font-weight: 800;
	line-height: 1;
	color: var(--tcr-primary, #2E62D6);
	letter-spacing: -0.03em;
}
.tcr-block-team-stats .tcr-teams-stat-label {
	font-size: 0.875rem;
	color: #5B6475;
	margin-top: 0.25rem;
	font-weight: 500;
	opacity: 1 !important;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

/* =========================================================
   TCR Teams Grid
   ========================================================= */
.tcr-teams-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.25rem;
	margin-top: 1.5rem;
}
.tcr-team-ic {
	border: 1px solid #E6E8EF;
	border-radius: 1rem;
	overflow: hidden;
	background: #fff;
}
.tcr-team-ic-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	padding: 1.25rem 1.25rem 0.75rem;
	gap: 1rem;
	background: linear-gradient(135deg, #eef2fa 0%, #f7f9fd 100%);
	border-bottom: 1px solid #dde4f0;
}
.tcr-team-ic-category {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: #2E62D6;
	margin: 0 0 0.25rem;
}
.tcr-team-ic-name {
	font-size: 1rem;
	font-weight: 700;
	margin: 0;
	color: #1F2433 !important;
}
.tcr-team-ic-league {
	font-size: 0.72rem;
	font-weight: 800;
	background: #2E62D6;
	color: #fff;
	padding: 0.3rem 0.65rem;
	border-radius: 0.4rem;
	white-space: nowrap;
	flex-shrink: 0;
	letter-spacing: .04em;
	box-shadow: 0 1px 4px rgba(46,98,214,.35);
}
.tcr-team-ic-body { padding: 0.75rem 1.25rem 1.25rem; }
.tcr-team-ic-meta {
	list-style: none;
	padding: 0;
	margin: 0 0 0.75rem;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}
.tcr-team-ic-meta li { display: flex; gap: 0.5rem; font-size: 0.875rem; }
.tcr-team-ic-key { color: #7a86a0; min-width: 68px; flex-shrink: 0; font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; font-size: 0.68rem; }
.tcr-team-ic-val { color: #1F2433; font-weight: 500; }
.tcr-team-ic-captain {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px solid #E6E8EF;
}
.tcr-team-ic-captain-avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: linear-gradient(135deg, #1a3a6e 0%, #2E62D6 100%);
	color: #fff;
	font-size: 0.72rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	letter-spacing: .04em;
	box-shadow: 0 2px 8px rgba(46,98,214,.3);
}
.tcr-team-ic-captain-info { display: flex; flex-direction: column; }
.tcr-team-ic-captain-label { font-size: 0.7rem; color: #5B6475; text-transform: uppercase; letter-spacing: .1em; }
.tcr-team-ic-captain-name { font-size: 0.875rem; font-weight: 600; color: #1F2433; }

/* =========================================================
   TCR Photo Mosaic
   ========================================================= */
.tcr-photo-mosaic {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	grid-auto-rows: 180px;
	gap: 0.75rem;
	margin-top: 1.5rem;
}
.tcr-photo-frame {
	border-radius: 0.5rem;
	overflow: hidden;
	position: relative;
	margin: 0;
}
.tcr-photo-frame img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.tcr-photo-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.5rem 0.75rem;
	background: linear-gradient(transparent, rgba(6,33,79,.75));
	color: #fff;
	font-size: 0.8rem;
}
.tcr-placeholder {
	background: #E6E8EF;
	display: flex;
	align-items: center;
	justify-content: center;
}
.tcr-placeholder span {
	color: #8A95A8;
	font-size: 0.8rem;
	font-weight: 500;
	text-align: center;
	padding: 0.5rem;
}
@media (max-width: 600px) {
	.tcr-photo-mosaic {
		grid-template-columns: repeat(2, 1fr);
		grid-auto-rows: 140px;
	}
	.tcr-photo-frame[style*="span 7"],
	.tcr-photo-frame[style*="span 5"] { grid-column: span 2; }
}

/* =========================================================
   TCR Coaches Grid
   ========================================================= */
.tcr-coaches {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 520px), 1fr));
	gap: 1.5rem;
	margin-top: 1.5rem;
}
.tcr-coach {
	display: flex;
	gap: 1.25rem;
	background: #fff;
	border: 1px solid #E6E8EF;
	border-radius: 1rem;
	padding: 1.5rem;
	align-items: flex-start;
}
.tcr-block-coaches-grid .tcr-coach-avatar {
	width: 56px !important;
	height: 56px !important;
	min-width: 56px !important;
	max-width: 56px !important;
	flex: 0 0 56px !important;
	border-radius: 50% !important;
	background: linear-gradient(135deg, #2E62D6 0%, #0E3A8A 100%) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-shrink: 0 !important;
	overflow: hidden !important;
}
.tcr-block-coaches-grid .tcr-coach-avatar::after { display: none !important; }
.tcr-block-coaches-grid .tcr-coach-avatar-initials { color: #fff; font-size: 1rem; font-weight: 700; z-index: 1; }
.tcr-coach-body { flex: 1; }
.tcr-coach-role { font-size: 0.75rem; color: #5B6475; text-transform: uppercase; letter-spacing: .1em; margin: 0 0 0.25rem; }
.tcr-coach h3 { font-size: 1.1rem; font-weight: 700; margin: 0 0 0.5rem; color: #1F2433; }
.tcr-coach-specialties { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-bottom: 0.75rem; }
.tcr-coach-specialties span {
	font-size: 0.72rem;
	background: rgba(46,98,214,.08);
	color: var(--tcr-primary, #2E62D6);
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	font-weight: 600;
}
.tcr-coach-contact a { font-size: 0.9rem; font-weight: 600; color: var(--tcr-primary, #2E62D6); text-decoration: none; }

/* =========================================================
   TCR Camps Grid
   ========================================================= */
.tcr-camps {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.25rem;
	margin-top: 1.5rem;
}
.tcr-camp {
	border: 1px solid #E6E8EF;
	border-radius: 1rem;
	padding: 1.5rem;
	background: #fff;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.tcr-camp-season {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--tcr-primary, #2E62D6);
	background: rgba(46,98,214,.08);
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	display: inline-block;
	width: fit-content;
}
.tcr-camp-date { font-size: 0.8rem; color: #5B6475; margin: 0.25rem 0 0; }
.tcr-camp h3 { font-size: 1rem; font-weight: 700; margin: 0.35rem 0 0; color: #1F2433; }
.tcr-camp p { font-size: 0.875rem; color: #5B6475; margin: 0.25rem 0 0; line-height: 1.55; }
.tcr-camp-details {
	margin-top: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px solid #E6E8EF;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}
.tcr-camp-details div { display: flex; gap: 0.5rem; font-size: 0.85rem; }
.tcr-camp-details strong { color: #5B6475; min-width: 45px; flex-shrink: 0; }
.tcr-camp-details span { color: #1F2433; font-weight: 500; }

/* =========================================================
   TCR Offers Grid
   ========================================================= */
.tcr-offers {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.25rem;
	margin-top: 1.5rem;
}
.tcr-offer {
	border: 1px solid #E6E8EF;
	border-radius: 1rem;
	padding: 1.5rem;
	background: #fff;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.tcr-offer-icon {
	width: 48px;
	height: 48px;
	background: linear-gradient(135deg, #2E62D6 0%, #0E3A8A 100%);
	color: #fff;
	border-radius: 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	font-weight: 700;
	flex-shrink: 0;
	margin-bottom: 0.25rem;
}
.tcr-offer-category { font-size: 0.72rem; font-weight: 600; color: #5B6475; text-transform: uppercase; letter-spacing: .1em; margin: 0; }
.tcr-offer h3 { font-size: 1rem; font-weight: 700; margin: 0.25rem 0 0; color: #1F2433; }
.tcr-offer > p { font-size: 0.875rem; color: #5B6475; line-height: 1.55; margin: 0.25rem 0 0; }
.tcr-offer-meta { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.5rem; }
.tcr-offer-tag {
	font-size: 0.72rem;
	background: rgba(46,98,214,.08);
	color: var(--tcr-primary, #2E62D6);
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	font-weight: 600;
}

/* =========================================================
   TCR Map Section
   ========================================================= */
.tcr-map {
	position: relative;
	border-radius: 1rem;
	overflow: hidden;
	height: 420px;
	margin-top: 1.5rem;
}
.tcr-map-frame {
	width: 100%;
	height: 100%;
	border: none;
	display: block;
	filter: grayscale(.15);
}
.tcr-map-overlay {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	background: #fff;
	border-radius: 0.875rem;
	padding: 1.25rem 1.5rem;
	box-shadow: 0 8px 40px rgba(6,33,79,.18);
	min-width: 220px;
	max-width: 280px;
}
.tcr-map-overlay-eyebrow {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--tcr-primary, #2E62D6);
	display: block;
	margin-bottom: 0.35rem;
}
.tcr-map-overlay h3 { font-size: 1rem; font-weight: 700; margin: 0 0 0.35rem; color: #1F2433; }
.tcr-map-overlay p { font-size: 0.875rem; color: #5B6475; margin: 0 0 1rem; line-height: 1.5; }
.tcr-map-actions { display: flex; flex-direction: column; gap: 0.4rem; }
.tcr-map-actions a {
	font-size: 0.8rem;
	font-weight: 600;
	padding: 0.45rem 0.85rem;
	border-radius: 999px;
	text-align: center;
	text-decoration: none;
	border: 1px solid #E6E8EF;
	color: #1F2433;
	transition: background .15s;
}
.tcr-map-actions a.is-primary {
	background: var(--tcr-primary, #2E62D6);
	color: #fff;
	border-color: transparent;
}
.tcr-map-actions a:hover { opacity: .85; }
@media (max-width: 600px) {
	.tcr-map { height: 360px; }
	.tcr-map-overlay { right: 0.75rem; top: auto; bottom: 0.75rem; max-width: calc(100% - 1.5rem); }
}

/* =========================================================
   TCR Booking Form
   ========================================================= */
.tcr-booking {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: 3rem;
	align-items: stretch;
	margin-top: 1.5rem;
}
@media (max-width: 860px) { .tcr-booking { grid-template-columns: 1fr; } }
.tcr-booking-info-eyebrow { font-size: 0.72rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--tcr-primary, #2E62D6); margin: 0 0 0.5rem; }
.tcr-booking-info h3 { font-size: 1.4rem; font-weight: 700; margin: 0 0 0.75rem; color: #1F2433; }
.tcr-booking-info p { font-size: 0.95rem; color: #5B6475; margin: 0 0 1rem; line-height: 1.65; }
.tcr-booking-features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.tcr-booking-features li { font-size: 0.9rem; color: #1F2433; padding-left: 1.25rem; position: relative; }
.tcr-booking-features li::before { content: '✓'; position: absolute; left: 0; color: var(--tcr-primary, #2E62D6); font-size: 0.8rem; }
.tcr-booking-form {
	background: #fff;
	border: 1px solid #E6E8EF;
	border-radius: 1.25rem;
	padding: 2rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.tcr-booking-form h4 { font-size: 1.05rem; font-weight: 700; margin: 0 0 0.25rem; color: #1F2433; }
.tcr-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
@media (max-width: 540px) { .tcr-field-row { grid-template-columns: 1fr; } }
.tcr-field { display: flex; flex-direction: column; gap: 0.3rem; }
.tcr-field label { font-size: 0.8rem; font-weight: 600; color: #1F2433; }
.tcr-field input,
.tcr-field select,
.tcr-field textarea {
	padding: 0.65rem 0.9rem;
	border: 1px solid #D1D5E0;
	border-radius: 0.5rem;
	font-size: 0.9rem;
	font-family: inherit;
	color: #1F2433;
	background: #FAFBFF;
	transition: border-color .15s;
}
.tcr-field input:focus,
.tcr-field select:focus,
.tcr-field textarea:focus { border-color: var(--tcr-primary, #2E62D6); outline: none; }
.tcr-booking-submit {
	background: linear-gradient(135deg, #2E62D6 0%, #0E3A8A 100%);
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: 0.9rem 2rem;
	font-size: 0.95rem;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	transition: opacity .15s;
}
.tcr-booking-submit:hover { opacity: .88; }
.tcr-booking-form small { font-size: 0.78rem; color: #8A95A8; line-height: 1.5; }
.tcr-booking-form small a { color: var(--tcr-primary, #2E62D6); }

/* =========================================================
   TCR Slider
   ========================================================= */
.tcr-slider { position: relative; margin-top: 1.5rem; }
.tcr-slider-track {
	display: flex;
	gap: 1rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 0.5rem;
}
.tcr-slider-track::-webkit-scrollbar { display: none; }
.tcr-slide {
	scroll-snap-align: start;
	flex-shrink: 0;
	width: 380px;
	height: 260px;
	border-radius: 0.75rem;
	overflow: hidden;
	position: relative;
	margin: 0;
}
.tcr-slide img { width: 100%; height: 100%; object-fit: cover; }
.tcr-slide-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.75rem 1rem;
	background: linear-gradient(transparent, rgba(6,33,79,.8));
	color: #fff;
	display: flex;
	flex-direction: column;
}
.tcr-slide-caption-eyebrow { font-size: 0.7rem; text-transform: uppercase; letter-spacing: .1em; opacity: .8; }
.tcr-slide-caption-title { font-size: 0.9rem; font-weight: 600; }
.tcr-slide.is-placeholder {
	background: #E6E8EF;
	display: flex;
	align-items: center;
	justify-content: center;
}
.tcr-slide-placeholder-label {
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}
.tcr-slide-placeholder-label span { font-size: 0.72rem; color: #8A95A8; text-transform: uppercase; letter-spacing: .1em; }
.tcr-slide-placeholder-label strong { font-size: 0.875rem; color: #5B6475; }
.tcr-slider-hint { font-size: 0.78rem; color: #8A95A8; margin: 0.5rem 0 0; text-align: right; }

/* =========================================================
   Kontakt: Feature Cards
   ========================================================= */
.tcr-feature-card {
	border: 1px solid #E6E8EF;
	border-radius: 1rem;
	padding: 1.75rem;
	background: #fff;
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.tcr-feature-num {
	font-size: 1.75rem;
	line-height: 1;
	display: block;
	margin-bottom: 0.35rem;
}
.tcr-feature-card h3 { font-size: 1.05rem; font-weight: 700; margin: 0; color: #1F2433; }
.tcr-feature-card p { font-size: 0.9rem; color: #5B6475; margin: 0; line-height: 1.55; }
.tcr-feature-card a { color: var(--tcr-primary, #2E62D6); font-weight: 600; text-decoration: none; }

/* =========================================================
   OVERRIDES — main.css Konflikte korrigieren
   ========================================================= */

/* Photo-Frame: main.css setzt blauen BG als Lade-Skeleton.
   Im Block-Kontext Platzhalter hellgrau zeigen. */
.tcr-block-photo-mosaic .tcr-photo-frame {
	background: #E8ECF2;
}
.tcr-block-photo-mosaic .tcr-photo-frame.tcr-placeholder {
	background: #E8ECF2;
	display: flex;
	align-items: center;
	justify-content: center;
}
.tcr-block-photo-mosaic .tcr-photo-frame.tcr-placeholder span {
	color: #8A95A8;
	font-size: 0.8rem;
	font-weight: 500;
	text-align: center;
	padding: 0.5rem;
}

/* Booking-Form: Grid gleich hoch wie Formular */
.tcr-booking {
	align-items: stretch !important;
}

/* Info-Sektion: dunkelblaues Design, volle Höhe */
.tcr-booking-info {
	background: linear-gradient(160deg, #0e2452 0%, #1a3a6e 100%) !important;
	border-radius: 1rem !important;
	padding: 2rem !important;
	box-sizing: border-box !important;
	display: flex !important;
	flex-direction: column !important;
}
.tcr-booking-info-eyebrow {
	color: rgba(255,255,255,.6) !important;
	font-size: .72rem !important;
	font-weight: 700 !important;
	letter-spacing: .15em !important;
	text-transform: uppercase !important;
}
.tcr-booking-info h3 {
	color: #ffffff !important;
	font-size: 1.5rem !important;
}
.tcr-booking-info p {
	color: rgba(255,255,255,.75) !important;
}
.tcr-booking-features {
	margin-top: auto !important;
}
.tcr-booking-features li {
	color: rgba(255,255,255,.9) !important;
}
.tcr-booking-features li::before {
	color: #60a5fa !important;
}

/* Seemann-Cup + andere Page-Hero Seiten: Titel immer gut lesbar */
.tcr-block-page-hero.tcr-page-hero-image .tcr-page-hero-eyebrow {
	color: rgba(255,255,255,.85) !important;
}
.tcr-block-page-hero.tcr-page-hero-image .tcr-page-hero-title {
	color: #fff !important;
	text-shadow: 0 2px 20px rgba(6,33,79,.5);
}

/* Tennisschule Split-Hero: kein Gap zu Header */
.tcr-block-split-hero {
	margin-block-start: 0 !important;
}

/* Kontakt-Seite: Falls kein Inhalt, wenigstens Mindest-Abstand */
.tcr-block-page-hero + .wp-block-post-content {
	padding-block-start: 0;
}

/* =========================================================
   Single Post: Cover-Hero + Titel-Überlappung
   ========================================================= */
/* Cover ohne Featured Image: anständige Mindesthöhe + Hintergrundfarbe */
.tcr-page-hero.tcr-page-hero-image.wp-block-cover:not([style*="background-image"]) {
	min-height: 28vh !important;
	background: var(--tcr-primary-dark, #06214F) !important;
}
/* Wenn kein Bild: Overlay ausblenden (kein leeres Element) */
.tcr-page-hero.wp-block-cover:not([style*="background-image"]) .wp-block-cover__background {
	opacity: 0.92 !important;
}
/* Post-Titel: negativer Margin nur wenn Cover-Bild vorhanden */
.tcr-post-title {
	padding: 0 1.5rem;
}
/* Post-Content-Bereich: genug Abstand nach oben */
.tcr-page-content {
	padding-top: 3rem !important;
	padding-bottom: 5rem !important;
}
/* Wenn das letzte Block-Element full-bleed ist, kein Abstand unten */
.tcr-page-content:has(.entry-content > .alignfull:last-child),
.tcr-page-content:has(.wp-block-post-content > .alignfull:last-child) {
	padding-bottom: 0 !important;
}
/* Seiten ohne tcr-page-content: Abstand vor Footer */
.page .entry-content.wp-block-post-content {
	padding-bottom: 5rem !important;
}
/* Ausnahme: nur tcr-block-* fullbleed Sections am Ende brauchen keinen Abstand */
.page .entry-content.wp-block-post-content:has(> .alignfull.tcr-fullbleed:last-child) {
	padding-bottom: 0 !important;
}
/* Datum unter Titel */
.tcr-post-date {
	padding: 0 1.5rem;
}

/* =========================================================
   Page-Hero Cover: Full-Bleed auch für wp:cover mit tcr-fullbleed
   (main.css greift nur für .tcr-hero-wrap / spez. BG-Farben)
   ========================================================= */
main.wp-block-group > .wp-block-cover.tcr-fullbleed,
main.wp-block-group > .wp-block-cover.alignfull.tcr-page-hero {
	position: relative !important;
	width: 100vw !important;
	max-width: 100vw !important;
	left: 50% !important;
	right: 50% !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	box-sizing: border-box !important;
}

/* =========================================================
   Nav Scroll — is-scrolled (Sicherheits-Override)
   ========================================================= */
.site-header.is-scrolled {
	background: rgba(255,255,255,.97) !important;
	box-shadow: 0 4px 24px -6px rgba(14,58,138,.16) !important;
	border-bottom-color: rgba(14,58,138,.08) !important;
}

/* =========================================================
   CTA-Banner dunkel: Texte + Buttons weiss
   ========================================================= */
.tcr-cta-dark h1,
.tcr-cta-dark h2,
.tcr-cta-dark h3,
.tcr-cta-dark p,
.tcr-cta-dark li {
	color: #ffffff !important;
}
.tcr-cta-dark .wp-block-button__link {
	background-color: #ffffff !important;
	color: #06214f !important;
	border-color: transparent !important;
}
.tcr-cta-dark .wp-block-button.is-style-outline .wp-block-button__link {
	background-color: transparent !important;
	color: #ffffff !important;
	border: 2px solid rgba(255,255,255,0.55) !important;
}

/* =========================================================
   News-Archiv (/news/) — Grid + Karten-Styling
   ========================================================= */

/* Hero */
.tcr-page-hero.tcr-fullbleed {
	background: radial-gradient(900px 400px at 80% 0%, rgba(46,98,214,.08), transparent 60%),
		linear-gradient(180deg, var(--tcr-primary-50, #EFF3FC) 0%, #FFFFFF 100%);
	padding-top: clamp(4rem, 8vw, 6rem) !important;
	padding-bottom: clamp(1.5rem, 3vw, 2.5rem) !important;
}

/* News-Archiv Hero: Bild mit Overlay */
.tcr-archive-hero {
	background:
		linear-gradient(160deg, rgba(6,33,79,.72) 0%, rgba(14,58,138,.55) 100%),
		url('https://tcreichenstein.ddev.site/wp-content/uploads/2026/04/hero-2-1.jpg') center/cover no-repeat !important;
	padding-top: clamp(5rem, 10vw, 8rem) !important;
	padding-bottom: clamp(2rem, 4vw, 3rem) !important;
}
.tcr-archive-hero .tcr-page-hero-inner .tcr-page-hero-eyebrow,
.tcr-archive-hero .tcr-page-hero-eyebrow {
	color: rgba(255,255,255,.85) !important;
}
.tcr-archive-hero .tcr-page-hero-inner .tcr-page-hero-eyebrow::before,
.tcr-archive-hero .tcr-page-hero-eyebrow::before {
	background: rgba(255,255,255,.55) !important;
}
.tcr-page-hero .tcr-page-hero-inner {
	padding-left: clamp(1.25rem, 4vw, 2.5rem) !important;
	padding-right: clamp(1.25rem, 4vw, 2.5rem) !important;
}
.tcr-page-hero .tcr-page-hero-eyebrow {
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--tcr-primary) !important;
	margin: 0;
	display: flex;
	align-items: center;
	gap: .5rem;
}
.tcr-page-hero .tcr-page-hero-eyebrow::before {
	content: '';
	display: inline-block;
	width: 1.75rem;
	height: 2px;
	background: var(--tcr-primary);
	flex-shrink: 0;
}

/* Archive-Head: Titel direkt unter Hero */
.tcr-archive-head {
	padding-top: 1.5rem !important;
	padding-bottom: 0 !important;
	padding-left: clamp(1.25rem, 4vw, 2.5rem) !important;
	padding-right: clamp(1.25rem, 4vw, 2.5rem) !important;
	margin-top: 0 !important;
}
.tcr-archive-head .wp-block-query-title,
.tcr-archive-head h1,
.tcr-archive-head .wp-block-heading {
	font-size: clamp(2.2rem, 4.5vw, 3.6rem) !important;
	font-weight: 700 !important;
	letter-spacing: -.025em !important;
	color: var(--tcr-ink) !important;
	margin: 0 0 .4rem !important;
	line-height: 1.05 !important;
}
.tcr-archive-head p {
	font-size: 1.05rem !important;
	color: var(--tcr-muted, #64748b) !important;
	margin: 0 !important;
	line-height: 1.6 !important;
}

/* Archive-Grid: 3-spaltiges Karten-Grid */
.tcr-archive-grid {
	padding: 0 clamp(1.25rem, 4vw, 2.5rem) 4rem !important;
}
.tcr-archive-grid .wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 1.75rem !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}
@media (max-width: 900px) {
	.tcr-archive-grid .wp-block-post-template {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}
@media (max-width: 560px) {
	.tcr-archive-grid .wp-block-post-template {
		grid-template-columns: 1fr !important;
	}
}

/* Grid: alle Zeilen gleich hoch */
.tcr-archive-grid .wp-block-post-template {
	align-items: stretch !important;
}

/* Einzelne Karte — volle Höhe der Grid-Row */
.tcr-archive-grid .wp-block-post {
	background: #fff;
	border: 1px solid var(--tcr-line, #e2e8f0);
	border-radius: 12px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
	transition: transform 300ms cubic-bezier(.22,.61,.36,1),
		box-shadow 300ms cubic-bezier(.22,.61,.36,1);
}
.tcr-archive-grid .wp-block-post:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px -8px rgba(14,58,138,.15);
}

/* Featured Image */
.tcr-archive-grid .wp-block-post-featured-image {
	display: block;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--tcr-primary-50, #EFF3FC);
	margin: 0;
}
.tcr-archive-grid .wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(.22,.61,.36,1);
	display: block;
}
.tcr-archive-grid .wp-block-post:hover .wp-block-post-featured-image img {
	transform: scale(1.05);
}
/* Kein Bild: Platzhalter */
.tcr-archive-grid .wp-block-post-featured-image:empty,
.tcr-archive-grid .wp-block-post-featured-image a:only-child:not(:has(img)) {
	min-height: 160px;
	background: linear-gradient(135deg, var(--tcr-primary-50, #EFF3FC) 0%, #dce8ff 100%);
}

/* Datum */
.tcr-archive-grid .wp-block-post-date {
	padding: 1.1rem 1.3rem .2rem;
	font-size: .75rem !important;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--tcr-primary) !important;
	margin: 0;
}
.tcr-archive-grid .wp-block-post-date time { color: inherit; }

/* Titel */
.tcr-archive-grid .wp-block-post-title {
	padding: .3rem 1.3rem .5rem;
	font-size: 1.15rem !important;
	font-weight: 700 !important;
	letter-spacing: -.015em;
	line-height: 1.3;
	margin: 0;
	color: var(--tcr-ink) !important;
}
.tcr-archive-grid .wp-block-post-title a {
	color: inherit !important;
	text-decoration: none;
	transition: color 180ms ease;
}
.tcr-archive-grid .wp-block-post-title a:hover { color: var(--tcr-primary) !important; }

/* Excerpt — wächst, um restlichen Platz zu füllen */
.tcr-archive-grid .wp-block-post-excerpt {
	padding: 0 1.3rem 1.3rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.tcr-archive-grid .wp-block-post-excerpt__excerpt {
	font-size: .93rem;
	color: var(--tcr-muted, #64748b);
	line-height: 1.55;
	margin: 0 0 .75rem;
	flex: 1;
}
.tcr-archive-grid .wp-block-post-excerpt__more-link {
	font-size: .85rem;
	font-weight: 600;
	color: var(--tcr-primary) !important;
	text-decoration: none;
	transition: color 180ms ease;
}
.tcr-archive-grid .wp-block-post-excerpt__more-link:hover {
	color: var(--tcr-primary-dark, #1a3a6e) !important;
}

/* Pagination */
.tcr-archive-grid .wp-block-query-pagination {
	display: flex;
	justify-content: center;
	gap: .5rem;
	margin-top: 3rem;
}
.tcr-archive-grid .wp-block-query-pagination a,
.tcr-archive-grid .wp-block-query-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 .75rem;
	border-radius: 8px;
	border: 1px solid var(--tcr-line, #e2e8f0);
	font-size: .9rem;
	font-weight: 600;
	color: var(--tcr-ink);
	text-decoration: none;
	transition: background 180ms ease, border-color 180ms ease, color 180ms ease;
}
.tcr-archive-grid .wp-block-query-pagination a:hover {
	background: var(--tcr-primary-50, #EFF3FC);
	border-color: var(--tcr-primary);
	color: var(--tcr-primary);
}
.tcr-archive-grid .wp-block-query-pagination .current {
	background: var(--tcr-primary);
	border-color: var(--tcr-primary);
	color: #fff;
}

/* =========================================================
   Per-Seite Focal-Points für Hero-Hintergrundbilder
   Gilt für: .tcr-page-hero-bg (page-hero) + .tcr-split-image (split-hero)
   ========================================================= */

/* tennisschule (ID:8) — Aufschlag-Aktion, Kopf oben */
.page-id-8 .tcr-page-hero-bg,
.page-id-8 .tcr-split-image { background-position: center 30% !important; }

/* mitglied-werden (ID:7) — Spielplatz, Kirschbaum */
.page-id-7 .tcr-page-hero-bg,
.page-id-7 .tcr-split-image { background-position: center 55% !important; }

/* seemann-cup (ID:9) — Abendstimmung breite Platzszene */
.page-id-9 .tcr-page-hero-bg,
.page-id-9 .tcr-split-image { background-position: center 50% !important; }

/* adresse (ID:10) — Baum/Spielplatz/Chalet, Hauptmotiv unten-mitte */
.page-id-10 .tcr-page-hero-bg,
.page-id-10 .tcr-split-image { background-position: center 60% !important; }

/* kontakt (ID:11) — gelbe Blumen vorne, Platz dahinter */
.page-id-11 .tcr-page-hero-bg,
.page-id-11 .tcr-split-image { background-position: center 55% !important; }

/* vorstand (ID:12) — Clubhaus-Schild, oben-mitte */
.page-id-12 .tcr-page-hero-bg,
.page-id-12 .tcr-split-image { background-position: center 45% !important; }

/* clubhaus (ID:13) — Clubhaus-Aussenansicht, zentriert */
.page-id-13 .tcr-page-hero-bg,
.page-id-13 .tcr-split-image { background-position: center 50% !important; }

/* interclub-teams (ID:14) — Doppel durch Schläger, mitte */
.page-id-14 .tcr-page-hero-bg,
.page-id-14 .tcr-split-image { background-position: center 55% !important; }

/* was-laeuft (ID:15) — Spielerin Netz Flutlicht, unten */
.page-id-15 .tcr-page-hero-bg,
.page-id-15 .tcr-split-image { background-position: center 65% !important; }

/* fotogalerie (ID:16) — Tennisball auf Sand, unten */
.page-id-16 .tcr-page-hero-bg,
.page-id-16 .tcr-split-image { background-position: center 65% !important; }

/* dokumente (ID:17) — Schild close-up, oben */
.page-id-17 .tcr-page-hero-bg,
.page-id-17 .tcr-split-image { background-position: center 40% !important; }

/* impressum (ID:18) — Spielplatz/Chalet */
.page-id-18 .tcr-page-hero-bg,
.page-id-18 .tcr-split-image { background-position: center 55% !important; }

/* datenschutz (ID:19) — Besen auf Court, B&W */
.page-id-19 .tcr-page-hero-bg,
.page-id-19 .tcr-split-image { background-position: center 55% !important; }

/* platzreservierung (ID:129) — Spielerin Netz Flutlicht */
.page-id-129 .tcr-page-hero-bg,
.page-id-129 .tcr-split-image { background-position: center 65% !important; }

/* news (ID:6) — breite Platzszene Abend */
.page-id-6 .tcr-page-hero-bg,
.page-id-6 .tcr-split-image { background-position: center 45% !important; }

/* =========================================================
   MOBILE OPTIMIERUNGEN — Global
   ========================================================= */

/* ── Mobile Nav Overlay ── */
.wp-block-navigation__responsive-container.is-menu-open {
	background: linear-gradient(160deg, #06214f 0%, #0e3a8a 100%) !important;
	padding: 1.5rem 1.75rem 2.5rem !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	/* Vollbild-Overlay */
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	width: 100% !important;
	height: 100dvh !important;
	min-height: 100vh !important;
	z-index: 100001 !important;
	overflow-y: auto !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: stretch !important;
	flex: 1 !important;
	gap: 0.25rem !important;
	margin-top: 2rem !important;
	width: 100% !important;
	max-width: 100% !important;
}
/* UL Container im Overlay → volle Breite, links ausgerichtet */
.wp-block-navigation__responsive-container.is-menu-open ul.wp-block-navigation__container {
	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	justify-content: flex-start !important;
	width: 100% !important;
	max-width: 100% !important;
	gap: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}
/* Einzelne Nav-Items volle Breite */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	width: 100% !important;
	align-items: stretch !important;
	justify-content: flex-start !important;
}
/* CTA "Mitglied werden" im Overlay — Creme als Akzent */
.wp-block-navigation__responsive-container.is-menu-open .tcr-nav-cta {
	margin-top: 1.5rem !important;
}
.wp-block-navigation__responsive-container.is-menu-open .tcr-nav-cta > a.wp-block-navigation-item__content {
	background: #F7F3EA !important;
	color: #06214f !important;
	padding: 0.9rem 1.5rem !important;
	border-radius: 999px !important;
	font-weight: 700 !important;
	display: inline-block !important;
	width: auto !important;
	text-align: center !important;
}
.wp-block-navigation__responsive-container.is-menu-open .tcr-nav-cta > a.wp-block-navigation-item__content:hover {
	background: #ffffff !important;
	color: #06214f !important;
}
/* Nav links im Overlay */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
	font-size: 1.4rem !important;
	font-weight: 700 !important;
	color: #ffffff !important;
	padding: 0.65rem 0 !important;
	border-bottom: none !important;
	display: block !important;
	letter-spacing: -.01em !important;
	text-decoration: none !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover {
	color: rgba(255,255,255,.7) !important;
}
/* Submenu links kleiner */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	font-size: 1rem !important;
	font-weight: 500 !important;
	padding: 0.4rem 0 !important;
	border-bottom: none !important;
	color: rgba(255,255,255,.85) !important;
}
/* Close-Button — nur im offenen Overlay sichtbar */
.wp-block-navigation__responsive-container-close {
	display: none !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
	color: #ffffff !important;
	background: rgba(255,255,255,.15) !important;
	border-radius: 50% !important;
	width: 42px !important;
	height: 42px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	align-self: flex-end !important;
	flex-shrink: 0 !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
	color: #fff !important;
	fill: #fff !important;
}
/* Hamburger-Button */
.wp-block-navigation__responsive-container-open {
	color: var(--tcr-primary, #2E62D6) !important;
	padding: 0.35rem !important;
}
.wp-block-navigation__responsive-container-open svg {
	width: 28px !important;
	height: 28px !important;
}
/* Body scroll-lock wenn Menü offen */
body:has(.wp-block-navigation__responsive-container.is-menu-open) {
	overflow: hidden !important;
}

/* ── Tablet (max 900px) ── */
@media (max-width: 900px) {
	/* Interclub Teams Grid → 2 Spalten */
	.tcr-teams-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
	/* Spinning badge verstecken */
	.tcr-split-badge {
		display: none !important;
	}
	/* Section-inner padding reduzieren */
	.tcr-section-inner {
		padding-left: 1.25rem !important;
		padding-right: 1.25rem !important;
	}
	/* Header padding anpassen */
	.tcr-block-header {
		padding: 0.85rem 1.25rem !important;
	}
	/* Page-hero Padding */
	.tcr-page-hero-inner {
		padding: 0 1.25rem !important;
	}
}

/* ── Mobil (max 640px) ── */
@media (max-width: 640px) {
	/* Interclub Teams → 1 Spalte */
	.tcr-teams-grid {
		grid-template-columns: 1fr !important;
	}
	/* Vorstand/Team-Grid → 1 Spalte */
	.tcr-team-grid {
		grid-template-columns: 1fr !important;
	}
	/* News-Grid → 1 Spalte */
	.tcr-news-grid,
	.tcr-archive-grid {
		grid-template-columns: 1fr !important;
	}
	/* Preis-Cards → 1 Spalte */
	.tcr-price-grid,
	.tcr-pricing,
	.tcr-cards {
		grid-template-columns: 1fr !important;
	}
	/* Preis-Card featured oben ohne Radius-Clip */
	.tcr-price-card {
		border-radius: 0.75rem !important;
	}
	/* Angebote-Cards → 1 Spalte */
	.tcr-block-section-angebote .tcr-cards {
		grid-template-columns: 1fr !important;
	}
	/* Coach-Grid → 1 Spalte */
	.tcr-coaches-grid {
		grid-template-columns: 1fr !important;
	}
	/* CTA-Buttons stacken */
	.tcr-hero-actions,
	.tcr-cta-actions {
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 0.75rem !important;
	}
	.tcr-hero-actions .wp-block-button,
	.tcr-cta-actions .wp-block-button {
		width: 100% !important;
	}
	.tcr-hero-actions .wp-block-button__link,
	.tcr-cta-actions .wp-block-button__link {
		width: 100% !important;
		text-align: center !important;
		justify-content: center !important;
	}
	/* Page Hero Schrift verkleinern */
	.tcr-page-hero-title {
		font-size: clamp(1.6rem, 7vw, 2.2rem) !important;
	}
	.tcr-page-hero-eyebrow {
		font-size: 0.7rem !important;
	}
	/* Section-Padding reduzieren */
	.tcr-block-section-anlage,
	.tcr-block-section-angebote,
	.tcr-block-section-tradition,
	.tcr-block-section-news,
	.tcr-block-section-termine {
		padding: clamp(2.5rem, 8vw, 4rem) 0 !important;
	}
	/* Section-inner padding — Mobile: 20px für gleichmässigen Seitenabstand */
	.tcr-section-inner {
		padding-left: 1.25rem !important;
		padding-right: 1.25rem !important;
	}
	/* Section-Titel verkleinern */
	.tcr-section-head h2,
	.tcr-section-head-split h2 {
		font-size: clamp(1.5rem, 6vw, 2rem) !important;
	}
	/* Stats-Grid → 2 Spalten */
	.tcr-stats {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 1rem !important;
	}
	/* Booking Form → 1 Spalte */
	.tcr-booking {
		grid-template-columns: 1fr !important;
	}
	.tcr-booking-info {
		padding: 1.5rem !important;
	}
	/* Formular-Felder stacken */
	.tcr-field-row {
		grid-template-columns: 1fr !important;
	}
	/* Partners Logos → 2 Spalten */
	.tcr-partners-logos {
		grid-template-columns: repeat(2, 1fr) !important;
	}
	/* Footer-Nav stacken */
	.tcr-footer-nav {
		grid-template-columns: 1fr !important;
		gap: 1.5rem !important;
	}
	/* Footer-Top stacken */
	.tcr-footer-top {
		flex-direction: column !important;
		gap: 1.5rem !important;
	}
	/* Page-content Padding */
	.page .entry-content.wp-block-post-content {
		padding-bottom: 3rem !important;
	}
	/* Breite Elemente nicht overflow */
	.tcr-map-wrap,
	.tcr-booking-map {
		height: 240px !important;
	}
	/* Touch-targets: min 44px */
	.wp-block-button__link,
	.tcr-card-link,
	.tcr-nav-link {
		min-height: 44px !important;
	}
}

/* ── Klein-Mobil (max 400px) ── */
@media (max-width: 400px) {
	.tcr-page-hero-title {
		font-size: clamp(1.4rem, 8vw, 1.8rem) !important;
	}
	.tcr-team-ic-league {
		font-size: 0.65rem !important;
		padding: 0.2rem 0.45rem !important;
	}
	.tcr-stats {
		grid-template-columns: 1fr !important;
	}
	.tcr-block-header {
		padding: 0.75rem 1rem !important;
	}
}

/* ── Overflow-Schutz global ── */
html, body {
	max-width: 100% !important;
	overflow-x: hidden !important;
}
/* Ausnahme: Header und Nav dürfen Overlay zeigen */
.tcr-fullbleed:not(.tcr-block-header),
.alignfull:not(.tcr-block-header):not(:has(.wp-block-navigation)) {
	max-width: 100vw !important;
	overflow-x: hidden !important;
}
/* Header explizit ohne overflow-clip */
.tcr-block-header {
	overflow: visible !important;
}

/* ── Hover-Effekt für Tennisschule-Cards (offers, camps) ── */
.tcr-offer,
.tcr-camp {
	transition: transform 280ms cubic-bezier(.22,.61,.36,1), box-shadow 280ms cubic-bezier(.22,.61,.36,1), border-color 280ms cubic-bezier(.22,.61,.36,1);
}
.tcr-offer:hover,
.tcr-camp:hover {
	transform: translateY(-4px);
	box-shadow: 0 10px 28px -6px rgba(46,98,214,.16);
	border-color: #a8c0f0 !important;
}

/* ── Hover für Vorstand/Trainer-Cards ── */
.tcr-team-card {
	transition: transform 280ms cubic-bezier(.22,.61,.36,1), box-shadow 280ms cubic-bezier(.22,.61,.36,1);
}
.tcr-team-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 24px -6px rgba(46,98,214,.14);
}

/* ── Hover für News-Cards ── */
.tcr-news-card {
	transition: transform 280ms cubic-bezier(.22,.61,.36,1), box-shadow 280ms cubic-bezier(.22,.61,.36,1);
}
.tcr-news-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 24px -6px rgba(46,98,214,.14);
}
