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

:root {
	--bg-color: #121415;
	--text-main: #f8f8f8;
	--text-muted: #a0aab2;
	--accent: #ffffff;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	background-color: var( --bg-color );
	background-image: radial-gradient( circle at center, #1e2224 0%, #0a0b0c 100% );
	color: var( --text-muted );
	font-family: "Montserrat", sans-serif;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

a {
	color: var( --accent );
	text-decoration: none;
	transition: opacity 0.3s ease;
}

/* --- Hero Section --- */
.hero {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 50px 20px 20px;
}

h1 {
	font-family: "Playfair Display", serif;
	font-size: clamp( 3rem, 8vw, 6rem );
	color: var( --text-main );
	letter-spacing: 2px;
	margin-bottom: 10px;
}

.subtitle_box {
	border: 1px solid rgba( 255, 255, 255, 0.2 );
	padding: 10px 30px;
	margin-top: 10px;
}

h2.subtitle {
	font-family: "Montserrat", sans-serif;
	font-size: clamp( 0.7rem, 2vw, 0.9rem );
	font-weight: 400;
	color: var( --text-main );
	letter-spacing: 6px;
	text-transform: uppercase;
}

/* --- Content Layout --- */
.container {
	max-width: 800px;
	margin: 0 auto;
	padding: 60px 20px;
}

section {
	margin-bottom: 80px;
}

.section_title {
	font-family: "Playfair Display", serif;
	font-size: 2rem;
	color: var( --text-main );
	margin-bottom: 30px;
	border-bottom: 1px solid rgba( 255, 255, 255, 0.1 );
	padding-bottom: 10px;
}

/* --- Experience Bullets --- */
.job {
	margin-bottom: 40px;
}

.job_header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 15px;
	flex-wrap: wrap;
}

.job_title {
	font-size: 1.2rem;
	color: var( --text-main );
	font-weight: 500;
}

.job_date {
	font-size: 0.9rem;
	color: var( --text-muted );
}

ul {
	list-style-type: none;
}

li {
	position: relative;
	padding-left: 20px;
	margin-bottom: 15px;
}

li::before {
	content: ">";
	position: absolute;
	left: 0;
	color: rgba( 255, 255, 255, 0.3  );
}

strong {
	color: var( --text-main );
	font-weight: 500;
}

/* --- Contact Section --- */
.contact_card {
	border: 1px solid rgba( 255, 255, 255, 0.08 );
	background: rgba( 0, 0, 0, 0.18 );
	padding: 22px 22px 20px;
}

.contact_meta {
	color: rgba( 255, 255, 255, 0.55 );
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-size: 0.78rem;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.contact_pill {
	display: inline-flex;
	align-items: center;
	padding: 7px 12px;
	border-radius: 999px;
	border: 1px solid rgba( 255, 255, 255, 0.14 );
	background: rgba( 255, 255, 255, 0.03 );
}

.contact_intro {
	margin-top: 14px;
	max-width: 62ch;
	color: var( --text-muted );
	padding: 14px 20px;
	border-radius: 12px;
	border: 1px solid rgba( 1, 67, 2, 0.4 );
	background: rgba( 0, 0, 0, 0.16 );
}

.contact_links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 18px;
}

.contact_link {
	border: 1px solid rgba( 255, 255, 255, 0.2 );
	padding: 10px 16px;
	font-size: 0.85rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	background: rgba( 255, 255, 255, 0.03 );
	transition: opacity 0.3s ease, background-color 0.25s ease, color 0.25s ease, transform 0.18s ease, border-color 0.25s ease;
}

.contact_link:hover {
	background-color: rgb( 212, 212, 212 );
	color: var( --bg-color );
	border-color: rgb( 134, 134, 134 );
	transform: translateY( -1px );
}

.contact_link:focus-visible {
	outline: 2px solid rgba( 255, 255, 255, 0.65 );
	outline-offset: 3px;
}

@media ( max-width: 480px ) {

	.contact_card {
		padding: 18px 16px 16px;
	}

	.contact_link {
		padding: 10px 14px;
	}

	.contact_intro {
		padding: 13px 14px;
	}

}