/* ============================================================
   EXPERIENCE / JOURNEY SECTION — journey.css
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@700;800&family=Inter:wght@400;500;600;700&display=swap");

:root {
	--journey-bg: var(--hero-bg);
	--journey-card: color-mix(in srgb, var(--hero-bg) 87%, #ffffff 13%);
	--journey-text: var(--hero-navy);
	--journey-muted: color-mix(in srgb, var(--hero-navy) 62%, #ffffff 38%);
	--journey-accent: var(--hero-accent);
	--journey-line: color-mix(in srgb, var(--hero-navy) 22%, transparent);
	--journey-shadow: rgba(0, 22, 102, 0.12);
}

#journey {
	position: relative;
	padding: 100px 32px 110px;
	background: var(--journey-bg);
	overflow: hidden;
}

.journey-container {
	width: min(100%, 1040px);
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
	gap: clamp(40px, 6vw, 92px);
	align-items: start;
}

.journey-column {
	min-width: 0;
}

.journey-photo-card {
	aspect-ratio: 4 / 3;
	border-radius: 14px;
	overflow: hidden;
	background: #ffffff;
	border: 1px solid color-mix(in srgb, var(--hero-navy) 12%, transparent);
	box-shadow: 0 20px 40px -28px var(--journey-shadow);
	margin-bottom: 28px;
}

.journey-photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 24%;
	filter: grayscale(1);
}

.journey-subtitle,
.journey-title {
	font-family: "Big Shoulders Display", sans-serif;
	letter-spacing: 0.02em;
	line-height: 1;
	color: var(--journey-text);
	margin: 0;
}

.journey-subtitle {
	font-size: clamp(34px, 4.2vw, 50px);
	margin-bottom: 18px;
}

.journey-title {
	font-size: clamp(40px, 5vw, 62px);
	margin-bottom: 10px;
}

.journey-company {
	font-family: "Inter", sans-serif;
	font-size: clamp(15px, 1.2vw, 18px);
	line-height: 1.5;
	color: var(--journey-muted);
	margin-bottom: 24px;
}

.journey-company strong {
	color: var(--journey-text);
	font-weight: 700;
}

.journey-edu-item {
	padding: 16px 0 0;
	border-top: 1px dashed var(--journey-line);
}

.journey-edu-item + .journey-edu-item {
	margin-top: 18px;
}

.journey-year {
	font-family: "Inter", sans-serif;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--journey-accent);
	margin: 0 0 6px;
}

.journey-item-title,
.journey-role-title {
	font-family: "Inter", sans-serif;
	font-size: clamp(20px, 2.2vw, 30px);
	font-weight: 700;
	line-height: 1.25;
	color: var(--journey-text);
	margin: 0 0 6px;
}

.journey-item-meta {
	font-family: "Inter", sans-serif;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.5;
	color: var(--journey-muted);
	margin: 0 0 6px;
}

.journey-role-copy {
	font-family: "Inter", sans-serif;
	font-size: clamp(14px, 1.1vw, 17px);
	font-weight: 400;
	line-height: 1.7;
	color: var(--journey-muted);
	margin: 0;
	max-width: 45ch;
}

.journey-timeline {
	position: relative;
	display: grid;
	gap: 34px;
	padding-left: 22px;
}

.journey-timeline::before {
	content: "";
	position: absolute;
	left: 0;
	top: 8px;
	bottom: 8px;
	width: 1px;
	background: linear-gradient(
		180deg,
		transparent 0%,
		var(--journey-line) 10%,
		var(--journey-line) 90%,
		transparent 100%
	);
}

.journey-role {
	position: relative;
	padding-left: 6px;
}

.journey-role::before {
	content: "";
	position: absolute;
	left: -26px;
	top: 8px;
	width: 9px;
	height: 9px;
	border-radius: 999px;
	background: var(--journey-text);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--journey-bg) 72%, #ffffff 28%);
}

.journey-role:hover::before {
	background: var(--journey-accent);
}

.journey-ambient-dot {
	position: absolute;
	right: max(8px, -2vw);
	top: 50%;
	translate: 0 -50%;
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: #ffffff;
	box-shadow:
		0 0 0 1px color-mix(in srgb, var(--hero-navy) 15%, transparent),
		0 8px 20px -10px rgba(255, 255, 255, 0.9);
}

@media (max-width: 980px) {
	#journey {
		padding: 64px 24px 92px;
	}

	.journey-container {
		grid-template-columns: 1fr;
		gap: 54px;
	}

	.journey-column--right {
		position: relative;
	}

	.journey-ambient-dot {
		display: none;
	}
}

@media (max-width: 640px) {
	#journey {
		padding: 52px 18px 76px;
	}

	.journey-photo-card {
		width: 100%;
	}

	.journey-timeline {
		padding-left: 18px;
		gap: 28px;
	}

	.journey-role::before {
		left: -22px;
	}
}
