:root {
	--ink: #102235;
	--muted: #486177;
	--surface: #ffffff;
	--soft-surface: #f4fbff;
	--brand: #1190f2;
	--brand-2: #00b8c8;
	--accent: #ff7d5a;
	--line: #d9e9f7;
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	font-family: 'Manrope', sans-serif;
	color: var(--ink);
	background:
		radial-gradient(circle at 92% 4%, rgba(17, 144, 242, 0.14), transparent 33%),
		radial-gradient(circle at 6% 28%, rgba(0, 184, 200, 0.11), transparent 32%),
		linear-gradient(180deg, #eef9ff 0%, #fcfeff 40%, #f9fdff 100%);
}

a {
	text-decoration: none;
	color: inherit;
}

main {
	overflow: hidden;
}

.container {
	width: min(1160px, calc(100% - 2.5rem));
	margin: 0 auto;
}

.section {
	padding: 5.25rem 0;
}

.section-kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.45rem 0.8rem;
	border-radius: 999px;
	border: 1px solid var(--line);
	background: rgba(255, 255, 255, 0.78);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #266086;
}

.hero {
	position: relative;
	min-height: 95vh;
	display: flex;
	align-items: center;
	padding: 5rem 0 4rem;
}

.hero-blob {
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
	filter: blur(14px);
	opacity: 0.75;
}

.hero-blob.blob-a {
	height: 18rem;
	width: 18rem;
	right: -3rem;
	top: 6%;
	background: radial-gradient(circle, rgba(17, 144, 242, 0.3) 0%, rgba(17, 144, 242, 0) 72%);
}

.hero-blob.blob-b {
	height: 17rem;
	width: 17rem;
	left: -3rem;
	bottom: 3%;
	background: radial-gradient(circle, rgba(255, 125, 90, 0.2) 0%, rgba(255, 125, 90, 0) 72%);
}

.hero-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 2.3rem;
	align-items: center;
}

.hero-title {
	font-family: 'Space Grotesk', sans-serif;
	font-size: clamp(2.4rem, 6.6vw, 5rem);
	line-height: 0.98;
	letter-spacing: -0.03em;
	margin-top: 1.15rem;
	margin-bottom: 1rem;
	color: #0c1f31;
}

.hero-title .gradient-word {
	background: linear-gradient(100deg, #0f8ce8 0%, #00b8c8 52%, #ff7d5a 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.hero-lead {
	max-width: 41rem;
	font-size: clamp(1.02rem, 2vw, 1.28rem);
	line-height: 1.6;
	color: var(--muted);
}

.hero-actions {
	margin-top: 2rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.9rem;
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	padding: 0.86rem 1.25rem;
	font-size: 0.93rem;
	font-weight: 800;
	letter-spacing: 0.01em;
	border-radius: 0.9rem;
	transition:
		transform 180ms ease,
		box-shadow 180ms ease,
		background 180ms ease;
}

.btn:hover {
	transform: translateY(-1px);
}

.btn-primary {
	color: #fff;
	background: linear-gradient(100deg, #1190f2, #00b8c8);
	box-shadow: 0 20px 38px -23px rgba(17, 144, 242, 0.95);
}

.btn-secondary {
	border: 1px solid var(--line);
	background: rgba(255, 255, 255, 0.88);
	color: #164162;
}

.hero-side-card {
	position: relative;
	background: rgba(255, 255, 255, 0.78);
	backdrop-filter: blur(9px);
	border: 1px solid var(--line);
	border-radius: 1.35rem;
	padding: 1.35rem;
	box-shadow: 0 30px 58px -40px rgba(16, 86, 133, 0.7);
}

.hero-side-top {
	display: flex;
	align-items: center;
	gap: 0.95rem;
	margin-bottom: 1.25rem;
}

.hero-side-eyebrow {
	margin: 0;
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: #3f7495;
}

.hero-side-title {
	margin: 0.18rem 0 0;
	font-size: 1rem;
	font-weight: 800;
	font-family: 'Space Grotesk', sans-serif;
	color: #11344e;
}

.logo-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 3.05rem;
	width: 3.05rem;
	border-radius: 0.84rem;
	background: linear-gradient(135deg, #edf8ff 0%, #ddf5ff 100%);
	border: 1px solid #cbe7fa;
}

.hero-side-list {
	display: grid;
	gap: 0.6rem;
}

.hero-side-list li {
	display: flex;
	align-items: center;
	gap: 0.62rem;
	font-size: 0.92rem;
	color: #2d5b7a;
}

.dot {
	height: 0.56rem;
	width: 0.56rem;
	border-radius: 999px;
	background: linear-gradient(120deg, #1190f2, #00b8c8);
	flex-shrink: 0;
}

.grid-2 {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}

.download-card {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: 1rem;
	padding: 1.25rem;
	box-shadow: 0 18px 34px -32px rgba(21, 95, 143, 0.55);
	transition:
		border-color 180ms ease,
		transform 180ms ease,
		box-shadow 180ms ease;
}

.download-card:hover {
	transform: translateY(-2px);
	border-color: #9fcef2;
	box-shadow: 0 26px 42px -30px rgba(21, 95, 143, 0.35);
}

.download-card h3 {
	margin: 0;
	font-size: 1.06rem;
	font-family: 'Space Grotesk', sans-serif;
}

.download-card p {
	margin: 0.45rem 0 0.9rem;
	font-size: 0.93rem;
	color: var(--muted);
}

.download-link {
	display: inline-flex;
	align-items: center;
	font-weight: 800;
	font-size: 0.86rem;
	color: #115986;
}

.showcase-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.2rem;
	margin-top: 1.25rem;
}

.shot {
	position: relative;
	min-height: 19rem;
	border-radius: 1.05rem;
	border: 1px solid #d4e7f7;
	background:
		linear-gradient(160deg, rgba(255, 255, 255, 0.88) 0%, rgba(237, 249, 255, 0.85) 100%),
		repeating-linear-gradient(
			45deg,
			rgba(17, 144, 242, 0.04) 0 10px,
			rgba(255, 255, 255, 0.2) 10px 20px
		);
	padding: 1.1rem;
	box-shadow: 0 16px 34px -30px rgba(16, 88, 136, 0.65);
}

.shot .label {
	display: inline-flex;
	padding: 0.3rem 0.6rem;
	border-radius: 999px;
	border: 1px solid #c6e2f7;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #2a5f81;
	background: rgba(255, 255, 255, 0.82);
}

.shot h3 {
	margin: 0.9rem 0 0.5rem;
	font-size: 1.08rem;
	font-family: 'Space Grotesk', sans-serif;
}

.shot p {
	margin: 0 0 1rem;
	font-size: 0.91rem;
	color: var(--muted);
	max-width: 100%; /* Ensure paragraph spans full width */
}

.shot-media-wrap {
	position: relative; /* Adjust positioning */
	margin-top: 1rem; /* Add spacing between text and image */
	border-radius: 0.85rem;
	border: 1px solid #cde4f5;
	overflow: hidden;
	background: #ffffff;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.5);
}

.shot-media {
	width: 100%;
	height: 15rem;
	object-fit: cover;
	object-position: top center;
}

footer {
	padding: 2.8rem 0 3rem;
	border-top: 1px solid var(--line);
	background: rgba(255, 255, 255, 0.84);
}

.footer-wrap {
	display: flex;
	gap: 1rem;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

.footer-links {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.footer-link {
	font-size: 0.86rem;
	font-weight: 800;
	padding: 0.64rem 0.86rem;
	border-radius: 0.75rem;
	border: 1px solid #d1e6f7;
	background: #fff;
	color: #24597b;
}

.reveal {
	opacity: 0;
	transform: translateY(16px);
}

@media (max-width: 980px) {
	.hero {
		min-height: auto;
		padding-top: 3.9rem;
	}

	.hero-grid,
	.showcase-grid {
		grid-template-columns: 1fr;
	}

	.grid-2 {
		grid-template-columns: 1fr;
	}

	.section {
		padding: 4rem 0;
	}
}
