/* =========================================================
   TC Reichenstein — Redesign 2026 v2
   Editorial Blau-Weiss · Lädt NACH main.css
   ========================================================= */

:root {
	--tcr-primary:        #0E3A8A;
	--tcr-primary-light:  #2E62D6;
	--tcr-primary-dark:   #06214F;
	--tcr-primary-50:     #F4F8FE;
	--tcr-primary-100:    #E8F1FF;
	--tcr-primary-200:    #C8DCFB;
	--tcr-ink:            #0F1A33;
	--tcr-ink-soft:       #2B3759;
	--tcr-muted:          #5B6986;
	--tcr-line:           #DCE5F2;
	--tcr-accent:         #E8DC4F;       /* nur sehr punktuell */

	--tcr-radius-sm:  10px;
	--tcr-radius-md:  16px;
	--tcr-radius-lg:  24px;
	--tcr-radius-xl:  36px;

	--tcr-shadow-card:  0 1px 2px rgba(14,58,138,.05), 0 18px 36px -16px rgba(14,58,138,.20);
	--tcr-shadow-hover: 0 2px 4px rgba(14,58,138,.06), 0 30px 60px -18px rgba(14,58,138,.30);

	--tcr-ease:     cubic-bezier(.22,.61,.36,1);
	--tcr-ease-out: cubic-bezier(.16,1,.3,1);

	--tcr-section-pad: clamp(3.5rem, 7vw, 6rem);
}

body {
	background:
		radial-gradient(1100px 520px at 92% -8%,  rgba(46,98,214,.08), transparent 60%),
		radial-gradient(900px  500px at -8% 30%,  rgba(14,58,138,.06), transparent 55%),
		#FFFFFF;
	color: var(--tcr-ink);
}

h1, h2, h3, h4 { color: var(--tcr-ink); text-wrap: balance; }
a { transition: color 200ms var(--tcr-ease); }

/* =========================================================
   HERO
   ========================================================= */
.tcr-hero-wrap > .tcr-hero {
	min-height: clamp(580px, 88vh, 840px) !important;
	background: #06214F !important;
	align-items: center !important;
}
.tcr-hero-bg-main {
	background-image: url('/wp-content/uploads/2026/05/tcr-394083123.jpg') !important;
	background-position: center 55% !important;
	filter: saturate(1.06) contrast(1.03);
	animation: tcrHeroZoom 22s var(--tcr-ease) infinite alternate;
}
.tcr-hero::after {
	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%) !important;
}

.tcr-hero-net {
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(ellipse at 50% 30%, rgba(0,0,0,.5), rgba(0,0,0,0) 70%);
	-webkit-mask-image: radial-gradient(ellipse at 50% 30%, rgba(0,0,0,.5), rgba(0,0,0,0) 70%);
	pointer-events: none;
	z-index: -1;
	opacity: .5;
}
.tcr-hero-orb {
	position: absolute; border-radius: 50%; pointer-events: none;
	z-index: -1; filter: blur(48px); opacity: .35;
}
.tcr-hero-orb-1 {
	width: 420px; height: 420px; top: 6%; left: -8%;
	background: radial-gradient(circle, rgba(255,255,255,.30), transparent 70%);
	animation: tcrFloat 16s ease-in-out infinite;
}
.tcr-hero-orb-2 {
	width: 480px; height: 480px; bottom: -12%; right: -10%;
	background: radial-gradient(circle, rgba(46,98,214,.70), transparent 70%);
	animation: tcrFloat 20s ease-in-out infinite reverse;
}

.tcr-hero-eyebrow {
	background: rgba(255,255,255,.10) !important;
	border-color: rgba(255,255,255,.22) !important;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	color: rgba(255,255,255,.92) !important;
	font-size: .8rem !important;
	letter-spacing: .04em;
	padding: .45rem 1.05rem !important;
}
.tcr-hero-eyebrow::before {
	background: #FFFFFF !important;
	box-shadow: 0 0 12px rgba(255,255,255,.7) !important;
	width: 6px !important; height: 6px !important;
	animation: tcrPulse 2.4s ease-in-out infinite;
}

/* Hero-Titel: kein Gradient-Gold mehr — feiner SVG-Unterstrich in Weiss */
.tcr-hero h1 em {
	font-style: normal;
	color: inherit;
	position: relative;
	display: inline;
}
.tcr-h1-accent {
	position: relative;
	display: inline-block;
	color: #FFFFFF;
	white-space: nowrap;
}
.tcr-h1-underline {
	position: absolute;
	left: -1%;
	right: -1%;
	bottom: -.18em;
	width: 102%;
	height: .35em;
	color: rgba(255,255,255,.95);
	pointer-events: none;
	stroke-dasharray: 720;
	stroke-dashoffset: 720;
	animation: tcrUnderlineDraw 1800ms 800ms var(--tcr-ease-out) forwards;
}
@keyframes tcrUnderlineDraw {
	to { stroke-dashoffset: 0; }
}

.tcr-hero p.lead {
	color: rgba(255,255,255,.88) !important;
	font-size: clamp(1.05rem, 1.4vw, 1.2rem) !important;
}

.tcr-hero-meta { gap: 2.5rem !important; }
.tcr-hero-meta span {
	color: rgba(255,255,255,.7) !important;
	font-size: .72rem !important;
	letter-spacing: .14em !important;
	text-transform: uppercase;
}
.tcr-hero-meta span strong {
	color: #FFFFFF !important;
	font-size: 1.85rem !important;
	font-weight: 700 !important;
	letter-spacing: -.02em !important;
	margin-bottom: .15rem;
}

/* Scroll-Cue: feine Linie + Label, rechts unten */
.tcr-scroll-cue {
	position: absolute;
	bottom: clamp(1rem, 3vw, 2rem);
	left: max(1.5rem, calc((100% - 1240px)/2));
	display: inline-flex;
	align-items: center;
	gap: .8rem;
	padding: 0;
	width: auto; height: auto;
	border: none !important;
	border-radius: 0;
	color: rgba(255,255,255,.78);
	text-decoration: none;
	font-family: 'DM Sans', sans-serif;
	font-size: .72rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	z-index: 2;
	transition: color 220ms var(--tcr-ease), gap 220ms var(--tcr-ease);
}
.tcr-scroll-cue-line {
	display: inline-block;
	width: 56px;
	height: 1px;
	background: linear-gradient(90deg, rgba(255,255,255,.7), rgba(255,255,255,.15));
	position: relative;
	overflow: hidden;
}
.tcr-scroll-cue-line::before {
	content: "";
	position: absolute;
	inset: 0;
	width: 50%;
	background: rgba(255,255,255,.95);
	animation: tcrLineSlide 2.4s var(--tcr-ease) infinite;
}
.tcr-scroll-cue:hover { color: #FFFFFF; gap: 1.1rem; }
.tcr-scroll-cue:hover .tcr-scroll-cue-line { background: rgba(255,255,255,.45); }
@media (max-width: 720px) { .tcr-scroll-cue { display: none; } }

/* =========================================================
   STRIPE — direkt nach Hero, deutlich kompakter
   ========================================================= */
.tcr-stripe {
	background: var(--tcr-primary-dark);
	color: #FFFFFF;
	overflow: hidden;
	padding: .85rem 0;
	border: 0;
	position: relative;
	margin: 0 !important;
}
/* Direkt nach Hero ohne weiße Lücke */
.tcr-hero-wrap + .tcr-stripe,
main > .tcr-hero-wrap + section,
.tcr-stripe + .tcr-section {
	margin-top: 0 !important;
}
/* Sicherstellen, dass kein Margin/Padding zwischen aufeinanderfolgenden Top-Level-Sektionen entsteht */
main.wp-block-group > .tcr-hero-wrap,
main.wp-block-group > .tcr-stripe,
main.wp-block-group > .tcr-fullbleed {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}
.tcr-stripe::before, .tcr-stripe::after {
	content: "";
	position: absolute; top: 0; bottom: 0;
	width: 80px;
	z-index: 2;
	pointer-events: none;
}
.tcr-stripe::before { left: 0;  background: linear-gradient(90deg, var(--tcr-primary-dark), rgba(6,33,79,0)); }
.tcr-stripe::after  { right: 0; background: linear-gradient(-90deg, var(--tcr-primary-dark), rgba(6,33,79,0)); }
.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;
}
.tcr-stripe-track span:nth-child(even) {
	color: rgba(255,255,255,.35);
}

/* =========================================================
   SECTION
   ========================================================= */
.tcr-section {
	padding: var(--tcr-section-pad) 0;
	position: relative;
}
/* Reduzierte Top-Abstände für gestaffelte Sektionen — News, Termine */
.tcr-section.tcr-section-tight { padding-top: clamp(2rem, 4vw, 3rem) !important; padding-bottom: clamp(2rem, 4vw, 3rem) !important; }
/* Sektion direkt nach CTA-Strip oder Stripe braucht weniger Top */
.tcr-cta-strip + .tcr-section,
.tcr-stripe + .tcr-section { padding-top: clamp(3rem, 5vw, 4.5rem); }
.tcr-section-soft {
	background:
		radial-gradient(900px 500px at 110% 0%, rgba(46,98,214,.10), transparent 60%),
		linear-gradient(180deg, var(--tcr-primary-50) 0%, #FFFFFF 100%);
	padding-top: var(--tcr-section-pad);
}
.tcr-section-inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}

/* Mobile: Konsistenter Mindest-Seitenabstand (20px) */
@media (max-width: 767px) {
	.tcr-section-inner {
		padding-left: max(1.25rem, env(safe-area-inset-left, 1.25rem));
		padding-right: max(1.25rem, env(safe-area-inset-right, 1.25rem));
	}
}
.tcr-section-head {
	max-width: 720px;
	margin: 0 auto clamp(2rem, 4vw, 3rem);
	text-align: center;
}
.tcr-section-head-split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	max-width: none;
	margin-bottom: clamp(2rem, 4vw, 3rem);
	text-align: left;
	align-items: end;
}
@media (min-width: 860px) {
	.tcr-section-head-split { grid-template-columns: 1.2fr 1fr; gap: 3rem; }
}
.tcr-section-head-center { text-align: center; max-width: 720px; margin-left: auto; margin-right: auto; }
.tcr-section-head 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-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-section-head-center .tcr-lede { margin-left: auto; margin-right: auto; }
.tcr-eyebrow {
	color: var(--tcr-primary) !important;
	font-weight: 600 !important;
	font-size: .74rem !important;
	letter-spacing: .22em !important;
	text-transform: uppercase;
	display: inline-flex !important;
	align-items: center;
	gap: .6rem;
	margin-bottom: .9rem !important;
}
.tcr-eyebrow::before {
	content: "";
	width: 28px;
	height: 1px;
	background: currentColor;
	display: inline-block;
}
.tcr-eyebrow-light { color: rgba(255,255,255,.85) !important; }

.tcr-section-link {
	font-family: 'DM Sans', sans-serif;
	font-weight: 600;
	color: var(--tcr-primary);
	text-decoration: none;
	font-size: .9rem;
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	transition: gap 200ms var(--tcr-ease), color 200ms var(--tcr-ease);
	align-self: end;
	justify-self: end;
	border-bottom: 1px solid var(--tcr-primary);
	padding-bottom: 2px;
}
.tcr-section-link:hover { gap: .7rem; color: var(--tcr-primary-light); }

/* =========================================================
   SHOWCASE (Anlage) — Caption deutlich Weiss
   ========================================================= */
.tcr-showcase {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-auto-rows: minmax(260px, auto);
	gap: 1.25rem;
}
@media (min-width: 900px) {
	.tcr-showcase { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 320px; gap: 1.5rem; }
}
.tcr-showcase-card {
	position: relative;
	margin: 0;
	overflow: hidden;
	border-radius: var(--tcr-radius-lg);
	box-shadow: var(--tcr-shadow-card);
	background: transparent;
	isolation: isolate;
}
.tcr-showcase-lg {
	grid-column: span 2;
	grid-row: span 2;
	min-height: 380px;
}
@media (max-width: 899px) {
	.tcr-showcase-lg { grid-row: span 1; min-height: 320px; }
}
.tcr-showcase-card img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transform: scale(1.02);
	transition: transform 1400ms var(--tcr-ease), filter 600ms var(--tcr-ease);
}
/* Removed - now using wp-block-cover__background for gradient */
.tcr-showcase-card figcaption {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: 1.4rem 1.6rem;
	color: #FFFFFF !important;
	z-index: 2;
}
.tcr-showcase-card figcaption h3 {
	margin: .55rem 0 0;
	color: #FFFFFF !important;
	font-size: clamp(1.1rem, 1.6vw, 1.5rem);
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1.15;
	text-shadow: 0 2px 12px rgba(6,33,79,.6);
}
.tcr-showcase-card figcaption p {
	margin: .4rem 0 0;
	color: rgba(255,255,255,.85) !important;
	font-size: .88rem;
	letter-spacing: .01em;
}
.tcr-tag {
	display: inline-block;
	padding: .25rem .7rem;
	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 !important;
	backdrop-filter: blur(8px);
}
.tcr-showcase-card:hover img { transform: scale(1.08); filter: brightness(1.06); }
.tcr-showcase-card:hover { box-shadow: var(--tcr-shadow-hover); }

/* =========================================================
   CARDS (Angebote) — flacher, editorialer
   ========================================================= */
.tcr-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.25rem;
}
.tcr-card {
	display: block;
	padding: 1.75rem 1.5rem 1.6rem;
	background: #FFFFFF;
	border: 1px solid var(--tcr-line);
	border-radius: var(--tcr-radius-md);
	text-decoration: none;
	color: var(--tcr-ink);
	transition: transform 320ms var(--tcr-ease), box-shadow 320ms var(--tcr-ease), border-color 320ms var(--tcr-ease);
	position: relative;
	overflow: hidden;
}
.tcr-card::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--tcr-primary), var(--tcr-primary-light));
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 480ms var(--tcr-ease);
}
.tcr-card-icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: var(--tcr-primary-100);
	color: var(--tcr-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.2rem;
	transition: transform 320ms var(--tcr-ease), background 320ms var(--tcr-ease), color 320ms var(--tcr-ease);
}
.tcr-card h3 {
	font-size: 1.18rem;
	font-weight: 700;
	margin: 0 0 .45rem;
	letter-spacing: -.02em;
	color: var(--tcr-ink);
}
.tcr-card p {
	color: var(--tcr-muted);
	font-size: .94rem;
	line-height: 1.6;
	margin: 0 0 1.15rem;
}
.tcr-card-link {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	color: var(--tcr-primary);
	font-weight: 600;
	font-size: .9rem;
	transition: gap 220ms var(--tcr-ease);
}
.tcr-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--tcr-shadow-hover);
	border-color: var(--tcr-primary-200);
}
.tcr-card:hover::before { transform: scaleX(1); }
.tcr-card:hover .tcr-card-icon {
	background: var(--tcr-primary);
	color: #FFFFFF;
	transform: rotate(-4deg) scale(1.05);
}
.tcr-card:hover .tcr-card-link { gap: .6rem; }

/* =========================================================
   SPLIT — Geschichte / Bild
   ========================================================= */
.tcr-split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 900px) {
	.tcr-split { grid-template-columns: 1fr 1.05fr; gap: 4rem; }
}
.tcr-split-text h2 { font-size: clamp(2rem, 4vw, 3.2rem); margin: 0; line-height: 1.05; letter-spacing: -.025em; }
.tcr-split-text p {
	color: var(--tcr-muted);
	font-size: 1.05rem;
	line-height: 1.7;
	margin: 1.25rem 0 0;
}
.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-stat strong {
	display: block;
	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-stat span {
	display: block;
	margin-top: .4rem;
	font-size: .72rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--tcr-muted);
	font-weight: 600;
}
.tcr-split-media { position: relative; min-height: 440px; }
.tcr-split-img {
	position: absolute;
	border-radius: var(--tcr-radius-xl);
	box-shadow: var(--tcr-shadow-card);
	display: block;
	overflow: hidden;
	object-fit: cover;
	transition: transform 700ms var(--tcr-ease);
}
.tcr-split-img:nth-of-type(1) {
	width: 78%; height: 80%;
	top: 0; right: 0;
	animation: tcrFloatSoft 7s ease-in-out infinite;
}
.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;
}
.tcr-split-media:hover .tcr-split-img { transform: scale(1.015); }
.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-split-badge-year {
	display: block;
	font-size: .62rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: rgba(255,255,255,.65);
	margin-bottom: .1rem;
}
.tcr-split-badge strong {
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: -.02em;
	color: #FFFFFF;
}

/* =========================================================
   CTA STRIP
   ========================================================= */
.tcr-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;
}
.tcr-cta-strip::before,
.tcr-cta-strip::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	z-index: -1;
}
.tcr-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-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-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-cta-strip-inner { grid-template-columns: 1.3fr 1fr; gap: 4rem; }
}
.tcr-cta-strip h2,
.tcr-cta-strip h2 * {
	color: #FFFFFF !important;
	font-size: clamp(1.85rem, 3.6vw, 2.85rem);
	margin: 0;
	line-height: 1.05;
	letter-spacing: -.02em;
}
.tcr-cta-strip p,
.tcr-cta-strip-text p {
	color: rgba(255,255,255,.88) !important;
	font-size: 1.05rem;
	line-height: 1.6;
	margin: 1.1rem 0 0;
	max-width: 50ch;
}
.tcr-cta-strip .tcr-eyebrow-light,
.tcr-cta-strip-text .tcr-eyebrow {
	color: rgba(255,255,255,.85) !important;
}
.tcr-cta-strip-actions {
	display: flex;
	flex-wrap: wrap;
	gap: .85rem;
	justify-self: end;
}
@media (max-width: 859px) {
	.tcr-cta-strip-actions { justify-self: start; }
}
.tcr-btn-light {
	background: #FFFFFF;
	color: var(--tcr-primary-dark) !important;
	border-color: #FFFFFF;
	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 #FFFFFF;
	transition: transform 220ms var(--tcr-ease), box-shadow 220ms var(--tcr-ease);
	box-shadow: 0 12px 28px rgba(0,0,0,.2);
}
.tcr-btn-light:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(0,0,0,.28); }
.tcr-btn-outline-light {
	background: transparent;
	color: #FFFFFF !important;
	border: 2px solid rgba(255,255,255,.65);
	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;
	transition: background 220ms var(--tcr-ease), border-color 220ms var(--tcr-ease), transform 220ms var(--tcr-ease);
}
.tcr-btn-outline-light:hover {
	background: rgba(255,255,255,.1);
	border-color: #FFFFFF;
	transform: translateY(-2px);
}
.tcr-btn-arrow { transition: transform 240ms var(--tcr-ease); display: inline-block; }
.tcr-btn:hover .tcr-btn-arrow,
.tcr-btn-light:hover .tcr-btn-arrow { transform: translateX(4px); }
body .tcr-btn-primary { background: var(--tcr-primary); color: #FFFFFF; }
body .tcr-btn-primary:hover { background: var(--tcr-primary-dark); color: #FFFFFF; }

/* =========================================================
   NEWS GRID
   ========================================================= */
.tcr-news-grid .wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
}
.tcr-news-card {
	background: #FFFFFF;
	border: 1px solid var(--tcr-line);
	border-radius: var(--tcr-radius-md);
	overflow: hidden;
	transition: transform 320ms var(--tcr-ease), box-shadow 320ms var(--tcr-ease);
	display: flex !important;
	flex-direction: column;
	padding: 0 !important;
}
.tcr-news-card .wp-block-post-featured-image {
	margin: 0 !important;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--tcr-primary-50);
}
.tcr-news-card .wp-block-post-featured-image img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--tcr-ease);
}
.tcr-news-card > *:not(.wp-block-post-featured-image) {
	padding-left: 1.4rem !important;
	padding-right: 1.4rem !important;
}
.tcr-news-card > .wp-block-post-date { padding-top: 1.2rem !important; }
.tcr-news-card > :last-child { padding-bottom: 1.4rem !important; }
.tcr-news-card .wp-block-post-title { margin: .4rem 0 .55rem !important; }
.tcr-news-card .wp-block-post-title a { color: var(--tcr-ink); text-decoration: none; transition: color 200ms var(--tcr-ease); }
.tcr-news-card .wp-block-post-title a:hover { color: var(--tcr-primary); }
.tcr-news-card:hover { transform: translateY(-4px); box-shadow: var(--tcr-shadow-hover); }
.tcr-news-card:hover .wp-block-post-featured-image img { transform: scale(1.05); }

/* =========================================================
   EVENTS LIST
   ========================================================= */
.tcr-events-wrap .tcr-event-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: .85rem;
}
.tcr-events-wrap .tcr-event-item {
	display: grid;
	grid-template-columns: 130px 1fr;
	gap: 1.4rem;
	padding: 1.25rem 1.5rem;
	background: #FFFFFF;
	border: 1px solid var(--tcr-line);
	border-radius: var(--tcr-radius-md);
	transition: transform 280ms var(--tcr-ease), border-color 280ms var(--tcr-ease), box-shadow 280ms var(--tcr-ease);
}
@media (max-width: 600px) {
	.tcr-events-wrap .tcr-event-item { grid-template-columns: 1fr; gap: .5rem; }
}
.tcr-events-wrap .tcr-event-item:hover {
	transform: translateX(4px);
	border-color: var(--tcr-primary-200);
	box-shadow: var(--tcr-shadow-card);
}
.tcr-events-wrap .tcr-event-date {
	color: var(--tcr-primary);
	font-weight: 700;
	display: flex;
	flex-direction: column;
	gap: .15rem;
	padding-right: 1.25rem;
	border-right: 1px solid var(--tcr-line);
}
@media (max-width: 600px) {
	.tcr-events-wrap .tcr-event-date { border-right: none; padding-right: 0; flex-direction: row; gap: .6rem; align-items: baseline; }
}
.tcr-events-wrap .tcr-event-date strong { font-size: 1rem; letter-spacing: -.01em; }
.tcr-events-wrap .tcr-event-date span { font-size: .85rem; color: var(--tcr-muted); font-weight: 500; }
.tcr-events-wrap .tcr-event-body h4 { margin: 0 0 .25rem; font-size: 1.05rem; color: var(--tcr-ink); }
.tcr-events-wrap .tcr-event-location {
	font-size: .85rem;
	color: var(--tcr-muted);
	margin: 0;
}

/* =========================================================
   PARTNERS — komplett überarbeitet, mit Abstand zum Footer
   ========================================================= */
.tcr-partners.tcr-fullbleed,
.tcr-partners {
	padding-top: var(--tcr-section-pad) !important;
	padding-bottom: clamp(5rem, 9vw, 8rem) !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	background:
		linear-gradient(180deg, #FFFFFF 0%, var(--tcr-primary-50) 100%);
	position: relative;
	margin-bottom: 0;
}
.tcr-partners + .site-footer,
.tcr-partners + footer {
	margin-top: 0 !important;
}
.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-partners-inner { grid-template-columns: 1fr 1.4fr; gap: 4rem; }
}
.tcr-partners-intro h2 {
	font-size: clamp(1.85rem, 3vw, 2.4rem);
	margin: 0;
	line-height: 1.1;
	letter-spacing: -.025em;
}
.tcr-partners-intro p {
	color: var(--tcr-muted);
	font-size: 1rem;
	line-height: 1.7;
	margin: 1rem 0 1.5rem;
	max-width: 36ch;
}
.tcr-partners-link {
	color: var(--tcr-primary);
	font-weight: 600;
	text-decoration: none;
	font-size: .92rem;
	border-bottom: 1px solid currentColor;
	padding-bottom: 2px;
	transition: gap 200ms var(--tcr-ease);
	display: inline-block;
}
.tcr-partners-link:hover { color: var(--tcr-primary-light); }
.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-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 var(--tcr-ease);
}
.tcr-partner-tile img {
	max-height: 56px;
	max-width: 70%;
	width: auto;
	height: auto;
	filter: grayscale(1);
	opacity: .65;
	transition: filter 320ms var(--tcr-ease), opacity 320ms var(--tcr-ease), transform 320ms var(--tcr-ease);
}
.tcr-partner-tile span {
	font-size: .72rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--tcr-muted);
	font-weight: 600;
	transition: color 280ms var(--tcr-ease);
}
.tcr-partner-tile:hover { background: var(--tcr-primary-50); }
.tcr-partner-tile:hover img { filter: grayscale(0); opacity: 1; transform: scale(1.04); }
.tcr-partner-tile:hover span { color: var(--tcr-primary); }

.tcr-partner-tile-placeholder {
	background: repeating-linear-gradient(45deg, #FFFFFF, #FFFFFF 6px, var(--tcr-primary-50) 6px, var(--tcr-primary-50) 12px);
}
.tcr-partner-tile-cta {
	color: var(--tcr-primary) !important;
	font-weight: 600;
	font-size: .8rem !important;
	letter-spacing: .04em !important;
	text-transform: none !important;
	text-align: center;
	max-width: 14ch;
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header {
	background: rgba(255,255,255,.85) !important;
	backdrop-filter: saturate(180%) blur(14px) !important;
	-webkit-backdrop-filter: saturate(180%) blur(14px) !important;
	border-bottom-color: rgba(220,229,242,.6) !important;
	transition: background 240ms var(--tcr-ease), box-shadow 240ms var(--tcr-ease);
}
.site-header.is-scrolled {
	background: rgba(255,255,255,.96) !important;
	box-shadow: 0 4px 20px -8px rgba(14,58,138,.18);
}
.tcr-logo-wordmark-top { color: var(--tcr-primary) !important; }
.tcr-logo-wordmark-bottom { color: var(--tcr-ink) !important; }
.tcr-nav-cta > a {
	background: var(--tcr-primary) !important;
	color: #FFFFFF !important;
	border-radius: 999px;
	padding: .55rem 1.1rem !important;
	transition: background 220ms var(--tcr-ease), transform 220ms var(--tcr-ease);
}
.tcr-nav-cta > a:hover { background: var(--tcr-primary-dark) !important; transform: translateY(-1px); }

/* =========================================================
   FOOTER — komplett neu, mit Weiss-Akzent
   ========================================================= */
.site-footer.tcr-footer,
footer.tcr-footer {
	background: var(--tcr-primary-dark) !important;
	color: rgba(255,255,255,.78);
	position: relative;
	overflow: hidden;
	padding: 0 !important;
	margin: 0 !important;
}
.site-footer.tcr-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;
}
.site-footer.tcr-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-footer-inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: clamp(3.5rem, 7vw, 5.5rem) clamp(1.25rem, 4vw, 2.5rem) 1.5rem;
	position: relative;
	z-index: 1;
}
.tcr-footer-top {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}
@media (min-width: 900px) {
	.tcr-footer-top { grid-template-columns: 1.1fr 1.6fr; gap: 4rem; }
}
.tcr-footer-logo {
	display: flex;
	align-items: center;
	gap: .9rem;
	margin-bottom: 1.25rem;
}
.tcr-footer-logo img {
	width: 48px; height: 48px;
	background: #FFFFFF;
	border-radius: 12px;
	padding: 4px;
}
.tcr-footer-logo > div { display: flex; flex-direction: column; line-height: 1.1; }
.tcr-footer-brand-top {
	color: rgba(255,255,255,.6) !important;
	font-size: .8rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 500;
}
.tcr-footer-brand-bottom {
	color: #FFFFFF !important;
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: -.015em;
}
.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-footer-cta {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .85rem 1.5rem;
	background: #FFFFFF;
	color: var(--tcr-primary-dark) !important;
	border-radius: 999px;
	font-weight: 700;
	font-size: .92rem;
	text-decoration: none;
	transition: transform 220ms var(--tcr-ease), box-shadow 220ms var(--tcr-ease);
}
.tcr-footer-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 32px rgba(0,0,0,.3);
	color: var(--tcr-primary-dark) !important;
}
.tcr-footer-cta:hover span { transform: translateX(4px); }
.tcr-footer-cta span { transition: transform 220ms var(--tcr-ease); }

.tcr-footer-nav {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 600px) {
	.tcr-footer-nav { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
}
.tcr-footer-col h4 {
	color: #FFFFFF !important;
	font-size: .7rem !important;
	letter-spacing: .22em !important;
	text-transform: uppercase;
	font-weight: 700 !important;
	margin: 0 0 1.25rem !important;
	padding-bottom: .8rem;
	border-bottom: 1px solid rgba(255,255,255,.12);
	position: relative;
}
.tcr-footer-col h4::after {
	content: "";
	position: absolute;
	bottom: -1px; left: 0;
	width: 28px; height: 1px;
	background: #FFFFFF;
}
.tcr-footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: .55rem;
}
.tcr-footer-col ul a {
	color: rgba(255,255,255,.78) !important;
	text-decoration: none;
	font-size: .95rem;
	transition: color 200ms var(--tcr-ease), padding-left 200ms var(--tcr-ease);
	position: relative;
	display: inline-block;
}
.tcr-footer-col ul a::before {
	content: "→";
	position: absolute;
	left: -1.3rem;
	opacity: 0;
	transform: translateX(-4px);
	transition: opacity 200ms var(--tcr-ease), transform 200ms var(--tcr-ease);
}
.tcr-footer-col ul a:hover {
	color: #FFFFFF !important;
	padding-left: .2rem;
}
.tcr-footer-col ul a:hover::before {
	opacity: 1;
	transform: translateX(0);
}
.tcr-footer-col-contact address {
	font-style: normal;
	color: rgba(255,255,255,.78);
	font-size: .95rem;
	line-height: 1.7;
}
.tcr-footer-col-contact address a {
	color: #FFFFFF !important;
	text-decoration: underline;
	text-decoration-color: rgba(255,255,255,.3);
	text-underline-offset: 3px;
	transition: text-decoration-color 200ms var(--tcr-ease);
}
.tcr-footer-col-contact address a:hover { text-decoration-color: #FFFFFF; }
.tcr-footer-anlage {
	color: rgba(255,255,255,.55) !important;
	margin-top: .1rem !important;
	font-size: .85rem !important;
}

/* Riesiger Wordmark als grafischer Akzent — endlos fließend mit Doppel-Track */
.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;
	color: transparent;
	-webkit-text-stroke: 1px rgba(255,255,255,.25);
	user-select: none;
	width: 100%;
	mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.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-footer-marquee-track span:not(.tcr-footer-marquee-sep) {
	-webkit-text-stroke: 1px rgba(255,255,255,.25);
	color: transparent;
}
.tcr-footer-marquee-sep {
	color: rgba(255,255,255,.45) !important;
	-webkit-text-stroke: 0 !important;
	font-size: .35em;
	align-self: center;
}
@keyframes tcrFooterScroll {
	from { transform: translateX(0); }
	to { transform: translateX(-100%); }
}

.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-footer-copy {
	color: rgba(255,255,255,.5) !important;
	font-size: .82rem !important;
	margin: 0 !important;
}
.tcr-footer-legal {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 1.5rem;
}
.tcr-footer-legal a {
	color: rgba(255,255,255,.55) !important;
	text-decoration: none;
	font-size: .82rem;
	transition: color 200ms var(--tcr-ease);
}
.tcr-footer-legal a:hover { color: #FFFFFF !important; }

/* =========================================================
   PAGE / SINGLE / ARCHIVE — Unterseiten-Polish
   ========================================================= */
.tcr-page-hero {
	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%);
	padding: clamp(5rem, 10vw, 7rem) 0 clamp(2rem, 4vw, 3rem);
	margin-top: 0 !important;
	position: relative;
	overflow: hidden;
	min-height: clamp(280px, 38vh, 420px);
	display: flex;
	align-items: flex-end;
}
.tcr-page-hero::before {
	content: "";
	position: absolute;
	right: -100px; bottom: -100px;
	width: 320px; height: 320px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(14,58,138,.08), transparent 70%);
	filter: blur(20px);
	pointer-events: none;
}
.tcr-page-hero-inner {
	max-width: 1240px;
	width: 100%;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 4vw, 2.5rem);
	position: relative;
	z-index: 2;
}
.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 0 1.1rem;
}
.tcr-page-hero-eyebrow::before {
	content: "";
	width: 28px;
	height: 1px;
	background: currentColor;
}
.tcr-page-hero-eyebrow-light {
	color: rgba(255,255,255,.85) !important;
}
.tcr-page-hero h1 {
	font-size: clamp(2.2rem, 4.5vw, 3.6rem) !important;
	font-weight: 700;
	letter-spacing: -.025em;
	line-height: 1.05;
	margin: 0 0 1rem !important;
	max-width: 22ch;
	color: var(--tcr-ink) !important;
}
.tcr-page-hero-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin-top: 1.5rem;
	color: var(--tcr-muted);
	font-size: .9rem;
}

/* Variante MIT Bild — Bild als Hintergrund, weisser Titel, kein Negative-Margin im Content */
.tcr-page-hero-image {
	min-height: clamp(380px, 52vh, 560px);
	background: var(--tcr-primary-dark);
	color: #FFFFFF;
	align-items: flex-end;
}
.tcr-page-hero-image::before { display: none; }
.tcr-page-hero-bg {
	position: absolute; inset: 0;
	background-image: var(--tcr-page-hero-image, none);
	background-size: cover;
	background-position: center 50%;
	z-index: 0;
	filter: saturate(1.05) contrast(1.02);
	transform: scale(1.02);
	animation: tcrHeroZoom 24s var(--tcr-ease) infinite alternate;
}
.tcr-page-hero-bg::after {
	content: "";
	position: absolute; inset: 0;
	background:
		linear-gradient(180deg, rgba(6,33,79,.30) 0%, rgba(6,33,79,.70) 60%, rgba(6,33,79,.95) 100%),
		linear-gradient(115deg, rgba(14,58,138,.45) 0%, rgba(6,33,79,0) 60%);
}
.tcr-page-hero-net {
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
	background-size: 56px 56px;
	mask-image: radial-gradient(ellipse at 50% 100%, rgba(0,0,0,.5), rgba(0,0,0,0) 70%);
	-webkit-mask-image: radial-gradient(ellipse at 50% 100%, rgba(0,0,0,.5), rgba(0,0,0,0) 70%);
	pointer-events: none;
	z-index: 1;
	opacity: .5;
}
.tcr-page-hero-image .tcr-page-hero-inner {
	padding-bottom: clamp(1.5rem, 4vw, 3rem);
}
/* Titel komplett innerhalb Hero, mit massivem negativem Margin Hochzieh */
.tcr-page-hero-image + .tcr-page-content {
	position: relative;
	padding-top: clamp(2rem, 4vw, 3rem);
}
.tcr-page-hero-image + .tcr-page-content > .wp-block-post-title,
.tcr-page-hero-image + .wp-block-group > .wp-block-post-title,
.tcr-page-hero-image + .tcr-page-content-wide > .wp-block-post-title,
.tcr-page-content-wide > .wp-block-post-title {
	color: #FFFFFF !important;
	position: relative;
	z-index: 3;
	max-width: 920px !important;
	width: 100%;
	margin-left: auto !important;
	margin-right: auto !important;
	padding: 0;
	margin-top: clamp(-13rem, -22vh, -9rem) !important;
	margin-bottom: clamp(3rem, 6vw, 5rem) !important;
	text-shadow: 0 4px 24px rgba(6,33,79,.45);
}
.tcr-page-content {
	max-width: 920px;
	margin: 0 auto;
	padding: clamp(2rem, 4vw, 3rem) clamp(1.25rem, 4vw, 2.5rem) clamp(4rem, 7vw, 6rem);
	font-size: 1.08rem;
	line-height: 1.75;
	color: var(--tcr-ink-soft);
}
/* Textspalten innerhalb bleiben gut lesbar, aber Bilder dürfen die volle Breite nutzen */
.tcr-page-content > p,
.tcr-page-content > ul,
.tcr-page-content > ol,
.tcr-page-content > h2,
.tcr-page-content > h3,
.tcr-page-content > h4,
.tcr-page-content > blockquote {
	max-width: 720px;
}
.tcr-page-content-wide {
	max-width: 1240px;
}
.tcr-page-content-wide > * {
	max-width: 920px;
	margin-left: auto !important;
	margin-right: auto !important;
}
.tcr-page-content-wide > .wp-block-image,
.tcr-page-content-wide > .wp-block-gallery,
.tcr-page-content-wide > .wp-block-cover,
.tcr-page-content-wide > .alignwide,
.tcr-page-content-wide > .alignfull {
	max-width: none;
}
.tcr-page-content-wide > .alignwide { max-width: 1240px; }
.tcr-page-content > h2,
.tcr-page-content > h3,
.tcr-page-content > h4 { color: var(--tcr-ink); margin-top: 2.5rem; margin-bottom: .8rem; }
.tcr-page-content > h2 { font-size: 1.8rem; }
.tcr-page-content > h3 { font-size: 1.35rem; }
.tcr-page-content > p { margin: 0 0 1.25rem; }
.tcr-page-content > p:first-of-type { font-size: 1.18rem; color: var(--tcr-ink); }
.tcr-page-content a { color: var(--tcr-primary); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--tcr-primary-200); }
.tcr-page-content a:hover { text-decoration-color: var(--tcr-primary); }
.tcr-page-content blockquote {
	border-left: 3px solid var(--tcr-primary);
	margin: 2rem 0;
	padding: .5rem 0 .5rem 1.5rem;
	font-style: italic;
	color: var(--tcr-ink);
	font-size: 1.2rem;
}
.tcr-page-content img,
.tcr-page-content .wp-block-image img {
	border-radius: var(--tcr-radius-md);
	box-shadow: var(--tcr-shadow-card);
	margin: 2rem 0;
}
.tcr-page-content ul, .tcr-page-content ol { padding-left: 1.5rem; }
.tcr-page-content li { margin-bottom: .5rem; }

.tcr-archive-grid {
	max-width: 1240px;
	margin: 0 auto;
	padding: clamp(2rem, 4vw, 3rem) clamp(1.25rem, 4vw, 2.5rem) clamp(4rem, 7vw, 6rem);
}
.tcr-archive-grid .wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
}
.tcr-archive-grid .wp-block-post {
	background: #FFFFFF;
	border: 1px solid var(--tcr-line);
	border-radius: var(--tcr-radius-md);
	overflow: hidden;
	transition: transform 280ms var(--tcr-ease), box-shadow 280ms var(--tcr-ease);
	padding: 0 !important;
}
.tcr-archive-grid .wp-block-post:hover {
	transform: translateY(-3px);
	box-shadow: var(--tcr-shadow-hover);
}
.tcr-archive-grid .wp-block-post-featured-image {
	margin: 0 !important;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--tcr-primary-50);
}
.tcr-archive-grid .wp-block-post-featured-image img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 600ms var(--tcr-ease);
}
.tcr-archive-grid .wp-block-post:hover .wp-block-post-featured-image img { transform: scale(1.05); }
.tcr-archive-grid .wp-block-post > *:not(.wp-block-post-featured-image) {
	padding-left: 1.5rem !important;
	padding-right: 1.5rem !important;
}
.tcr-archive-grid .wp-block-post > .wp-block-post-date { padding-top: 1.2rem !important; }
.tcr-archive-grid .wp-block-post > :last-child { padding-bottom: 1.5rem !important; }
.tcr-archive-grid .wp-block-post-title a {
	color: var(--tcr-ink);
	text-decoration: none;
	transition: color 200ms var(--tcr-ease);
}
.tcr-archive-grid .wp-block-post-title a:hover { color: var(--tcr-primary); }

/* =========================================================
   404
   ========================================================= */
.tcr-404 {
	background:
		radial-gradient(800px 400px at 30% 20%, rgba(46,98,214,.12), transparent 60%),
		linear-gradient(180deg, var(--tcr-primary-50) 0%, #FFFFFF 100%);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.25rem, 4vw, 2.5rem);
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
}
.tcr-404-inner {
	max-width: 540px;
	text-align: center;
}
.tcr-404-mark {
	width: clamp(140px, 18vw, 200px);
	height: clamp(140px, 18vw, 200px);
	margin: 0 auto 1.75rem;
	animation: tcrFloatSoft 4s ease-in-out infinite;
}
.tcr-404-mark svg { width: 100%; height: 100%; }
.tcr-404 h1 {
	font-size: clamp(2rem, 5vw, 3.2rem);
	font-weight: 700;
	letter-spacing: -.025em;
	line-height: 1.1;
	margin: .5rem 0 1rem;
	color: var(--tcr-ink);
}
.tcr-404 p {
	color: var(--tcr-muted);
	font-size: 1.05rem;
	line-height: 1.65;
	margin: 0 auto 2rem;
	max-width: 38ch;
}
.tcr-404-actions {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: .75rem;
}
.tcr-btn-ghost-dark {
	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;
	background: transparent;
	color: var(--tcr-primary) !important;
	border: 2px solid var(--tcr-primary-200);
	transition: background 220ms var(--tcr-ease), border-color 220ms var(--tcr-ease), transform 220ms var(--tcr-ease);
}
.tcr-btn-ghost-dark:hover {
	background: var(--tcr-primary-50);
	border-color: var(--tcr-primary);
	transform: translateY(-2px);
}

/* =========================================================
   REVEAL
   ========================================================= */
[data-reveal],
.tcr-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 900ms var(--tcr-ease), transform 900ms var(--tcr-ease);
	will-change: opacity, transform;
}
[data-reveal].is-in,
.tcr-reveal.is-in { opacity: 1; transform: translateY(0); }

.tcr-showcase [data-reveal]:nth-child(2) { transition-delay: 120ms; }
.tcr-showcase [data-reveal]:nth-child(3) { transition-delay: 240ms; }
.tcr-cards [data-reveal]:nth-child(2) { transition-delay: 80ms; }
.tcr-cards [data-reveal]:nth-child(3) { transition-delay: 160ms; }
.tcr-cards [data-reveal]:nth-child(4) { transition-delay: 240ms; }

/* =========================================================
   KEYFRAMES
   ========================================================= */
@keyframes tcrHeroZoom {
	0%   { transform: scale(1.02); }
	100% { transform: scale(1.10); }
}
@keyframes tcrFloat {
	0%, 100% { transform: translate(0, 0); }
	50%      { transform: translate(20px, -30px); }
}
@keyframes tcrFloatSoft {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-8px); }
}
@keyframes tcrPulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(255,255,255,.5); }
	50%      { box-shadow: 0 0 0 10px rgba(255,255,255,0); }
}
@keyframes tcrLineSlide {
	0%   { transform: translateX(-100%); }
	100% { transform: translateX(280%); }
}
@keyframes tcrMarquee {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}
@keyframes tcrSpin {
	0%   { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .001ms !important;
	}
	[data-reveal], .tcr-reveal { opacity: 1; transform: none; }
}
