/* ==================================================
    IMPORTS
================================================== */
@import url("themes.css");
@import url("vars.css");
@import url("nav.css");
@import url("sections.css");
/* ==================================================
    RESET
================================================== */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

/* ==================================================
    BASE
================================================== */
html {
	scroll-behavior: smooth;
}

body {
	background-color: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.7;
}

a {
	color: var(--color-primary);
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

h1,
h2,
h3 {
	font-family: var(--font-heading);
	line-height: 1.2;
}

/* ==================================================
    FOOTER
================================================== */
footer {
	text-align: center;
	padding: var(--spacing-md);
	border-top: 1px solid var(--color-border);
	color: var(--color-muted);
	font-size: 0.85rem;
}
/* ==================================================
    MEDIA QUERIES
================================================== */
/* laptop */
@media (max-width: 1024px) {
	.cards-grid {
		grid-template-columns: repeat(2, 1fr);
	}
    .highlights-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* tablet */
@media (max-width: 768px) {
	.cards-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.skills-grid {
		grid-template-columns: repeat(3, 1fr);
	}
	.highlights-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.hero-roles {
		grid-template-columns: repeat(3, auto);
	}
	.hero-roles span:nth-child(3)::after {
		display: none;
	}

	.nav-toggle {
		display: block;
	}
	.nav-links {
		display: none;
		flex-direction: column;
		position: absolute;
		top: var(--nav-height);
		left: 0;
		right: 0;
		background-color: var(--color-surface);
		border-bottom: 1px solid var(--color-border);
		padding: var(--spacing-sm) var(--spacing-md);
		gap: var(--spacing-sm);
	}
	.nav-links.open {
		display: flex;
	}
}

/* mobile */
@media (max-width: 480px) {
	.cards-grid {
		grid-template-columns: 1fr;
	}
	.skills-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.highlights-grid {
		grid-template-columns: 1fr;
	}

	.hero h1 {
		font-size: 2rem;
	}
}
