:root {
	--bg: #07111f;
	--bg-elevated: rgba(13, 23, 38, 0.9);
	--bg-panel: rgba(15, 24, 41, 0.78);
	--bg-panel-strong: rgba(18, 28, 46, 0.96);
	--line: rgba(172, 191, 227, 0.15);
	--line-strong: rgba(194, 164, 255, 0.28);
	--text: #f4f7ff;
	--text-soft: #e0e3eb;
	--text-dim: #ffffff;
	--accent: #b873f8;
	--accent-2: #facafc;
	--accent-3: #c75ef0;
	--shadow: 0 28px 80px rgba(2, 6, 15, 0.5);
	--radius-xl: 34px;
	--radius-lg: 24px;
	--radius-md: 18px;
	--max-width: 1180px;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	overflow-x: clip;
}

body {
	margin: 0;
	min-height: 100vh;
	overflow-x: clip;
	color: var(--text);
	background:
		radial-gradient(circle at 12% 10%, rgba(137, 87, 255, 0.22), transparent 50%),
		radial-gradient(circle at 88% 14%, rgba(255, 85, 198, 0.16), transparent 40%),
		radial-gradient(circle at 70% 72%, rgba(196, 132, 255, 0.14), transparent 60%),
		linear-gradient(180deg, #08111f 0%, #091523 46%, #0a1324 100%);
	font-family: Aptos, "Segoe UI Variable", "Segoe UI", sans-serif;
	line-height: 1.6;
}

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

img,
svg {
	display: block;
	max-width: 100%;
}

.site-shell {
	width: min(calc(100% - 2rem), var(--max-width));
	margin: 0 auto;
}

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	transform: none;
	width: 100%;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 0;
	padding: 1rem 1.2rem;
	border: 1px solid var(--line);
	border-radius: 0 0 28px 28px;
	background: rgba(8, 16, 30, 0.78);
	backdrop-filter: blur(22px);
	box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
}

.brand-mark {
	font-weight: 700;
	font-size: 1rem;
	letter-spacing: -0.02em;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	flex-wrap: wrap;
}

.site-nav a {
	padding: 0.7rem 1rem;
	border-radius: 999px;
	color: var(--text-soft);
	transition: background-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.site-nav a.is-active {
	color: var(--text);
	background: rgba(130, 168, 255, 0.12);
	transform: translateY(-1px);
}

main {
	padding: 0.75rem 0 4.2rem;
}

.hero,
.page-hero {
	position: relative;
	padding: 3.2rem;
	margin-top: 0;
	border: 1px solid var(--line);
	border-radius: var(--radius-xl);
	background:
		linear-gradient(180deg, rgba(12, 21, 38, 0.9), rgba(9, 18, 31, 0.96)),
		var(--bg-panel);
	box-shadow: var(--shadow);
	overflow: hidden;
}

.hero {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: min(84vh, 860px);
	text-align: center;
}

.hero::before,
.page-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 0% 0%, rgba(130, 168, 255, 0.14), transparent 34%),
		radial-gradient(circle at 100% 10%, rgba(197, 135, 255, 0.11), transparent 26%);
	pointer-events: none;
}

.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(6, 11, 20, 0.36), rgba(5, 10, 18, 0.82)),
		var(--hero-bg-image, url("assets/hero_gifs/A SHORT SURVEY 2.gif")) center / cover no-repeat;
	opacity: 0.42;
	transition: background-image 700ms ease-in-out;
	pointer-events: none;
}

.hero-reference {
	--hero-bg-image: url("assets/hero_gifs/A SHORT SURVEY 2.gif");
	width: auto;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	min-height: min(92vh, 980px);
	border-left: 0;
	border-right: 0;
	border-radius: 0;
}

.hero-copy,
.page-hero {
	position: relative;
	z-index: 1;
}

.hero-copy-compact {
	max-width: 760px;
	width: 100%;
	margin: 0 auto;
}

.eyebrow,
.section-kicker {
	margin: 5% 0 0.85rem;
	color: var(--accent);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

h1,
h2,
h3 {
	margin: 0;
	line-height: 1.06;
	letter-spacing: 0.00em;
}

h1 {
	font-size: clamp(3rem, 7vw, 5.4rem);
}

.hero-reference h1 {
	white-space: nowrap;
	font-size: clamp(1.45rem, 5.2vw, 5.4rem);
}

h2 {
	font-size: clamp(2.15rem, 4.8vw, 3.2rem);
}

h3 {
	font-size: 1.5rem;
}

p {
	margin: 0;
	color: var(--text-soft);
}

.typed-line,
.project-page-subtitle {
	margin-top: 1.1rem;
	color: var(--text);
	font-size: clamp(1.28rem, 2.4vw, 1.85rem);
	font-weight: 500;
}

.typed-title {
	color: var(--accent-3);
}

.caret {
	display: inline-block;
	width: 0.09em;
	height: 1.05em;
	margin-left: 0.12rem;
	background: currentColor;
	vertical-align: -0.08em;
	animation: blink 1s steps(1) infinite;
}

@keyframes blink {
	50% {
		opacity: 0;
	}
}

.skills-band,
.meta-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.skills-band span,
.meta-row span,
.blank-state-tag {
	display: inline-flex;
	align-items: center;
	min-height: 2.2rem;
	padding: 0.42rem 0.85rem;
	border: 1px solid rgba(130, 168, 255, 0.14);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.03);
	color: var(--text);
	font-size: 0.92rem;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.15rem;
	padding: 0.85rem 1.25rem;
	border-radius: 999px;
	border: 1px solid transparent;
	font-weight: 700;
	transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.button:hover,
.button:focus-visible {
	transform: translateY(-2px);
}

.button-primary {
	color: #161a2c;
	background: linear-gradient(135deg, var(--accent), var(--accent-2));
	/*background-color: #a3408a;*/
	box-shadow: 0 0px 13px rgba(224, 71, 255, 0.5);
}

.button-secondary {
	border-color: var(--line);
	background: rgba(255, 255, 255, 0.04);
}

.section {
	padding-top: 5.2rem;
}

.section-heading {
	max-width: 44rem;
	margin-bottom: 1.9rem;
}

.section-heading p:last-child {
	margin-top: 0.95rem;
}

.page-hero h1+p {
	margin-top: 1rem;
}

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

.project-card,
.blank-state-card,
.resume-frame,
.case-panel {
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	background:
		linear-gradient(180deg, rgba(14, 23, 40, 0.9), rgba(11, 19, 34, 0.96)),
		var(--bg-panel);
	box-shadow: var(--shadow);
}

.project-card {
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
	overflow: hidden;
	transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.project-card:hover,
.project-card:focus-visible {
	transform: translateY(-4px);
	border-color: var(--line-strong);
	box-shadow: 0 32px 80px rgba(2, 6, 15, 0.62);
}

.project-card-image {
	width: 100%;
	aspect-ratio: 63 / 50;
	object-fit: cover;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.project-card>*:not(.project-card-image) {
	margin-left: 1.5rem;
	margin-right: 1.5rem;
}

.project-card>.project-link {
	margin-bottom: 1.5rem;
}

.project-card-featured {
	background:
		linear-gradient(180deg, rgba(17, 29, 52, 0.96), rgba(11, 19, 34, 0.98)),
		var(--bg-panel);
}

.project-accent {
	width: calc(100% - 3rem);
	height: 7px;
	margin-top: 1.35rem;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--accent), var(--accent-2), var(--accent-3));
}

.project-type,
.project-stack,
.project-link {
	font-size: 0.92rem;
	font-weight: 700;
}

.project-card p,
.project-card li {
	line-height: 1.45;
}

.project-points li+li {
	margin-top: 1rem;
}

.project-type,
.project-stack {
	color: var(--accent);
}

.project-points,
.case-panel ul {
	margin: 0;
	padding-left: 1.2rem;
	color: var(--text-soft);
}

.project-link {
	margin-top: auto;
	color: var(--accent-3);
}

.about-section {
	padding-bottom: 2.6rem;
}

.about-layout {
	display: grid;
	grid-template-columns: minmax(260px, 0.7fr) minmax(0, 1.3fr);
	gap: 1.8rem;
	align-items: center;
}

.blank-state-card,
.resume-frame,
.case-panel {
	padding: 1.4rem;
}

.portrait-wrap {
	display: flex;
	align-items: flex-start;
	justify-content: center;
}

.portrait-image {
	width: 100%;
	max-width: 360px;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	border-radius: 0;
}

.about-copy {
	display: grid;
	gap: 1rem;
	align-content: center;
}

.page-main {
	min-height: calc(100vh - 14rem);
}

.blank-state,
.resume-frame-section,
.case-study {
	padding-top: 1.4rem;
}

.blank-state-card {
	min-height: 320px;
	display: grid;
	place-content: center;
	gap: 1rem;
	text-align: center;
}

.video-embed-frame {
	display: grid;
	gap: 1rem;
}

.video-embed-frame iframe {
	width: min(100%, 980px);
	margin: 0 auto;
	aspect-ratio: 16 / 9;
	padding: 0.8rem;
}

.resume-frame-section {
	display: grid;
	gap: 1rem;
}

.resume-frame {
	width: min(100%, 980px);
	margin: 0 auto;
	aspect-ratio: 8.5 / 11.25;
	padding: 0.8rem;
}

.resume-frame iframe {
	width: 100%;
	height: 100%;
	border: 0;
	border-radius: 14px;
	background: #ffffff;
}

.meta-row {
	margin-top: 1.4rem;
}

.project-link-row {
	margin-top: 1.35rem;
}

.project-link-button {
	gap: 0.6rem;
	padding: 0.4rem 0.6rem;
}

.project-link-button img {
	width: 1.7rem;
	height: 1.7rem;
	object-fit: cover;
}

.resume-link-button {
	padding: 0 20%;

	justify-self: center;
	justify-content: center;
}

.case-study {
	width: min(100%, 940px);
	margin: 0 auto;
	display: block;
}

.case-panel h2 {
	margin-bottom: 0.8rem;
	font-size: clamp(1.7rem, 3vw, 2.2rem);
}

.case-panel {
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
}

.case-panel+.case-panel {
	margin-top: 2.4rem;
}

.case-panel p+p {
	margin-top: 1rem;
}

.site-footer {
	display: grid;
	place-items: center;
	gap: 0.75rem;
	padding: 2rem 0 3rem;
	text-align: center;
}

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

.footer-links a {
	display: grid;
	place-items: center;
	width: 3rem;
	height: 3rem;
	border: 1px solid var(--line);
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.04);
	transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.footer-links a:hover,
.footer-links a:focus-visible {
	transform: translateY(-2px);
	border-color: var(--line-strong);
	background: rgba(255, 255, 255, 0.08);
}

.footer-links img,
.footer-links svg {
	width: 1.1rem;
	height: 1.1rem;
	object-fit: contain;
}

.footer-links img {
	filter: brightness(0) invert(1);
}

.footer-links svg {
	fill: currentColor;
}

.footer-email,
.footer-copy {
	font-size: 0.94rem;
	color: var(--text-dim);
}

@media (max-width: 980px) {

	.project-grid,
	.about-layout,
	.case-study {
		grid-template-columns: 1fr;
	}

	.about-layout {
		align-items: start;
	}

	.hero,
	.page-hero {
		padding: 2.4rem;
	}

	.resume-frame {
		width: 100%;
	}
}

@media (max-width: 720px) {
	.site-shell {
		width: min(calc(100% - 1rem), var(--max-width));
	}

	.site-header {
		position: fixed;
		left: 0;
		transform: none;
		width: 100%;
		border-radius: 0 0 28px 28px;
		padding: 0.95rem;
	}

	.site-nav {
		width: 100%;
		justify-content: flex-start;
	}

	main {
		padding: 0.5rem 0 3rem;
	}

	.hero,
	.page-hero {
		padding: 5.75rem 1.1rem 1.25rem;
		margin-top: 0;
		border-radius: 26px;
	}

	.hero-reference {
		min-height: 68vh;
	}

	.hero-reference h1 {
		font-size: clamp(1.8rem, 7.2vw, 2.8rem);
	}

	.section {
		padding-top: 4rem;
	}

	.meta-row,
	.skills-band {
		gap: 0.6rem;
	}

	.project-card>*:not(.project-card-image) {
		margin-left: 1rem;
		margin-right: 1rem;
	}

	.project-accent {
		width: calc(100% - 2rem);
		margin-top: 1rem;
	}

	.project-card>.project-link {
		margin-bottom: 1rem;
	}

	.resume-frame {
		aspect-ratio: auto;
		min-height: 78vh;
	}

	.case-study {
		width: 100%;
	}

	.case-panel+.case-panel {
		margin-top: 2rem;
	}

	.project-page .site-shell {
		width: min(calc(100% - 0.35rem), var(--max-width));
	}

	.project-page .page-hero {
		padding: 5.75rem 0.8rem 1.1rem;
	}

	.project-page .case-study {
		width: min(100%, calc(100vw - 1.2rem));
	}

	.project-page .case-panel {
		padding-left: 0.85rem;
		padding-right: 0.85rem;
	}
}