*, *:before, *:after {
	box-sizing: border-box;
}

html {
	overflow-x: hidden;
}

body {
	margin: 0;
	font-family: 'Nunito', sans-serif;
}

body.dark-mode {
	filter: invert(100%);

	.image-container img {
		filter: invert(100%);
	}

	.bg {
		opacity: 0 !important;
	}

	section:nth-child(even), footer:nth-child(even) {
		background: #eee !important;
	}

	section:nth-child(odd), footer:nth-child(odd) {
		background: white !important;
	}

	.works-card .text-container {
		color: #333 !important;

		a {
			color: inherit !important;
			background: rgba(0,0,0,0.1) !important;
			box-shadow: none !important;
		}
	}

	footer {
		color: #333 !important;
	}
}

.main {
	height: 100vh;
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: column;
	overflow-y: hidden;

	> * {
		position: relative;
	}


	> canvas#bg {
		position: absolute;
		top: 0;
		left: 0;
	}

	.text-container {
		text-align: left;
		max-width: 50rem;
		margin: auto auto auto 13vw;
	}

	h1 {
		font-size: 4rem;
		font-weight: 600;
		margin: 0 0 2rem;
		color: #333;
	}

	h3 {
		margin: 1rem 0 0;
		font-size: 1.7rem;
		line-height: 1.4;
		font-weight: normal;
		color: #999;
	}

	em {
		color: #333;
		font: inherit;
	}

	a {
		color: #333;
		text-decoration: none;
		border-bottom: 0.2rem solid transparent;
		white-space: nowrap;
		position: relative;

		&:before, &:after {
			content: '';
			bottom: 0.4rem;
			left: 0;
			width: 100%;
			height: 0.1rem;
			background: rgba(#333, 0.2);
			position: absolute;
			opacity: 0.2;
			transition: all 0.2s ease;
		}

		&:before {
			transform: scaleX(0);
			transform-origin: center left;
		}

		&:after {
			opacity: 0.5;
		}

		&:hover:before {
			transform: scaleX(1);
			opacity: 1;
		}
	}
}

.works-card {
	height: 100vh;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	max-width: 100%;
	position: relative;
	z-index: 10;
	
	> div {
		width: 50%;
		position: relative;
		height: 100%;
	}
	
	.image-container img {
		width: 133%;
		position: absolute;
		top: 0;
		bottom: 0;
		margin: auto;
		border-radius: 0.2rem;
		box-shadow: 0 0 10rem rgba(0,0,0,0.1), 0 0.25rem 1rem rgba(0,0,0,0.33);
	}
	
	.image-container:nth-child(1) img {
		right: 0;
	}
	
	.image-container:nth-child(2) img {
		left: 0;
	}
	
	.text-container {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		padding: 0 2rem;
		transition: all 0.225s ease;
		
		> * {
			max-width: 30rem;
			width: 100%;
		}
		
		h1 {
			font-size: 3.3rem;
			margin: 0 0 1rem;
		}
		
		p {
			font-size: 1.15rem;
			line-height: 1.5;
			margin: 1rem 0 0;
		}
		
		a {
			color: black;
			text-decoration: none;
			position: relative;
			background: rgba(black, 0.05);
			display: inline-block;
			padding: 1rem 2rem 1rem 1.25rem;
			border-radius: 0.1rem;
			margin-top: 1rem;
			box-shadow: 0 0.05rem 0.025rem rgba(0,0,0,0.3);
			margin-right: 1rem;
			
			&:before {
				position: absolute;
				bottom: 1.2rem;
				left: 1.25rem;
				width: calc(100% - 3.25rem);
				content: '';
				height: 0.115rem;
				transition: all 0.2s ease;
				border-top: 0.115rem solid black;
				opacity: 0.2;
				box-sizing: border-box;
				transform: scaleX(0);
				transform-origin: center left;
			}
			
			&:after {
				content: '';
				position: absolute;
				right: 1.25rem;
				pointer-events: none;
				font-size: 0.66rem;
				top: 0;
				bottom: 0;
				height: 0.33rem;
				width: 0.33rem;
				transform: rotate(45deg);
				border: 1px solid rgba(black, 1);
				border-bottom: 0;
				border-left: 0;
				line-height: 1.2rem;
				margin: auto;
				opacity: 0.7;
				transition: all 0.2s ease;
			}
			
			&:hover {
				&:before {
					transform: scaleX(1);
				}
				
				&:after {
					right: 1.15rem;
				}
			}
			
			&.dark {
				color: rgba(255,255,255,0.8);
				background: rgba(white, 0.9);

				&:before {
					border-color: inherit;
				}

				&:after {
					border-color: inherit;
				}
			}
		}
	}
}

#contact {
	position: relative;
	z-index: 10;
	text-align: center;
	padding: 5rem 2rem 3rem;

	h1 {
		font-size: 3.3rem;
		margin: 0 0 2rem;
	}

	p {
		font-size: 1.15rem;
		line-height: 1.5;
		margin: 1rem auto 0;
	}

	.contact-info-container {
		max-width: 40rem;
		margin: 2rem auto;
		text-align: left;
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		height: 12rem;

		a.contact-method {
			text-decoration: none;
			color: inherit;
			display: block;
			width: 50%;
			height: 6rem;
			position: relative;
			padding-left: 6rem;
			display: flex;
			flex-direction: column;
			align-items: flex-start;
			justify-content: center;
			overflow: hidden;

			h3, p {
				font-weight: normal;
				margin: 0;
				transition: all 0.2s ease;
			}

			h3 {
				font-size: 1.5rem;
				line-height: 1.4;
				transform: translateY(0.6rem);
			}

			p {
				line-height: 1.25rem;
				height: 1.25rem;
				transform: translateY(1rem);
				opacity: 0;
				color: #777;
				font-size: 0.9rem;
			}

			i {
				font-size: 2rem;
				line-height: 6rem;
				position: absolute;
				top: 0;
				left: 0;
				width: 6rem;
				height: 6rem;
				text-align: center;

				&:before {
					position: relative;
					z-index: 10;
				}

				&:after {
					position: absolute;
					top: 0;
					left: 0;
					right: 0;
					bottom: 0;
					margin: auto;
					width: 60%;
					height: 60%;
					border-radius: 50%;
					opacity: 0;
					transform: scale(0.7);
					content: '';
					transition: all 0.2s ease;
					background: #333;
				}
			}

			i.email {
				&:before {
					content: '@';
					font-style: normal;
					font-weight: bold;
					line-height: 5.5rem;
					top: 0;
					left: 0;
					width: 100%;
					height: 100%;
					position: absolute;
					text-align: center;
				}
			}

			&:hover {
				h3 {
					transform: translateY(0);
				}

				p {
					transform: translateY(0);
					opacity: 1;
				}
			}
		}
	}
}

footer {
	position: relative;
	z-index: 10;
	text-align: center;
	padding: 3rem 0;
	background: #1f2e3a;
	color: white;
	font-size: 1.2rem;
}

.ticker {
	padding: 2rem 0 0;
	font-size: 0.9rem;
	opacity: 0.7;
	font-family: monospace;
	letter-spacing: 1px;
}

.ticker:after {
	content: '_';
	opacity: 0.4;
	animation: blink 0.5s infinite;
}

@keyframes blink {
	0% { opacity: 0; }
	49% { opacity: 0; }
	51% { opacity: 1; }
	100% { opacity: 1; }
}

@media(max-width: 900px), (orientation: portrait) {
	.main > .text-container {
		margin: auto;
		padding: 2rem;
	}

	.works-card {
		flex-direction: column;
		height: auto;
		
		> div {
			height: auto;
			width: 100%;
		}
		
		.text-container {
			order: 2;
			padding-bottom: 2rem;
		}
		
		.image-container {
			order: 1;
			padding-top: 3rem;
			min-height: calc(45vw + 5rem);
		}
		
		.image-container img {
			width: 80vw;
			margin: auto;
			display: block;
			top: 0;
			bottom: 0;
			left: 0;
			right: 0;
			margin: auto;
			box-shadow: 0 0 5rem rgba(0,0,0,0.1), 0 0.25rem 1rem rgba(0,0,0,0.33);
		}
	}

	#contact {
		text-align: left;

		.contact-info-container a.contact-method {
			h3 {
				transform: translateY(0);
			}

			p {
				transform: translateY(0);
				opacity: 1;
			}
		}
	}
}

@media(max-width: 600px) {
	#contact .contact-info-container {
		height: auto;

		a.contact-method {
			width: 100%;
		}
	}
}

@media(max-width: 400px) {
	.main {
		> .text-container {
			h1 {
				font-size: 3rem;
			}

			h3 {
				font-size: 1.5rem;
			}
		}
	}

	.works-card {
		> .text-container {
			p {
				font-size: 1rem;
			}
			
			h1 {
				font-size: 2.6rem;
			}
		}
	}
}

.bg-scroller {
	z-index: 5;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	
	.bg {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		opacity: 0;
		transition: all 0.225s ease;
	}
}

@media(min-width: 1800px) {
  html {
    font-size: 20px;
  }
}
@media(min-width: 2400px) {
  html {
    font-size: 24px;
  }
}
@media(min-width: 2800px) {
  html {
    font-size: 32px;
  }
}
@media(min-width: 3600px) {
  html {
    font-size: 36px;
  }
}