.wp-block-apcs-platform-conference-hero.apcs-conference-hero,
.apcs-conference-hero {
	--apcs-conference-hero-ink: #2f3a43;
	--apcs-conference-hero-title: #26313a;
	--apcs-conference-hero-muted: #26313a;
	--apcs-conference-hero-soft: rgb(47 58 67 / 0.68);
	position: relative;
	isolation: isolate;
	height: 90vh;
	height: 90svh;
	min-height: 640px;
	margin-block: 0;
	overflow: hidden;
	background: #eef4f6;
	color: var(--apcs-conference-hero-ink);
}

.apcs-conference-hero__media,
.apcs-conference-hero__wash {
	position: absolute;
	inset: 0;
	z-index: -2;
}

.apcs-conference-hero__slide {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	margin: 0;
	opacity: 0;
	transition: opacity 900ms ease;
}

.apcs-conference-hero__slide.is-active,
.apcs-conference-hero__media--single .apcs-conference-hero__slide {
	opacity: 1;
}

.apcs-conference-hero__image {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center 55%;
	filter: saturate(0.82) contrast(0.96) brightness(1.08);
}

.apcs-conference-hero-editor__slide-list {
	display: grid;
	gap: 10px;
	margin-top: 14px;
}

.apcs-conference-hero-editor__slide {
	display: grid;
	gap: 8px;
	padding: 10px;
	border: 1px solid #d0d7de;
	border-radius: 8px;
	background: #fff;
}

.apcs-conference-hero-editor__slide-title,
.apcs-conference-hero-editor__slide-url {
	margin: 0;
}

.apcs-conference-hero-editor__slide-title {
	font-size: 12px;
	font-weight: 700;
	color: #1f2937;
}

.apcs-conference-hero-editor__slide-url {
	font-size: 11px;
	line-height: 1.35;
	color: #4b5563;
	word-break: break-all;
}

.apcs-conference-hero-editor__slide-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.apcs-conference-hero__wash {
	z-index: -1;
	background:
		radial-gradient(circle at 78% 18%, rgb(255 255 255 / 0.52) 0 22%, rgb(255 255 255 / 0) 48%),
		linear-gradient(180deg, rgb(255 255 255 / 0.46) 0%, rgb(255 255 255 / 0.3) 42%, rgb(255 255 255 / 0.58) 100%),
		linear-gradient(90deg, rgb(255 255 255 / 0.58) 0%, rgb(255 255 255 / 0.32) 48%, rgb(255 255 255 / 0.18) 100%);
	backdrop-filter: saturate(1.05);
}

.apcs-conference-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background-image:
		linear-gradient(rgb(7 19 28 / 0.055) 1px, transparent 1px),
		linear-gradient(90deg, rgb(7 19 28 / 0.045) 1px, transparent 1px);
	background-size: 80px 80px;
	mask-image: linear-gradient(180deg, rgb(0 0 0 / 0.15), rgb(0 0 0 / 0.32) 40%, transparent 82%);
	pointer-events: none;
}

.apcs-conference-hero__model {
	position: absolute;
	z-index: 0;
	opacity: 0.98;
	pointer-events: auto;
	cursor: grab;
	touch-action: none;
	mix-blend-mode: normal;
	filter: drop-shadow(0 24px 50px rgb(7 19 28 / 0.24));
	transform: translate3d(0, 0, 0);
	animation: apcsModelFloat 15s ease-in-out infinite alternate;
}

.apcs-conference-hero__model--main {
	inset-block-start: auto;
	inset-block-end: clamp(-170px, -13vh, -118px);
	inset-inline-end: clamp(-210px, -12vw, -142px);
	width: min(74vw, 1120px);
	height: min(92vh, 960px);
	min-width: 820px;
	min-height: 760px;
	transform-origin: right bottom;
	animation-name: apcsModelFloatAnchored;
}

.apcs-conference-hero__model.is-dragging {
	cursor: grabbing;
}

.apcs-conference-hero__model::before,
.apcs-conference-hero__model::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
}

.apcs-conference-hero__model::before {
	inset: 9% 4% 5% 0;
	background:
		radial-gradient(circle at 52% 45%, rgb(255 255 255 / 0.34), rgb(255 255 255 / 0) 58%),
		radial-gradient(circle at 58% 40%, rgb(103 169 185 / 0.11), rgb(103 169 185 / 0) 66%);
	filter: blur(0.5px);
}

.apcs-conference-hero__model::after {
	inset: 72% 18% 8% 22%;
	background: radial-gradient(ellipse at center, rgb(7 19 28 / 0.16), rgb(7 19 28 / 0) 70%);
	filter: blur(18px);
	transform: rotate(-9deg);
}

.apcs-conference-hero__model-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
}

.apcs-conference-hero__model-canvas {
	z-index: 1;
	opacity: 1;
}

.apcs-conference-hero__model[data-apcs-hero-model-failed="true"],
.apcs-conference-hero__model[data-apcs-hero-model-loading="true"] .apcs-conference-hero__model-canvas,
.apcs-conference-hero__model-fallback {
	display: none;
}

@keyframes apcsModelFloat {
	0% {
		transform: translate3d(0, 10px, 0) rotate(-2.2deg) scale(0.98);
	}
	100% {
		transform: translate3d(-18px, -12px, 0) rotate(1.8deg) scale(1);
	}
}

@keyframes apcsModelFloatAnchored {
	0% {
		transform: translate3d(0, 0, 0) rotate(-1.1deg) scale(0.99);
	}
	100% {
		transform: translate3d(0, 0, 0) rotate(1.2deg) scale(1);
	}
}

@media (prefers-reduced-motion: reduce) {
	.apcs-conference-hero__model {
		animation: none;
	}
}

.apcs-conference-hero__inner {
	position: relative;
	z-index: 1;
	box-sizing: border-box;
	height: 100%;
	min-height: 100%;
	width: min(100%, 1920px);
	margin-inline: auto;
	padding: clamp(92px, 9vw, 124px) clamp(24px, 2.8vw, 48px) clamp(30px, 3.4vw, 52px);
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	align-items: end;
	gap: clamp(24px, 4vw, 60px);
}

.apcs-conference-hero__copy {
	position: relative;
	z-index: 2;
	align-self: end;
	width: 100%;
	max-width: none;
}

.apcs-conference-hero__eyebrow,
.apcs-conference-hero__meta,
.apcs-conference-hero__title {
	position: relative;
	z-index: 1;
	margin: 0;
}

.apcs-conference-hero__eyebrow {
	font-family: "Space Grotesk", "Manrope", sans-serif;
	font-size: clamp(24px, 2.15vw, 34px);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.035em;
	text-transform: uppercase;
}

.apcs-conference-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px 16px;
	padding-block-start: clamp(12px, 1.2vw, 18px);
	font-family: "Manrope", sans-serif;
	font-size: clamp(24px, 1.9vw, 34px);
	font-weight: 750;
	line-height: 1.35;
	letter-spacing: -0.02em;
	color: #26313a;
	opacity: 1;
}

.apcs-conference-hero__meta p {
	margin: 0;
}

.apcs-conference-hero__meta span {
	width: 4px;
	height: 4px;
	border-radius: 999px;
	background: currentColor;
	opacity: 1;
}

.apcs-conference-hero__title {
	max-width: none;
	padding-block-start: clamp(22px, 3.2vw, 42px);
	font-family: "Space Grotesk", "Manrope", sans-serif;
	font-size: clamp(48px, 5.65vw, 88px);
	font-weight: 900;
	line-height: 0.96;
	letter-spacing: -0.065em;
	text-wrap: balance;
	color: var(--apcs-conference-hero-title);
	text-shadow: 0 2px 18px rgb(255 255 255 / 0.34);
}

.apcs-conference-hero__actions {
	position: relative;
	z-index: 1;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: clamp(10px, 1vw, 14px);
	margin-block-start: clamp(20px, 2.2vw, 30px);
}

.apcs-conference-hero__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: clamp(46px, 4.2vw, 58px);
	padding: 0 clamp(18px, 1.8vw, 26px);
	border: 1px solid rgb(47 58 67 / 0.18);
	border-radius: 0;
	font-family: "Space Grotesk", "Manrope", sans-serif;
	font-size: clamp(15px, 1.02vw, 18px);
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.01em;
	text-decoration: none;
	transition: background-color 0.22s ease, border-color 0.22s ease, color 0.22s ease, transform 0.2s ease;
}

.apcs-conference-hero__action--primary {
	background: #2f3a43;
	border-color: #2f3a43;
	color: #fff;
	box-shadow: 0 16px 36px rgb(47 58 67 / 0.18);
}

.apcs-conference-hero__action--secondary,
.apcs-conference-hero__action--ghost {
	background: rgb(255 255 255 / 0.44);
	backdrop-filter: blur(16px);
	color: var(--apcs-conference-hero-title);
}

.apcs-conference-hero__action--ghost {
	padding-inline-end: clamp(14px, 1.4vw, 20px);
}

.apcs-conference-hero__action:hover,
.apcs-conference-hero__action:focus-visible {
	transform: translateY(-2px);
	outline: 2px solid rgb(47 58 67 / 0.24);
	outline-offset: 4px;
}

.apcs-conference-hero__action--primary:hover,
.apcs-conference-hero__action--primary:focus-visible {
	background: #1f2931;
	border-color: #1f2931;
}

.apcs-conference-hero__action--secondary:hover,
.apcs-conference-hero__action--secondary:focus-visible,
.apcs-conference-hero__action--ghost:hover,
.apcs-conference-hero__action--ghost:focus-visible {
	background: rgb(255 255 255 / 0.72);
	border-color: rgb(47 58 67 / 0.34);
}

.apcs-conference-hero__action .apcs-material-icon {
	font-size: 20px;
	line-height: 1;
}

.editor-styles-wrapper .apcs-conference-hero {
	min-height: 680px;
}

@media (max-width: 900px) {
	.apcs-conference-hero,
	.wp-block-apcs-platform-conference-hero.apcs-conference-hero {
		height: 90vh;
		height: 90svh;
		min-height: 620px;
	}

	.apcs-conference-hero__model--main {
		inset-block-start: auto;
		inset-block-end: -118px;
		inset-inline-end: -118px;
		width: 86vw;
		height: 86vh;
		min-width: 620px;
		min-height: 660px;
		opacity: 0.58;
	}

	.apcs-conference-hero__inner {
		grid-template-columns: minmax(0, 1fr);
		padding-block-start: 112px;
	}

	.apcs-conference-hero__copy {
		max-width: 100%;
	}

	.apcs-conference-hero__title {
		font-size: clamp(38px, 9.4vw, 58px);
	}

	.apcs-conference-hero__actions {
		gap: 10px;
		margin-block-start: 18px;
	}

	.apcs-conference-hero__action {
		min-height: 44px;
		padding-inline: 16px;
		font-size: 15px;
	}
}

@media (max-width: 560px) {
	.apcs-conference-hero,
	.wp-block-apcs-platform-conference-hero.apcs-conference-hero {
		min-height: 580px;
	}

	.apcs-conference-hero__model--main {
		inset-block-start: auto;
		inset-block-end: -76px;
		inset-inline-end: -72px;
		width: 108vw;
		height: 72vh;
		min-width: 0;
		min-height: 500px;
		opacity: 0.32;
	}

	.apcs-conference-hero__inner {
		padding-inline: 20px;
		padding-block-end: 32px;
	}

	.apcs-conference-hero__eyebrow {
		font-size: clamp(22px, 7vw, 30px);
	}

	.apcs-conference-hero__meta {
		display: grid;
		gap: 6px;
		font-size: clamp(17px, 4.6vw, 21px);
	}

	.apcs-conference-hero__actions {
		align-items: stretch;
	}

	.apcs-conference-hero__meta span {
		display: none;
	}
}
