@import url('https://fonts.googleapis.com/css2?family=Signika+Negative:wght@300..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Antonio:wght@100..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Sono:wght@200..800&display=swap');

:root {
	--br-def: 0.5rem;
	--nav-hide: 0px;
	--nav-height: 0px;
	--nav-width: 0px;
	--content-width: 0px;
	--transition-def: 0.3s;
	--primary-font: "Signika Negative", sans-serif;
	--secondary-font: "Antonio", sans-serif;
	--me-font: "Sono", monospace;
}

/* General Styling */
body {
	font-family: var(--primary-font);
	transition: var(--transition-def) !important;
}
.lock-movement {
	overflow: hidden;
}
.no-br {
	border-radius: 0;
}
.br-c {
	border-radius: var(--br-def) !important;
	-webkit-border-radius: var(--br-def) !important;
	-moz-border-radius: var(--br-def) !important;
	-ms-border-radius: var(--br-def) !important;
	-o-border-radius: var(--br-def) !important;
}
.br-c .br-c {
	border-radius: calc(var(--br-def) / 2);
	-webkit-border-radius: calc(var(--br-def) / 2);
	-moz-border-radius: calc(var(--br-def) / 2);
	-ms-border-radius: calc(var(--br-def) / 2);
	-o-border-radius: calc(var(--br-def) / 2);
}
.vh-100 {
	height: 100vh !important;
	height: calc(var(--vh, 1vh) * 100) !important;
}

.row {
	margin: 0;
}
::-webkit-scrollbar {
	width: 0;
	height: 0;
}
a {
	text-decoration: none;
	color: var(--primary-color);
	transition: var(--transition-def);
	-webkit-transition: var(--transition-def);
	-moz-transition: var(--transition-def);
	-ms-transition: var(--transition-def);
	-o-transition: var(--transition-def);
}
a:hover {
	color: var(--primary-hover-color);
}
.card {
	border-radius: var(--br-def);
}
::selection {
	background: var(--secondary-color);
	color: white;
}
::-moz-selection {
	background: var(--secondary-color);
	color: white;
}

/* Buttons */
.btn {
	border: 0 !important;
	box-shadow: none !important;
	outline: 0 !important;
	font-weight: 600;
	border-radius: var(--br-def) !important;
	-webkit-border-radius: var(--br-def) !important;
	-moz-border-radius: var(--br-def) !important;
	-ms-border-radius: var(--br-def) !important;
	-o-border-radius: var(--br-def) !important;
}
.btn-primary {
	background-color: var(--primary-color);
	color: white;
}
.btn-primary:hover {
	background-color: var(--primary-hover-color);
	color: white;
}
.btn-secondary {
	background-color: var(--secondary-color);
	color: white;
}
.btn-secondary:hover {
	background-color: var(--secondary-hover-color);
	color: white;
}
.btn-info {
	background-color: var(--info-color);
	color: white;
}
.btn-info:hover {
	background-color: var(--info-hover-color);
	color: white;
}
.btn-light {
	background-color: white;
	color: var(--primary-color);
}
.btn-light:hover {
	background-color: rgb(224, 229, 231);
	color: var(--primary-color);
}
.fade {
	transition: opacity 0.4s linear !important;
}
.show {
	opacity: 1 !important;
}
.hide {
	opacity: 0 !important;
}

/* Forms */
.nostyle-form {
	display: block;
	width: 100%;
	font-size: 1rem;
	font-weight: 400;
	color: #212529;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border-radius: 0 0 10px 10px;
	padding: 0.2rem 0.5rem;
	border: 0 !important;
	outline: 0 !important;
	background-color: #ffffff75 !important;
}
.nostyle-form-box {
	border: 1px solid rgba(214, 214, 214, 0.514);
	background-color: #ffffff75;
	border-radius: var(--br-def);
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
	transition: background-color 5000s ease-in-out 0s;
}
.form-control {
	border-radius: var(--br-def);
}

/* Navbar */
label {
	cursor: pointer;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

/* General Backgrounds */
.bg-trans {
	background-color: transparent;
}
.bg-alt {
	background-color: var(--page-bg-color-alt) !important;
}
.bg-primary {
	background-color: var(--primary-color) !important;
}
.bg-secondary {
	background-color: var(--secondary-color) !important;
}
.bg-info {
	background-color: var(--info-color) !important;
}
.bg-grey {
	background-color: #f3f3f3;
}

/* General Text Formatting */
.text-trans {
	color: #ffffffaf;
}
.hero-title {
	font-size: 5rem;
	color: white;
	padding: 4rem 5vw 2rem 5vw;
}
.text-primary {
	color: var(--primary-color) !important;
}
.text-secondary {
	color: var(--secondary-color) !important;
}
.text-info {
	color: var(--info-color) !important;
}
.fw-100 {
	font-weight: 100 !important;
}
.fw-200 {
	font-weight: 200 !important;
}
.fw-300 {
	font-weight: 300 !important;
}
.fw-400 {
	font-weight: 400 !important;
}
.fw-500 {
	font-weight: 500 !important;
}
.fw-600 {
	font-weight: 600 !important;
}
.fw-700 {
	font-weight: 700 !important;
}
.fw-800 {
	font-weight: 800 !important;
}
.fw-900 {
	font-weight: 900;
}
.fs-xs {
	font-size: 0.8rem;
}
.fs-sm {
	font-size: 0.9rem;
}


/* 404 Page */
.title-404 {
	font-size: calc(1.2rem + 3vw);
}
.links-404 {
	list-style: none;
	font-size: calc(1.2rem + 0.5vw);
	font-weight: 800;
	padding: 0;
}
.links-404 li {
	margin: 0 1.5rem 0 0;
}
.links-404 a {
	color: white;
}
.links-404 a:hover {
	color: #ffffffb2;
}

/* Gallery */
.galpreview {
	overflow: hidden;
	height: 10rem;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

/* Contact Page */
.contact-form .form-control {
	border: 0 !important;
	outline: 0 !important;
	box-shadow: none !important;
	padding: 0;
}
.contact-form h6 {
	user-select: none;
}
.contact-form {
	border: 1px solid #00000017;
	border-radius: var(--br-def);
	padding: 0.5rem 1.2rem;
	outline: 3px solid white;
	-webkit-border-radius: var(--br-def);
	-moz-border-radius: var(--br-def);
	-ms-border-radius: var(--br-def);
	-o-border-radius: var(--br-def);
}
.form-control:focus ~ .contact-form {
	outline-color: var(--secondary-color);
}

/* Marquee */
.marquee {
	position: relative;
	display: flex;
	overflow: hidden;
	user-select: none;
	padding: 1rem 0;
}
.marquee.websites {
	padding: 0 0 8rem 0;
	max-width: 40rem;
	margin: auto;
}
.marquee.projects {
	padding: 1rem 0 1.75rem 0;
	background-color: var(--page-bg-color);
	border-bottom: 1px solid rgba(var(--page-bg-color-alt-rgb), 0.1);
	font-family: var(--secondary-font);
}
.marquee.projects li {
	font-size: 5rem;
	line-height: 5rem;
	font-weight: 900;
}
.marquee.websites::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	width: 5rem;
	background: linear-gradient(-90deg, var(--page-bg-color) 0%, #ffffff00 100%);
	z-index: +1;
}
.marquee.websites::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 5rem;
	background: linear-gradient(90deg, var(--page-bg-color) 0%, #ffffff00 100%);
	z-index: +1;
}
.marquee.websites li {
	padding: 0 1.5rem;
	font-size: 1.2rem;
	line-height: 1.1rem;
	color: rgba(var(--page-text-color-rgb), 0.8);
	text-transform: uppercase;
	font-family: var(--me-font);
	font-weight: 600;
}
.projects .marquee {
	border-bottom: 1px solid rgba(var(--page-text-color-rgb), 0.2);
}
.marquee li {
	padding: 0 1.5rem;
	font-size: 3rem;
	color: var(--primary-color);
	text-transform: uppercase;
	font-weight: 800;
}
.marquee-content {
	flex-shrink: 0;
	display: flex;
	justify-content: space-around;
	align-items: center;
	width: auto;
	list-style: none;
	text-align: center;
	margin: 0;
	padding: 0;
}
@keyframes scroll {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-100%);
	}
}
@media (prefers-reduced-motion: reduce) {
	.marquee-content {
		animation-play-state: paused !important;
	}
}
.marquee-content {
	animation: scroll 50s linear infinite;
}
/* Reverse animation */
.marquee-reverse .marquee-content {
	animation-direction: reverse;
}
.marquee-fit-content {
	max-width: fit-content;
}
.marquee-pos-absolute .marquee-content:last-child {
	position: absolute;
	top: 0;
	left: 0;
}
.marquee-pos-absolute .marquee-content:last-child {
	animation-name: scroll-abs;
}
@keyframes scroll-abs {
	from {
		transform: translateX(100%);
	}
	to {
		transform: translateX(0);
	}
}

/* General Page Formatting */
.gradient-bg {
	background-image: url(/images-old/purple-gradient.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	animation: gradient 120s linear infinite;
	-webkit-animation: gradient 120s linear infinite;
	position: relative;
}
body#home {
	--gap: 0rem;

	display: flex;
	flex-direction: column;
	background-color: rgba(var(--page-bg-color-alt-rgb), 1);
}
.page-holder {
	flex-grow: 1;
}
.noise:before {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: "";
	opacity: 0.125;
	z-index: 1500;
	pointer-events: none;
	background: url(/images-old/noise4.gif);
}
#navTop {
	position: fixed;
	left: calc((var(--nav-width) + 6rem) * -1);
	top: 0;
	bottom: 0;
	color: var(--nav-text-color);
	z-index: 1050;
	transition: 2s;
	-webkit-transition: 2s;
	-moz-transition: 2s;
	-ms-transition: 2s;
	-o-transition: 2s;
}
.loaded #navTop {
	left: 0;
}
.nav-content {
	height: 100%;
	width: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.nav-open {
	width: 20%;
	display: flex;
	align-items: center;
	justify-content: start;
}
.nav-me {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	/* overflow: hidden; */
}
.nav-goomby {
	width: var(--nav-width);
	position: absolute;
	top: calc((var(--nav-width) / 1.5) * -1);
}
.nav-bean {
	width: var(--nav-width);
	position: absolute;
	bottom: calc(var(--nav-width) * -0.5);
	right: calc((var(--nav-width) / 1.5) * -1);
	z-index: +1;
}
.nav-boongy {
	width: var(--nav-width);
	position: absolute;
	bottom: calc(var(--nav-width) * -1);
}
.nav-name {
	background-color: black;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	font-family: var(--me-font);
	font-weight: 600;
	text-transform: lowercase;
	text-wrap: nowrap;
	writing-mode: vertical-lr;
	-webkit-writing-mode: vertical-lr;
	-ms-writing-mode: vertical-lr;
	transform: rotate(180deg);
	padding: 1rem 0;
	font-size: 1.05rem;
	-webkit-transform: rotate(180deg);
	-moz-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	-o-transform: rotate(180deg);
	border-radius: var(--br-def) 0 0 0;
	-webkit-border-radius: var(--br-def) 0 0 0;
	-moz-border-radius: var(--br-def) 0 0 0;
	-ms-border-radius: var(--br-def) 0 0 0;
	-o-border-radius: var(--br-def) 0 0 0;
}
#navTop h4 {
	margin: 0;
	font-family: var(--me-font);
}
.nav-socials {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: end;
	background-color: black;
	width: var(--nav-width);
	margin-top: 1rem;
	font-size: 1rem;
	padding: 0.5rem 0;
	border-radius: 0 var(--br-def) var(--br-def) 0;
	-webkit-border-radius: 0 var(--br-def) var(--br-def) 0;
	-moz-border-radius: 0 var(--br-def) var(--br-def) 0;
	-ms-border-radius: 0 var(--br-def) var(--br-def) 0;
	-o-border-radius: 0 var(--br-def) var(--br-def) 0;
}
.full-page {
	min-height: 100vh;
	position: relative;
}

.SmoothScroll {
	position: fixed;
	width: 100%;
  }
.nav-button button {
	padding: 0;
	margin: 0.5rem;
	background-color: transparent !important;
	border: 0 !important;
	outline: 0 !important;
	color: var(--nav-text-color);
	transition: var(--transition-def);
	-webkit-transition: var(--transition-def);
	-moz-transition: var(--transition-def);
	-ms-transition: var(--transition-def);
	-o-transition: var(--transition-def);
}
.nav-button button:hover {
	color: var(--nav-text-hover-color);
}
.nav-profile {
	width: 3.5rem;
	height: 3.5rem;
	object-fit: cover;
	object-position: center;
	border-radius: 0 var(--br-def) 0 0;
	-webkit-border-radius: 0 var(--br-def) 0 0;
	-moz-border-radius: 0 var(--br-def) 0 0;
	-ms-border-radius: 0 var(--br-def) 0 0;
	-o-border-radius: 0 var(--br-def) 0 0;
}
.page-grid {
	overflow-x: hidden;
}
.grid-block.intro {
	position: relative;
	height: 100vh;
	overflow: hidden;
	--video-color: white;
	z-index: -2;
}
@keyframes gradient {
	0% {
		background-position: 50% 100%;
    background-size: calc(100vh + 100vw);
	}
	25% {
		background-position: 25% 50%;
    background-size: calc(175vh + 120vw);
	}
	50% {
		background-position: 100% 0%;
    background-size: calc(130vh + 105vw);
	}
	75% {
		background-position: 50% 25%;
    background-size: calc(105vh + 110vw);
	}
	100% {
		background-position: 50% 100%;
    background-size: calc(100vh + 100vw);
	}
}
.grid-block.projects {
	background-color: var(--page-bg-color);
	padding: 0 var(--nav-width);
}
.grid-block.bio-skills {
	min-width: 100%;
	background-color: var(--page-bg-color-alt);
	color: var(--page-text-color-alt);
	position: relative;
	display: flex;
	flex-wrap: wrap;
}
.grid-block.bio-skills .title {
	padding: 3rem calc(var(--nav-width) + 2rem) 1rem calc(var(--nav-width) + 2rem);
	border-bottom: 1px solid rgba(var(--page-bg-color-rgb), 0.4);
	margin-bottom: 4rem;
	font-family: var(--secondary-font);
	text-transform: uppercase;
}
.grid-block.bio-skills .title p {
	margin: 0;
	font-size: 3rem;
}
.grid-block .bio {
	width: 40rem;
	max-width: 100%;
	flex-grow: 1;
	border-right: 1px solid rgba(var(--page-bg-color-rgb), 0.4);
}
.grid-block .skills {
	width: 40rem;
	max-width: 100%;
}
.grid-block .education {
	width: 40rem;
	max-width: 100%;
	border-right: 1px solid rgba(var(--page-bg-color-rgb), 0.4);
}
.grid-block .experience {
	width: 40rem;
	max-width: 100%;
	flex-grow: 1;
}
.grid-block.contact {
	padding: 10rem var(--nav-width);
	background-color: var(--primary-color);
	color: var(--page-text-color);
	display: flex;
	align-items: center;
	justify-content: center;
	border-top: 1px solid rgba(var(--page-bg-color-rgb), 0.4);
}
.grid-block.contact.gradient-bg {
	background-image: url(/images-old/purple-gradient3.jpg);
}
.grid-block.contact h4 {
	font-size: 7vw;
	font-family: var(--secondary-font);
	text-transform: uppercase;
	font-weight: 900;
}
.grid-block.contact a {
	color: var(--page-bg-color);
}
.grid-block.contact a:hover {
	color: var(--secondary-color);
}
.img-bar {
	background-color: var(--primary-color);
	width: 100%;
	height: 15rem;
}
.img-bar.gradient-bg {
	background-image: url(/images-old/purple-gradient2.jpg);
}

.grid-block .text-item {
	padding: 0 calc(var(--nav-width) + 2rem);
	font-size: 2rem;
	line-height: 1.8rem;
	font-family: var(--secondary-font);
}
.grid-block .text-item-sub {
	padding: 0 calc(var(--nav-width) + 2rem);
	color: var(--info-color);
	font-size: 1.5rem;
	line-height: 1.5rem;
	font-family: var(--me-font);
}

.intro-text {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: +1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: var(--video-color);
}
.intro-logo {
	position: absolute;
	z-index: +1;
	top: 1rem;
	left: 1rem;
	width: 5rem;
}
.intro-logo img {
	max-width: 100%;
	filter: invert(100%);
	-webkit-filter: invert(100%);
}
.intro-text .main-text {
	border-top: 2px solid var(--video-color);
	border-bottom: 2px solid var(--video-color);
	padding: 0 0 1.5vw 0;
	opacity: 0;
	transition: 5s;
	-webkit-transition: 5s;
	-moz-transition: 5s;
	-ms-transition: 5s;
	-o-transition: 5s;
}
.loaded .intro-text .main-text {
	opacity: 1;
}
.intro-text .main-text h1 {
	margin: 0;
	font-size: 10vw;
	line-height: 10vw;
	font-weight: 900;
	text-transform: uppercase;
	text-align: center;
	font-family: var(--secondary-font);
}
.intro-text .sub-text {
	padding: 1.2rem 0;
	font-family: var(--secondary-font);
	opacity: 0;
	transition: 4s;
	-webkit-transition: 4s;
	-moz-transition: 4s;
	-ms-transition: 4s;
	-o-transition: 4s;
	transition-delay: 1s;
}
.loaded .intro-text .sub-text {
	opacity: 1;
}
.intro-text .sub-text h3 {
	margin: 0;
	font-size: 5vw;
	line-height: 5vw;
	text-transform: uppercase;
	text-align: center;
}
.scroll-indicator {
	z-index: +1;
	position: absolute;
	bottom: 1rem;
	right: 1rem;
	left: 1rem;
	color: var(--video-color);
	text-align: center;
	opacity: 0;
	transition: 4s;
	-webkit-transition: 4s;
	-moz-transition: 4s;
	-ms-transition: 4s;
	-o-transition: 4s;
	transition-delay: 1s;
}
.loaded .scroll-indicator {
	opacity: 1;
}
.scroll-indicator p {
	font-family: var(--me-font);
	margin: 0;
	font-size: 1.2rem;
}

.website-block {
	height: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 5rem 1.25rem;
}
.website-block a {
	width: 25vw;
	margin: 3rem 1.5vw;
}
.website-block a .website-container {
	width: 100%;
}
.website-block .website-container img {
	width: 100%;
	transition: 0.4s;
	-webkit-transition: 0.4s;
	-moz-transition: 0.4s;
	-ms-transition: 0.4s;
	-o-transition: 0.4s;
}
.website-block .website-container:hover img {
	transform: scale(1.02);
	-webkit-transform: scale(1.02);
	-moz-transform: scale(1.02);
	-ms-transform: scale(1.02);
	-o-transform: scale(1.02);
}
.website-block .website-container p {
	margin: 0;
}
.website-block .website-container .website-name {
	font-family: var(--secondary-font);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--page-text-color);
}
.website-block .website-container .website-jobs {
	font-family: var(--me-font);
	font-size: 1rem;
	font-weight: 400;
	color: rgba(var(--page-text-color-rgb), 0.7);
}
.website-block .website-container .website-source {
	font-family: var(--primary-font);
	font-size: 0.9rem;
	font-weight: 400;
	color: rgba(var(--page-text-color-rgb), 0.5);
}
.website-block .website-container .website-featured {
	font-family: var(--primary-font);
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--primary-color);
}

@media (max-width: 1279px) {
	.grid-block.bio-skills .title {
		border-bottom: 0;
		margin-bottom: 1rem;
		text-decoration: underline;
	}
	.grid-block .bio {
		width: 40rem;
		border-right: 0;
		border-bottom: 1px solid rgba(var(--page-bg-color-rgb), 0.4);
	}
	.grid-block .education {
		width: 100%;
		border-right: 0;
		border-bottom: 1px solid rgba(var(--page-bg-color-rgb), 0.4);
	}
	.website-block a {
		width: 100%;
		margin: 3rem 1.5vw;
	}
}
@media (max-width: 500px) {
	#navTop {
		position: fixed;
		left: -20rem;
		top: 0;
		right: 0;
		bottom: unset;
		color: var(--nav-text-color);
		z-index: 1050;
	}
	.nav-me {
		flex-direction: row;
	}
	.nav-profile {
		border-radius: 0;
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		-ms-border-radius: 0;
		-o-border-radius: 0;
}
	.nav-name {
		width: auto;
		height: 3.5rem;
		writing-mode:horizontal-tb;
		-webkit-writing-mode:horizontal-tb;
		-ms-writing-mode:horizontal-tb;
		transform: rotate(0deg);
		padding: 0.2rem 0.8rem;
		font-size: 1.05rem;
		-webkit-transform: rotate(0deg);
		-moz-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		border-radius: 0 0 var(--br-def) 0;
		-webkit-border-radius: 0 0 var(--br-def) 0;
		-moz-border-radius: 0 0 var(--br-def) 0;
		-ms-border-radius: 0 0 var(--br-def) 0;
		-o-border-radius: 0 0 var(--br-def) 0;
}
	.nav-bean {
		width: 3.5rem;
		bottom: 2rem;
		right: -9rem;
	}
	.nav-socials {
		width: 8rem;
		flex-direction: row;
		justify-content: center;
		margin-top: 0.5rem;
		font-size: 1rem;
		padding: 0.25rem 0;
	}
	.grid-block.projects {
		padding: 0 1rem;
	}
	.grid-block.bio-skills .title {
		padding: 3rem 1.5rem 1rem 1.5rem;
	}
	.grid-block.contact {
		padding: 10rem 1rem;
	}
	.grid-block .text-item {
		padding: 0 1.5rem;
	}
	.grid-block .text-item-sub {
		padding: 0 1.5rem;
	}
	
	.intro-text .main-text {
		border-top: 0;
		border-bottom: 0;
		padding: 0 0 1rem 0;
		opacity: 0;
	}
	.intro-text .main-text h1 {
		font-size: 25vw;
		line-height: 25vw;
	}
	.intro-text .sub-text {
		padding: 1.2rem 0;
	}
	.intro-text .sub-text h3 {
		font-size: 8.5vw;
		line-height: 8.5vw;
	}
	.scroll-indicator {
		bottom: 5rem;
	}
}