/* Case Study: Hero — Sora loaded via agp-csi-font-sora */
.agp-csi .agp-csi-hero {
	min-height: 100vh;
	background: var(--csi-navy);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 100px 40px 80px;
	position: relative;
	overflow: hidden;
}
.agp-csi .agp-csi-hero-bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(ellipse 70% 50% at 50% 30%, rgba(26, 161, 140, 0.12) 0%, transparent 70%);
}
.agp-csi .agp-csi-hero-grid {
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.04;
	background-image: linear-gradient(var(--csi-teal) 1px, transparent 1px),
		linear-gradient(90deg, var(--csi-teal) 1px, transparent 1px);
	background-size: 60px 60px;
}
.agp-csi .agp-csi-hero-content {
	max-width: 860px;
	text-align: center;
	position: relative;
	z-index: 1;
}
.agp-csi .agp-csi-case-label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--csi-teal);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 36px;
}
.agp-csi .agp-csi-case-label::before,
.agp-csi .agp-csi-case-label::after {
	content: "";
	display: block;
	width: 28px;
	height: 1px;
	background: var(--csi-teal);
	opacity: 0.5;
}
.agp-csi .agp-csi-hero h1 {
	font-size: clamp(32px, 5.5vw, 64px) !important;
	font-weight: 800 !important;
	color: #fff !important;
	line-height: 1.1 !important;
	margin: 0 0 28px;
	letter-spacing: -0.02em;
}
.agp-csi .agp-csi-hero h1 em {
	color: var(--csi-teal);
	font-style: normal;
}
.agp-csi .agp-csi-hero-sub {
	color: rgba(255, 255, 255, 0.55);
	font-size: 17px;
	line-height: 1.75;
	max-width: 580px;
	margin: 0 auto 52px;
}
.agp-csi .agp-csi-hero-org {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 100px;
	padding: 10px 20px 10px 10px;
}
.agp-csi .agp-csi-org-badge {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--csi-teal);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 800;
	color: #fff;
}
.agp-csi .agp-csi-org-name {
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	text-align: left;
}
.agp-csi .agp-csi-org-tagline {
	color: rgba(255, 255, 255, 0.45);
	font-size: 11px;
	text-align: left;
}
.agp-csi .agp-csi-hero-line {
	display: block;
	overflow: hidden;
}
.agp-csi .agp-csi-hero-line-inner {
	display: block;
}
.agp-csi .agp-csi-scroll-hint {
	position: absolute;
	bottom: 36px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	color: rgba(255, 255, 255, 0.3);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	z-index: 1;
}
.agp-csi .agp-csi-scroll-arrow {
	width: 28px;
	height: 28px;
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}
@media (max-width: 768px) {
	.agp-csi .agp-csi-hero {
		padding-left: 20px;
		padding-right: 20px;
	}
}