/**
 * Intersections home hero — layout, glows, float motion (pattern intersections-home-gutenverse-hero).
 * Horizontal rail: --intersections-content-max / --intersections-gutter-x (style.css).
 */



/* Fill viewport height through outer column (with or without Gutenverse .sticky-wrapper). */
.guten-intersections-hero .guten-InHeroOuterCol {
	align-self: stretch;
	min-height: 100vh;
}

.guten-intersections-hero .guten-InHeroOuterCol > .sticky-wrapper,
.guten-intersections-hero .guten-InHeroOuterCol > .sticky-wrapper > .guten-column-wrapper,
.guten-intersections-hero .guten-InHeroOuterCol > .guten-column-wrapper {
	align-items: stretch !important;
	align-content: stretch !important;
	flex: 1 1 auto;
	min-height: 100%;
	width: 100%;
}

.guten-intersections-hero .guten-InHeroOuterCol .section-wrapper {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	min-height: 100%;
	width: 100%;
}

.guten-intersections-hero .guten-InHeroInner {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	min-height: 100%;
}

.guten-intersections-hero .guten-InHeroInner > .guten-container {
	max-width: var(--intersections-content-max) !important;
	margin-left: auto !important;
	margin-right: auto !important;
	width: 100% !important;
	flex: 1 1 auto;
	flex-wrap: wrap;
	align-items: stretch;
	min-height: 100%;
	gap: 2rem;
}

.guten-intersections-hero::before,
.guten-intersections-hero::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	filter: blur(100px);
	z-index: 0;
	opacity: 0.5;
	pointer-events: none;
}

.guten-intersections-hero::before {
	width: 450px;
	height: 450px;
	background: #fff4da;
	top: -10%;
	left: -5%;
}

.guten-intersections-hero::after {
	width: 600px;
	height: 600px;
	background: #e1effb;
	bottom: -15%;
	right: 5%;
}

@media (min-width: 992px) {
	.guten-intersections-hero .guten-InHeroInner > .guten-container {
		flex-wrap: nowrap;
		gap: 3rem;
	}

	/*
	 * Copy column: column stack, no wrap (Gutenverse defaults to flex-wrap:wrap and can reorder rows).
	 * Left-align all blocks; keep block vertically centered in the tall column.
	 */
	.guten-intersections-hero .guten-InHeroCopy > .sticky-wrapper > .guten-column-wrapper,
	.guten-intersections-hero .guten-InHeroCopy > .guten-column-wrapper {
		display: flex !important;
		flex-direction: column !important;
		flex-wrap: nowrap !important;
		justify-content: center !important;
		align-items: flex-start !important;
		align-content: flex-start !important;
		min-height: 100%;
	}

	.guten-intersections-hero .guten-InHeroCopy .guten-InHeroLogo.guten-element {
		width: 100% !important;
		max-width: min(50vw, 100%) !important;
		align-self: flex-start;
	}

	.guten-intersections-hero .guten-InHeroCopy .guten-InHeroLogo .guten-image-wrapper {
		justify-content: flex-start !important;
		width: 100%;
		max-width: min(50vw, 100%);
	}

	.guten-intersections-hero .guten-InHeroCopy .guten-InHeroLogo img {
		width: 100% !important;
		max-width: min(50vw, 100%) !important;
		height: auto !important;
		margin-left: 0 !important;
		margin-right: auto !important;
	}

	.guten-intersections-hero .intersections-hero-title {
		white-space: nowrap;
		text-align: left;
		max-width: 100%;
		font-size: clamp(1.35rem, 3.25vw, 3.25rem);
	}

	.guten-intersections-hero .intersections-hero-date,
	.guten-intersections-hero .intersections-hero-location {
		text-align: left;
		align-self: stretch;
	}

	.guten-intersections-hero .guten-InHeroCta {
		align-self: flex-start;
	}

	/* Override Gutenverse column align-* (see gutenverse class-column.php) + sticky-wrapper DOM. */
	.guten-intersections-hero .guten-InHeroVisualCol > .sticky-wrapper > .guten-column-wrapper,
	.guten-intersections-hero .guten-InHeroVisualCol > .guten-column-wrapper {
		flex-direction: column !important;
		justify-content: flex-end !important;
		align-content: flex-end !important;
		align-items: center !important;
	}
}

@media (max-width: 991px) {
	.guten-intersections-hero .intersections-hero-title {
		white-space: normal;
	}

	.guten-intersections-hero .guten-InHeroInner .guten-InHeroCopy {
		order: 2;
		text-align: center;
	}

	.guten-intersections-hero .guten-InHeroInner .guten-InHeroVisualCol {
		order: 1;
	}

	.guten-intersections-hero .guten-InHeroInner .guten-InHeroCopy .guten-column-wrapper {
		align-items: center;
	}

	.guten-intersections-hero .guten-InHeroVisualCol > .sticky-wrapper > .guten-column-wrapper,
	.guten-intersections-hero .guten-InHeroVisualCol > .guten-column-wrapper {
		flex-direction: column !important;
		justify-content: center !important;
		align-content: center !important;
		align-items: center !important;
	}

	.intersections-hero-title,
	.intersections-hero-date,
	.intersections-hero-location {
		text-align: center;
	}
}

.intersections-hero-title {
	margin: 0 0 1.5rem;
	font-family: "Inter", system-ui, sans-serif;
	font-size: clamp(2rem, 4vw, 3.5rem);
	font-weight: 400;
	line-height: 1.15;
	letter-spacing: -0.01em;
	color: #df007e;
}

.intersections-hero-title strong {
	font-weight: 800;
}

.intersections-hero-date {
	margin: 0 0 0.5rem;
	font-family: "Inter", system-ui, sans-serif;
	font-size: 1.2rem;
	font-weight: 800;
	color: #1b1642;
	letter-spacing: 0.05em;
}

.intersections-hero-location {
	margin: 0 0 2rem;
	font-family: "Inter", system-ui, sans-serif;
	font-size: 1.2rem;
	font-weight: 400;
	color: #1b1642;
}

.guten-intersections-hero .guten-InHeroVisualCol > .sticky-wrapper > .guten-column-wrapper,
.guten-intersections-hero .guten-InHeroVisualCol > .guten-column-wrapper {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-end;
	align-content: flex-end;
	min-height: 0;
}

.guten-intersections-hero .guten-InHeroHand .guten-image-wrapper {
	max-height: 75vh;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	width: 100%;
}

.guten-intersections-hero .guten-InHeroHand img {
	width: auto;
	max-width: 100%;
	max-height: 75vh;
	height: auto;
	margin: 0 auto;
	display: block;
	object-fit: contain;
	object-position: bottom center;
	animation: intersections-hero-float-main 8s ease-in-out infinite;
	filter: drop-shadow(0 25px 45px rgba(0, 0, 0, 0.1));
}

.guten-intersections-hero .guten-InHeroFloat1,
.guten-intersections-hero .guten-InHeroFloat2 {
	position: absolute;
	pointer-events: none;
	z-index: 2;
}

.guten-intersections-hero .guten-InHeroFloat1 {
	width: 90px;
	max-width: 22%;
	top: 10%;
	left: 5%;
	animation: intersections-hero-float-slow 12s ease-in-out infinite;
}

.guten-intersections-hero .guten-InHeroFloat2 {
	width: 140px;
	max-width: 28%;
	top: 5%;
	right: -5%;
	animation: intersections-hero-float-slow 15s ease-in-out infinite reverse;
}

@media (max-width: 991px) {
	.guten-intersections-hero::before,
	.guten-intersections-hero::after {
		display: none;
	}

	.guten-intersections-hero .guten-InHeroFloat1,
	.guten-intersections-hero .guten-InHeroFloat2 {
		width: 60px;
		max-width: 20%;
	}
}

@keyframes intersections-hero-float-main {
	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-20px);
	}
}

@keyframes intersections-hero-float-slow {
	0%,
	100% {
		transform: translateY(0) rotate(0deg);
	}

	50% {
		transform: translateY(-30px) rotate(20deg);
	}
}
