@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/aFTU7PB1QTsUX8KYthSQBLyM.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/aFTU7PB1QTsUX8KYthqQBA.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../fonts/aFTR7PB1QTsUX8KYvumzEY2tbZX9.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../fonts/aFTR7PB1QTsUX8KYvumzEYOtbQ.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'DM Sans';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url(../fonts/rP2rp2ywxg089UriCZaSExd86J3t9jz86Mvy4qCRAL19DksVat_XDV36TGc5pg.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'DM Sans';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url(../fonts/rP2rp2ywxg089UriCZaSExd86J3t9jz86Mvy4qCRAL19DksVat_XDV30TGc.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(../fonts/rP2Yp2ywxg089UriI5-g4vlH9VoD8Cmcqbu6-K6z8GXhnU04aw.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(../fonts/rP2Yp2ywxg089UriI5-g4vlH9VoD8Cmcqbu0-K6z8GXhnU0.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/rP2Yp2ywxg089UriI5-g4vlH9VoD8Cmcqbu6-K6z8GXhnU04aw.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/rP2Yp2ywxg089UriI5-g4vlH9VoD8Cmcqbu0-K6z8GXhnU0.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../fonts/rP2Yp2ywxg089UriI5-g4vlH9VoD8Cmcqbu6-K6z8GXhnU04aw.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../fonts/rP2Yp2ywxg089UriI5-g4vlH9VoD8Cmcqbu0-K6z8GXhnU0.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Syne';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../fonts/8vIH7w4qzmVxm2NL9Hz_.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Syne';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../fonts/8vIH7w4qzmVxm25L9Hz_.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Syne';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../fonts/8vIH7w4qzmVxm2BL9A.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* greek */
@font-face {
  font-family: 'Syne';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../fonts/8vIH7w4qzmVxm2NL9Hz_.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Syne';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../fonts/8vIH7w4qzmVxm25L9Hz_.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Syne';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../fonts/8vIH7w4qzmVxm2BL9A.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
	--bg: #0d0d14;
	--bg2: #13131f;
	--bg3: #1a1b26;
	--bg4: #1f2035;
	--surface: #24253a;
	--border: rgba(122, 162, 247, 0.18);
	--border2: rgba(255, 255, 255, 0.06);

	--fg: #cdd6f4;
	--fg2: #a9b1d6;
	--fg3: #565f89;

	--blue: #7aa2f7;
	--purple: #bb9af7;
	--light-purple: #7935f8;
	--green: #9ece6a;
	--yellow: #e0af68;
	--red: #f7768e;
	--rose: #f483fc;
	--cyan: #7dcfff;
	--orange: #ff9e64;

	--radius-sm: 8px;
	--radius-md: 14px;
	--radius-lg: 20px;
	--radius-xl: 28px;

	--font-display: 'Syne', sans-serif;
	--font-body: 'DM Sans', sans-serif;
	--font-mono: 'DM Mono', monospace;

	--gutter: clamp(1rem, 5vw, 3rem);
	--max-w: 900px;

	--transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
}

body {
	background: var(--bg);
	color: var(--fg);
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.6;
	min-height: 100vh;
	overflow-x: hidden;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	display: block;
	max-width: 100%;
}

ul {
	list-style: none;
}

.ambient {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	overflow: hidden;
}
.blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(100px);
	opacity: 0.18;
}
.blob-1 {
	width: 500px;
	height: 500px;
	background: var(--blue);
	top: -150px;
	left: -100px;
}
.blob-2 {
	width: 400px;
	height: 400px;
	background: var(--purple);
	bottom: 10%;
	right: -100px;
}
.blob-3 {
	width: 300px;
	height: 300px;
	background: var(--green);
	top: 50%;
	left: 40%;
	opacity: 0.1;
}

.page-wrap {
	min-height: 100vh;
}

.main-col {
	grid-column: 3;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.content {
	position: relative;
	z-index: 1;
	max-width: var(--max-w);
	width: 100%;
	margin: 0 auto;
	padding: 3rem 0.25rem 3rem;
	display: flex;
	flex-direction: column;
	gap: 2rem;
	flex: 1;
}

.hero-card {
	background: var(--bg3);
	border: 1px solid var(--border);
	border-radius: var(--radius-xl);
	padding: 2.5rem;
	display: flex;
	align-items: center;
	gap: 2rem;
	position: relative;
	overflow: hidden;
	animation: fadeUp 0.6s ease both;
}
.hero-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(122, 162, 247, 0.05) 0%,
		transparent 60%
	);
	pointer-events: none;
}

.hero-text {
	flex: 1;
}

.available-badge {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 5px 14px;
	border-radius: 100px;
	background: rgba(158, 206, 106, 0.12);
	border: 1px solid rgba(158, 206, 106, 0.3);
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--green);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}
.available-badge .dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 6px var(--green);
	animation: blink 2s ease-in-out infinite;
}

.hero-name {
	font-family: var(--font-display);
	font-size: clamp(2rem, 5vw, 3.2rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: -1.5px;
	margin-bottom: 0.5rem;
}
.hero-name .first {
	color: var(--fg);
}
.hero-name .last {
	background: linear-gradient(
		135deg,
		var(--blue) 0%,
		var(--purple) 55%,
		var(--red) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.hero-role {
	font-size: 1rem;
	font-weight: 300;
	color: var(--fg2);
	margin-bottom: 1.25rem;
	line-height: 1.5;
}
.hero-role strong {
	color: var(--fg);
	font-weight: 500;
}

.hero-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.tag {
	padding: 4px 12px;
	border-radius: 6px;
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.03em;
}
.tag-blue {
	background: rgba(122, 162, 247, 0.15);
	color: var(--blue);
	border: 1px solid rgba(122, 162, 247, 0.25);
}
.tag-purple {
	background: rgba(187, 154, 247, 0.15);
	color: var(--purple);
	border: 1px solid rgba(187, 154, 247, 0.25);
}
.tag-light-purple {
	background: rgba(152, 101, 247, 0.15);
	color: var(--light-purple);
	border: 1px solid rgba(137, 84, 235, 0.25);
}
.tag-green {
	background: rgba(158, 206, 106, 0.15);
	color: var(--green);
	border: 1px solid rgba(158, 206, 106, 0.25);
}
.tag-cyan {
	background: rgba(125, 207, 255, 0.15);
	color: var(--cyan);
	border: 1px solid rgba(125, 207, 255, 0.25);
}
.tag-yellow {
	background: rgba(224, 175, 104, 0.15);
	color: var(--yellow);
	border: 1px solid rgba(224, 175, 104, 0.25);
}
.tag-orange {
	background: rgba(216, 142, 30, 0.15);
	color: var(--orange);
	border: 1px solid rgba(223, 144, 26, 0.25);
}
.hero-avatar {
	flex-shrink: 0;
	width: clamp(100px, 15vw, 140px);
	height: clamp(100px, 15vw, 140px);
	border-radius: 50%;
	background: linear-gradient(135deg, var(--blue), var(--purple));
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 4vw, 2.5rem);
	font-weight: 800;
	color: var(--bg);
	position: relative;
	box-shadow: 0 0 40px rgba(122, 162, 247, 0.25);
}
.hero-avatar::after {
	content: '';
	position: absolute;
	inset: -3px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--blue), var(--purple), var(--red));
	z-index: -1;
	opacity: 0.5;
}
.cards-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 1.25rem;
	animation: fadeUp 0.6s 0.15s ease both;
}

.card {
	background: var(--bg3);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: 2rem;
	position: relative;
	overflow: hidden;
	transition:
		transform var(--transition),
		border-color var(--transition),
		box-shadow var(--transition);
}
.card:hover {
	transform: translateY(-3px);
	border-color: rgba(122, 162, 247, 0.35);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}
.card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(122, 162, 247, 0.04) 0%,
		transparent 50%
	);
	pointer-events: none;
}

.card-projects {
	grid-column: 1 / span 2;
}

.card-icon {
	width: 40px;
	height: 40px;
	border-radius: var(--radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	margin-bottom: 1.2rem;
}
.icon-blue {
	background: rgba(122, 162, 247, 0.18);
}
.icon-purple {
	background: rgba(187, 154, 247, 0.18);
}
.icon-orange {
	background: rgba(224, 175, 104, 0.15);
}
.icon-yellow {
	background: rgba(224, 175, 104, 0.25);
}
.icon-green {
	background: rgba(158, 206, 106, 0.15);
}

.card-title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 700;
	margin-bottom: 0.4rem;
	letter-spacing: -0.3px;
}
.card-desc {
	font-size: 0.875rem;
	color: var(--fg2);
	font-weight: 300;
	margin-bottom: 1.5rem;
	line-height: 1.6;
}

.project-list {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}
.project-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.7rem 1rem;
	background: var(--bg4);
	border: 1px solid var(--border2);
	border-radius: var(--radius-sm);
	transition:
		background var(--transition),
		border-color var(--transition);
	cursor: pointer;
}
.project-item:hover {
	background: var(--surface);
	border-color: var(--border);
}
.project-item-left {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.project-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}
.project-name {
	font-size: 0.875rem;
	font-weight: 500;
}
.project-stack {
	font-size: 0.75rem;
	color: var(--fg3);
	font-family: var(--font-mono);
}
.project-arrow {
	color: var(--fg3);
	font-size: 0.875rem;
	transition:
		transform var(--transition),
		color var(--transition);
}
.project-item:hover .project-arrow {
	transform: translateX(3px);
	color: var(--blue);
}

.github-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 1.25rem;
	padding: 0.6rem 1.25rem;
	border-radius: var(--radius-sm);
	background: var(--bg4);
	border: 1px solid var(--border);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--fg2);
	transition:
		background var(--transition),
		color var(--transition),
		border-color var(--transition);
}
.github-link:hover {
	background: var(--surface);
	color: var(--fg);
	border-color: rgba(122, 162, 247, 0.4);
}

.card-social {
	grid-column: 3;
}
.social-list {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}
.social-item {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	padding: 0.75rem 1rem;
	background: var(--bg4);
	border: 1px solid var(--border2);
	border-radius: var(--radius-sm);
	transition:
		background var(--transition),
		border-color var(--transition),
		transform var(--transition);
}
.social-item:hover {
	background: var(--surface);
	border-color: var(--border);
	transform: translateX(4px);
}
.social-icon {
	width: 34px;
	height: 34px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.95rem;
	flex-shrink: 0;
}
.social-info {
	flex: 1;
	min-width: 0;
}
.social-name {
	font-size: 0.875rem;
	font-weight: 500;
	display: block;
}
.social-handle {
	font-size: 0.75rem;
	color: var(--fg3);
	font-family: var(--font-mono);
}
.social-arrow {
	color: var(--fg3);
	font-size: 0.8rem;
	transition: color var(--transition);
}
.social-item:hover .social-arrow {
	color: var(--blue);
}

.card-school {
	grid-column: 1 / span 3;
}

.school-projects-list {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.school-projects-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.85rem 1rem;
	background: var(--bg4);
	border: 1px solid var(--border2);
	border-radius: var(--radius-sm);
	transition:
		background var(--transition),
		border-color var(--transition),
		transform var(--transition);
}
.school-projects-item:hover {
	background: var(--surface);
	border-color: var(--border);
}
.school-projects-item:hover .social-arrow {
	color: var(--blue);
}
.school-projects-item .project-item-left {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	flex: 1;
	min-width: 0;
}
.school-icon {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	border-radius: 8px;
	background: var(--fg3);
	border: 1px solid var(--border2);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.school-icon img {
	width: 24px;
	height: 24px;
	object-fit: contain;
}

.school-item-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.school-item-text .project-name {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--fg);
	white-space: nowrap;
}
.school-item-text .project-stack {
	font-size: 0.75rem;
	color: var(--fg3);
	font-family: var(--font-mono);
	line-height: 1.5;

	display: -webkit-box;
	line-clamp: 1;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
	max-height: 1.5em;

	transition:
		max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1),
		-webkit-line-clamp 0.35s;
}

/* Déploie au hover de l'item parent */
.school-projects-item:hover .project-stack {
	line-clamp: 10;
	-webkit-line-clamp: 10;
	max-height: 10em;
}

.school-projects-item .social-arrow {
	flex-shrink: 0;
	color: var(--fg3);
	font-size: 0.875rem;
	align-self: flex-start;
	margin-top: 2px;
	transition: color var(--transition);
}

footer {
	position: relative;
	z-index: 1;
	border-top: 1px solid var(--border);
	background: var(--bg2);
	animation: fadeUp 0.6s 0.3s ease both;
	width: 100%;
}

.footer-inner {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 1.25rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.footer-left {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.55rem 1.1rem;
	border-radius: var(--radius-sm);
	font-size: 0.8125rem;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--transition);
	border: 1px solid transparent;
	white-space: nowrap;
}

.btn-primary {
	background: linear-gradient(135deg, var(--blue), var(--purple));
	color: var(--bg);
	font-weight: 600;
}
.btn-primary:hover {
	opacity: 0.9;
	box-shadow: 0 4px 20px rgba(122, 162, 247, 0.35);
	transform: translateY(-1px);
}

.btn-outline {
	background: var(--bg3);
	border-color: var(--border);
	color: var(--fg2);
}
.btn-outline:hover {
	background: var(--surface);
	color: var(--fg);
	border-color: rgba(122, 162, 247, 0.4);
	transform: translateY(-1px);
}

.footer-copy {
	font-size: 0.75rem;
	color: var(--fg3);
}

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(18px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes blink {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.3;
	}
}
@media (max-width: 680px) {
	:root {
		--gutter: 0.5rem;
	}

	.nav-links {
		display: none;
	}
	.hamburger {
		display: flex;
	}
	.mobile-menu {
		display: flex;
	}

	.hero-card {
		flex-direction: column-reverse;
		align-items: flex-start;
		padding: 1.5rem;
	}
	.hero-avatar {
		width: 72px;
		height: 72px;
		font-size: 1.4rem;
		align-self: flex-end;
	}

	.cards-grid {
		grid-template-columns: 1fr;
	}
	.card-projects,
	.card-social,
	.card-school-projects {
		grid-column: 1;
	}

	.school-item-text .project-stack {
		max-width: 38ch;
	}

	.footer-inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}
}
