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

body, input, select, textarea {
	font-family: "Inter", Helvetica, sans-serif;
	line-height: 1.75;
}

body {
	background: #0f1720;
}

p {
	text-align: left;
}

a {
	border-bottom-color: rgba(13, 148, 136, 0.35);
}

a:hover {
	color: #0d9488 !important;
}

h1, h2, h3, h4, h5, h6 {
	font-family: "Inter", Helvetica, sans-serif;
	line-height: 1.15;
}

#wrapper > .bg {
	background-color: #0f1720;
	background-image: linear-gradient(0deg, rgba(15, 23, 32, 0.84), rgba(15, 23, 32, 0.62)), url("../../images/dark_blue_background.jpg");
	background-position: center, center;
	background-size: auto, cover;
}

#intro {
	justify-content: center;
	min-height: 92vh;
	padding: 6rem 2rem 4rem;
}

#intro h1 {
	font-size: 4.5rem;
	margin-bottom: 1rem;
	max-width: none;
	text-align: center;
}

#intro h1 span {
	display: block;
}

#intro .hero-copy {
	font-size: 1.2rem;
	font-style: normal;
	line-height: 1.7;
	max-width: 46rem;
	margin: 0 auto 2rem;
}

.eyebrow {
	color: #7dd3fc;
	font-family: "Inter", Helvetica, sans-serif;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.16em;
	line-height: 1.4;
	margin: 0 0 0.8rem;
	text-transform: uppercase;
}

.eyebrow.dark {
	color: #0f766e;
	text-align: center;
}

.hero-actions {
	justify-content: center;
	margin-top: 1rem;
}

#intro .button.primary {
	background: #0f766e;
	box-shadow: none;
	color: #ffffff !important;
}

#intro .button.primary:hover {
	background: #0d9488;
	box-shadow: none;
	color: #ffffff !important;
}

#header .logo {
	border-radius: 8px;
}

#nav {
	background: rgba(15, 23, 32, 0.88);
	backdrop-filter: blur(12px);
}

#nav .links li a {
	color: #f8fafc;
}

#nav .icons a {
	color: #f8fafc;
}

#main {
	background: #f8fafc;
	border-radius: 8px 8px 0 0;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.22);
	overflow: hidden;
}

#main > * {
	border-top-color: #dbe3ea;
}

#main > .profile-section {
	padding: 4rem 6rem 3rem;
}

header.major.compact {
	margin: 0 auto 2rem;
	max-width: 50rem;
	text-align: center;
}

header.major.compact h2 {
	font-size: 2.45rem;
	margin-bottom: 1rem;
}

.lead {
	color: #334155;
	font-size: 1.05rem;
	line-height: 1.8;
	margin-left: auto;
	margin-right: auto;
	max-width: 48rem;
	text-align: center;
}

.impact-list,
.project-detail ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

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

.impact-list li,
.project-detail section {
	background: #ffffff;
	border: 1px solid #dbe3ea;
	border-radius: 8px;
	color: #334155;
	line-height: 1.65;
	padding: 1.25rem;
}

.impact-list strong {
	color: #0f172a;
}

.project-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
}

.project-tags li {
	background: #e6fffb;
	border: 1px solid #99f6e4;
	border-radius: 8px;
	color: #115e59;
	font-family: "Inter", Helvetica, sans-serif;
	font-size: 0.78rem;
	font-weight: 700;
	line-height: 1;
	padding: 0.7rem 0.85rem;
}

#main > .post.project-feature {
	padding: 4.5rem 6rem;
}

#main > .post.project-feature header.major > h2 {
	font-size: 2.8rem;
}

.project-feature .image.main {
	border-radius: 8px;
	margin: 2.5rem auto;
	max-width: 54rem;
	overflow: hidden;
}

.project-feature .image.main img,
.project-grid .image.fit img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.project-detail {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 2rem 0 2.5rem;
	text-align: left;
}

.project-detail h3 {
	font-size: 1rem;
	margin-bottom: 0.75rem;
}

.project-detail li {
	margin-top: 0.65rem;
	padding-left: 1rem;
	position: relative;
}

.project-detail li:before {
	background: #0d9488;
	border-radius: 50%;
	content: "";
	height: 0.35rem;
	left: 0;
	position: absolute;
	top: 0.7rem;
	width: 0.35rem;
}

#main > .posts.project-grid {
	background: #ffffff;
	gap: 0;
}

#main > .posts.project-grid > article {
	display: flex;
	flex-direction: column;
	padding: 3rem;
	text-align: left;
}

.project-grid header {
	margin-top: 1.25rem;
}

.project-grid h2 {
	font-size: 1.55rem;
	margin-bottom: 0.8rem;
}

.project-grid p {
	color: #475569;
	line-height: 1.7;
	margin-bottom: 1.3rem;
}

.project-grid .image.fit {
	aspect-ratio: 16 / 10;
	border-radius: 8px;
	margin: 0 0 0.5rem;
	overflow: hidden;
}

.project-grid .project-tags {
	justify-content: flex-start;
	margin: auto 0 1.5rem;
}

.project-grid .actions.special {
	justify-content: flex-start;
	margin-top: auto;
}

.button,
input[type="submit"],
input[type="reset"],
input[type="button"],
button {
	border-radius: 8px;
}

.button.primary,
input[type="submit"].primary,
input[type="reset"].primary,
input[type="button"].primary,
button.primary {
	background: #0f766e;
	color: #ffffff !important;
}

.button.primary:hover,
input[type="submit"].primary:hover,
input[type="reset"].primary:hover,
input[type="button"].primary:hover,
button.primary:hover {
	background: #0d9488;
}

#footer {
	background: #e2e8f0;
	color: #334155;
}

#footer .contact-intro h2 {
	color: #0f172a;
	font-size: 2rem;
	margin-bottom: 1rem;
}

#footer .contact-intro p,
#footer p {
	color: #475569;
}

#footer a {
	color: #0f172a;
}

@media screen and (max-width: 980px) {
	#intro h1 {
		font-size: 3.8rem;
	}

	#main > .profile-section,
	#main > .post.project-feature {
		padding: 4rem;
	}

	.impact-list,
	.project-detail {
		grid-template-columns: 1fr;
	}

	#main > .posts.project-grid > article {
		padding: 2.5rem;
	}
}

@media screen and (max-width: 736px) {
	#intro {
		min-height: 82vh;
		padding: 4rem 1.5rem 2rem;
	}

	#intro h1 {
		font-size: 2.8rem;
	}

	#intro .hero-copy {
		font-size: 1rem;
	}

	#intro .hero-actions {
		display: flex;
	}

	#main {
		width: 100%;
	}

	#main > .profile-section,
	#main > .post.project-feature {
		padding: 3rem 1.5rem;
	}

	header.major.compact h2,
	#main > .post.project-feature header.major > h2 {
		font-size: 2rem;
	}

	.lead {
		text-align: left;
	}

	#main > .posts.project-grid > article {
		padding: 2rem 1.5rem;
	}

	.project-grid .image.fit {
		max-width: none;
	}

	#footer .contact-intro h2 {
		font-size: 1.6rem;
	}
}
