/* Fonts, Colours and Spacing */
@font-face {
	font-family: "Oxygen";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("../webfonts/oxygen-400.ttf") format("truetype");
}
@font-face {
	font-family: "Oxygen";
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url("../webfonts/oxygen-700.ttf") format("truetype");
}

:root {
	--font-main: "Oxygen", sans-serif;

	--color-base: #272727;
	--color-contrast-1: #f9f9f9;
	--color-contrast-2: #b7b7b7;
	--color-accent-blue: #3366ff;
	--color-accent-gray: #777777;

	--container-max-width: 1280px;
	--spacing-10: 1rem;
	--spacing-15: 1.5rem;
	--spacing-20: 2rem;
	--spacing-30: 3rem;
	--spacing-50: 10rem;
}

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

body {
	background-color: var(--color-base);
	color: var(--color-contrast-2);
	font-family: var(--font-main);
	font-size: var(--spacing-10);

	-webkit-font-smoothing: antialiased;
}

.container {
	max-width: var(--container-max-width);
	margin: 0 auto;
	padding: 0 20px;
}

.site-wrapper {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.site-main {
	flex: 1;
}

/* Header */
.site-header {
	padding: 20px 0;
}

.header-content {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}

.logo-area {
	display: flex;
	align-items: center;
	gap: 15px;
}

.site-logo {
	width: 70px;
	height: 70px;
	display: block;
}

.site-title {
	color: var(--color-contrast-1);
	font-size: clamp(1rem, 2.5vw, 2rem);
	font-weight: 400;
}

.site-title a {
	text-decoration: none;
	color: inherit;
}

/* Hero Section */
.hero-section {
	text-align: center;
	padding: var(--spacing-50) 0 var(--spacing-30) 0;
}

.hero-image-container {
	margin-bottom: var(--spacing-15);
}

.hero-image {
	max-width: 100%;
	height: auto;

	/* width: 580px; */
	/* border-radius: var(--spacing-15); */
	/* box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3); */
	padding: 3rem;

	/* width: 1100px; */
	border-radius: var(--spacing-15);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.main-heading {
	color: var(--color-contrast-1);
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	font-weight: 400;
	margin-bottom: var(--spacing-15);
}

.sub-heading {
	font-size: var(--spacing-20);
	margin-bottom: var(--spacing-15);
	padding: var(--spacing-10) 0;
}

.contact-links-container {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--spacing-30);
	margin-bottom: var(--spacing-15);
}

.contact-links-container p {
	margin-bottom: 0;
}

.contact-link {
	color: var(--color-contrast-2);
	text-decoration: none;
	font-size: var(--spacing-10);
	transition: color 0.3s ease;
}

.contact-link:hover {
	color: var(--color-contrast-1);
}

.contact-link i {
	width: 25px;
	text-align: center;
	margin-right: 8px;
}

/* Footer */
.site-footer {
	padding: var(--spacing-30) 0;
}

.footer-content {
	text-align: right;
}

.hosting-credit a {
	text-decoration: none;
}

.giga {
	color: var(--color-accent-blue);
	font-weight: 700;
}

.tech {
	color: var(--color-accent-gray);
}

/* Responsive Adjustments */
@media (max-width: 768px) {
	.sub-heading {
		font-size: var(--spacing-15);
	}

	.hero-image {
		width: 100%;
	}
}
