@font-face {
	font-family: 'Fira Sans';
	src: url('fonts/Fira_Sans/FiraSans-Light.ttf') format('truetype');
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Fira Sans';
	src: url('fonts/Fira_Sans/FiraSans-Medium.ttf') format('truetype');
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Oswald';
	src: url('fonts/Oswald/Oswald-Medium.ttf') format('truetype');
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

:root {
	--color-dark: #1E2225;
	--color-light: #fff;

	--spacing-05: 0.5rem;
	--spacing-10: 1rem;
	--spacing-15: 1.5rem;
	--spacing-20: 2rem;
	--spacing-30: 3rem;
	--spacing-50: 5rem;

	--h1-font-size: 3rem;
	--h2-font-size: 3.875rem;
}

@media screen and (max-width: 468px) {
	:root {
		--spacing-30: 1.5rem;

		--h1-font-size: 2rem;
		--h2-font-size: 2rem;
	}
}

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

body {
	font-family: 'Fira Sans', sans-serif;
	font-size: calc(15px + 0.390625vw);
	font-weight: 300;
	line-height: 1;
}

strong {
	font-weight: 500;
}

img {
	display: block;
	height: auto;
	max-width: 100%;
}

h1,
h2 {
	font-family: 'Oswald', sans-serif;
	font-weight: 500;
}

h1 {
	font-size: var(--h1-font-size);
	margin-bottom: var(--spacing-10);
}

h2 {
	font-size: var(--h2-font-size);
	margin: var(--spacing-10) var(--spacing-30) var(--spacing-15) var(--spacing-30);
}

p {
	line-height: 1.75;
	margin-bottom: var(--spacing-10);
}

p:last-child {
	margin: 0;
}

p a {
	color: var(--color-dark);
	position: relative;
	text-decoration: none
}

p a::before {
	background: var(--color-dark);
	bottom: 0;
	content: '';
	height: 1px;
	left: 0;
	position: absolute;
	transform: scaleX(1);
	transform-origin: right;
	transition: transform .2s linear;
	width: 100%;
}

p a:hover::before {
	transform: scaleX(0);
	transform-origin: left;
}

html {
	scroll-behavior: smooth;
}

main {
	height: 100vh;
	-webkit-overflow-scrolling: touch;
	overflow-y: scroll;
	scroll-snap-type: y proximity;
	width: 100vw;
}

header {
	position: fixed;
	right: var(--spacing-20);
	text-align: right;
	top: var(--spacing-10);
	z-index: 100
}

@media screen and (max-width: 468px) {
	header {
		right: var(--spacing-10);
	}
}

header a {
	background-color: rgba(49, 66, 69, .65);
	border: 1px solid var(--color-light);
	color: var(--color-light);
	display: inline-block;
	font-family: 'Oswald';
	font-weight: 500;
	padding: var(--spacing-10);
	text-align: center;
	text-decoration: none;
	text-shadow: 1px 1px 1px rgba(49, 66, 69, 1);
	transition: background-color .2s linear;
}

header a:hover {
	background-color: rgba(49, 66, 69, 1);
}

.full-height {
	display: grid;
	height: 100dvh;
	scroll-snap-align: start;
}

/* home ================================================ */

.home section {
	background-image: url('img/skyboats.jpg');
	background-image: url('img/skyboats.webp');
	background-image: url('img/skyboats.avif');
	background-position: center center;
	background-size: cover;
	filter: saturate(80%);
	grid-template-columns: 50% 40% 10%;
	grid-template-rows: 100%;
}

.home .content {
	background: rgba(30, 34, 37, 0.88);
	color: var(--color-light);
	display: flex;
	flex-direction: column;
	grid-area: 1 / 2 / 2 / 3;
	padding: var(--spacing-30);
}

@media screen and (max-width: 768px) {
	.home section {
		background-position: left center;
		grid-template-columns: 1fr 1fr;
		grid-template-rows: 100%;
	}

	.home .content {
		grid-area: 1 / 2 / 2 / 2;
		padding: var(--spacing-30);
	}
}

@media screen and (max-width: 468px) {
	.home section {
		grid-template-columns: 1fr;
		grid-template-rows: 1fr auto;
	}

	.home .content {
		grid-area: 2 / 1 / 3 / 1;
		padding: var(--spacing-30);
	}
}

.home .content img {
	margin-bottom: var(--spacing-20);
}

@media screen and (max-width: 468px) {
	.skyboats-logo {
		width: 20%;
	}
}

.home .content ul {
	list-style: none;
	margin-top: auto;
	padding: 0;
}

.home .content ul li {
	border-bottom: 1px solid var(--color-light);
	font-weight: 500;
	padding: var(--spacing-10) 0;
	text-transform: uppercase;
}

.home .content ul li a {
	color: var(--color-light);
	text-decoration: none;
}

section {
	color: var(--color-light);
}

section:not(.full-height) {
	padding: var(--spacing-30);
}

/* footer ============================================== */

footer {
	align-items: center;
	background-color: var(--color-dark);
	color: var(--color-light);
	display: grid;
	gap: var(--spacing-30);
	grid-template-columns: repeat(2, 1fr);
	padding: var(--spacing-30) var(--spacing-30) var(--spacing-50) var(--spacing-30);
}

footer p a {
	color: var(--color-light)
}

footer p a::before {
	background: var(--color-light);
}

@media screen and (max-width: 468px) {
	footer {
		grid-template-columns: 1fr;
	}
}

/* google map ========================================== */

.map-container {
	aspect-ratio: 16/9;
	overflow: hidden;
	position: relative;
}

.map-container iframe {
	height: 100% !important;
	left: 0;
	position: absolute;
	top: 0;
	width: 100% !important;
}