@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@400;500;600;700&display=swap');

/* #region Fonts */
.font-regular
{
	font-family: Montserrat, sans-serif;
	font-style: normal;
	font-weight: 400;
}

.font-medium
{
	font-family: Montserrat, sans-serif;
	font-style: normal;
	font-weight: 500;
}

.font-semibold
{
	font-family: Montserrat, sans-serif;
	font-style: normal;
	font-weight: 600;
}

.font-bold
{
	font-family: Montserrat, sans-serif;
	font-style: normal;
	font-weight: 700;
}
/* #endregion */

:root
{
	--clr-dark: #101012;
	--clr-accent: #EA80FF;
	--blur-bg: 25px;
	--main-border-radius: 20px;
	--second-border-radius: 30px;
	--main-font-size: 16px;
}

*, *::before, *::after
{
	user-select: none;
	-moz-user-select: none;
	-khtml-user-select: none;
	-webkit-user-select: none;
	pointer-events: none;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	font-family: Montserrat, sans-serif;
	font-size: var(--main-font-size);
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	color: white;
	position: relative;
	interpolate-size: allow-keywords;
}

*:not(path) { transition: all 0.2s; }
svg { transition: all 0.2s !important; }

h1, h2, h3, h4, h5, h6, p, a, .text-inner-span { white-space: pre; }

/* #region Scroll */
.element-not-in-scroll
{
	opacity: 0;
	transform: translateY(50%);
	transition: all 0.2s, opacity 2s, transform 1s !important;
}

.element-in-scroll
{
	opacity: unset;
	transform: translateY(0%);
}

.sections-container
{
	min-height: 100vh;
	background-color: var(--clr-dark);

	--temp1: color-mix(in srgb, var(--clr-accent) 80%, var(--clr-dark)) 25%;
	--temp2: color-mix(in srgb, var(--clr-accent) 15%, var(--clr-dark)) 75%;
	--temp3: color-mix(in srgb, var(--clr-accent) 6%, var(--clr-dark)) 85%;
	--temp4: color-mix(in srgb, var(--clr-accent) 3%, var(--clr-dark)) 90%;
	--temp5: color-mix(in srgb, var(--clr-accent) 1%, var(--clr-dark)) 95%;

	background: radial-gradient(55vw 55vw at calc(100% - 55vw * 0.5) calc(55vw * -0.5), var(--clr-accent), var(--temp1), var(--temp2), var(--temp3), var(--temp4), var(--temp5), var(--clr-dark)) no-repeat,
		radial-gradient(55vw 55vw at calc(55vw * -0.5) 1500px, var(--clr-accent), var(--temp1), var(--temp2), var(--temp3), var(--temp4), var(--temp5), var(--clr-dark)) no-repeat,
		radial-gradient(55vw 55vw at calc(100% + 55vw * 0.5) 2700px, var(--clr-accent), var(--temp1), var(--temp2), var(--temp3), var(--temp4), var(--temp5), var(--clr-dark)) no-repeat,
		radial-gradient(55vw 55vw at calc(55vw * -0.5) 4000px, var(--clr-accent), var(--temp1), var(--temp2), var(--temp3), var(--temp4), var(--temp5), var(--clr-dark)) no-repeat;
	background-blend-mode: lighten;
}

@media (min-width: 1024px)
{
.sections-container::before
{
	content: '';
	position: absolute;
	inset: 0;
	background: url('../images/noise.jpg');
	background-size: 256px;
	opacity: 0.05;
}
}
/* #endregion */

/* #region Containers */
.sections-container
{
	display: block;
	width: 100%;
	height: 100%;
}

section
{
	display: block;
	width: 100%;
	height: fit-content;
	margin-bottom: 150px;
}

.sections-container section:last-of-type { margin-bottom: 0; }
/* #endregion */

/* #region Text */
.text-inner-span
{
	display: inline-block;
	width: fit-content;
	height: fit-content;
	color: inherit;
	background: inherit;
	background-clip: inherit;
	transition: inherit;
	pointer-events: inherit;
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	backdrop-filter: inherit;
	line-height: inherit;
}

.text-inner-link
{
	font-weight: 400;
	pointer-events: all;
	color: color-mix(in srgb, var(--clr-accent) 50%, transparent);
	text-shadow: 0 0 20px color-mix(in srgb, var(--clr-accent) 0%, transparent);
}

.text-inner-link:hover
{
	color: color-mix(in srgb, var(--clr-accent) 75%, white 15%);
	text-shadow: 0 0 40px color-mix(in srgb, var(--clr-accent) 90%, white 10%);
}

.text-inner-link:active
{
	color: color-mix(in srgb, var(--clr-accent) 35%, white 10%);
	text-shadow: 0 0 30px color-mix(in srgb, var(--clr-accent) 25%, transparent);
}

.text-gradient
{
	color: transparent;
	background: radial-gradient(65% 150% at 65% 25%,
		rgba(255, 255, 255, 0.25) 20%,
		rgba(255, 255, 255, 0.85) 45%,
		rgba(255, 255, 255, 0.85) 55%,
		rgba(255, 255, 255, 0.25) 80%);
	background-clip: text;
}

.text-semitransparent
{
	color: rgba(255, 255, 255, 0.35);
	background: none;
}

.text-almostwhite
{
	color: rgba(255, 255, 255, 0.75);
	background: none;
}

.text-subtext-in-item
{
	width: fit-content;
	height: fit-content;
	font-size: calc(var(--main-font-size) * 0.875);
}

.text-header-in-item
{
	width: fit-content;
	height: fit-content;
	font-size: var(--main-font-size);
}
/* #endregion */

/* #region Button */
.button
{
	max-width: fit-content;
	width: 180px;
	height: 50px;
	padding: 0 26px;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: center;
	gap: 10px;
	white-space: unset;
	border-radius: var(--main-border-radius);
	background: rgba(255, 255, 255, 0.05);
	border: 2px solid rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(var(--blur-bg));
	box-shadow: 0 8px 50px 0 transparent;
}

.button * { pointer-events: none; }

.button > svg
{
	max-width: 20px;
	max-height: 35%;
	flex-shrink: 0;
	fill: rgba(255, 255, 255, 0.5);
}

.button > svg:last-of-type { width: 0; opacity: 0; margin-right: -10px; }

.button > .text-inner-span
{
	color: rgba(255, 255, 255, 0.5);
	background: unset;
	backdrop-filter: unset;
}

.button:hover
{
	background: var(--clr-accent);
	border: 2px solid transparent;
	box-shadow: 0 16px 100px 4px color-mix(in srgb, var(--clr-accent) 50%, transparent);
}

.button:hover > svg { fill: rgba(0, 0, 0, 0.65); }
.button:hover > .text-inner-span { color: rgba(0, 0, 0, 0.65); }

.button:hover > svg:first-of-type, .button:active > svg:first-of-type { max-width: 0; opacity: 0; margin-left: -10px; }
.button:hover > svg:last-of-type, .button:active > svg:last-of-type { width: unset; opacity: unset; margin-right: unset; }

.button:active
{
	background: color-mix(in srgb, var(--clr-accent) 40%, transparent);
	border: 2px solid color-mix(in srgb, rgba(255, 255, 255, 0.75), var(--clr-accent));
	box-shadow: 0 16px 100px -4px color-mix(in srgb, var(--clr-accent) 50%, transparent);
}

.button:active > svg { fill: color-mix(in srgb, rgba(255, 255, 255, 0.75), var(--clr-accent)); }
.button:active > .text-inner-span { color: color-mix(in srgb, rgba(255, 255, 255, 0.75), var(--clr-accent)); }
/* #endregion */

/* #region Navbar */
navbar
{
	position: fixed;
	top: clamp(10px, 2vw, 200px);
	left: 50%;
	transform: translateX(-50%);
	width: fit-content;
	height: 72px;
	border-radius: var(--second-border-radius);
	background: color-mix(in srgb, var(--clr-dark) 75%, transparent);
	border: 1px solid rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(var(--blur-bg));
	box-shadow: 0 16px 64px 0 rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: center;
	padding: 10px 32px;
	z-index: 1;
	pointer-events: all;
	transition: all 0.2s, gap 0.5s, margin 0.5s, padding 0.5s !important;
}

navbar:not(.navbar-with-button) { gap: 0px; }
navbar > .button { transition: all 0.2s, width 0.5s, transform 0.5s, opacity 0.5s !important; }

navbar:not(.navbar-with-button) > .button
{
	width: 0;
	padding: 0;
	border: 0px solid transparent;
	opacity: 0;
	display: flex;
	transform: scale(0.5);
}

navbar:not(.navbar-with-button) > .navbar-link { margin-right: 32px; }
navbar:not(.navbar-with-button) > .navbar-link:nth-last-child(2) { margin-right: 0; }

.navbar-with-button
{
	padding-right: 10px;
	gap: 32px;
}

.navbar-with-button > .button
{
	width: 180px;
	opacity: 1;
}

navbar > .navbar-link
{
	width: fit-content;
	height: 24px;
	color: rgba(255, 255, 255, 0.35);
	overflow: clip;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: flex-start;
}

navbar > .navbar-link-current { color: rgba(255, 255, 255, 0.75); }
navbar > .navbar-link .text-inner-span
{
	line-height: 24px;
	transition: all 0.2s, transform 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

navbar > .navbar-link:hover .text-inner-span
{
	color: rgba(255, 255, 255, 0.9);
	transform: translateY(-100%);
}

navbar > .navbar-link:active .text-inner-span { color: rgba(255, 255, 255, 0.25); }
/* #endregion */

.noise-on-hover
{
	position: absolute;
	inset: -2px;
	border-radius: inherit;
	background: url('../images/noise.png');
	background-size: 256px;
	mask-image: radial-gradient(300px 300px at center, white, transparent);
	opacity: 0;
	mix-blend-mode: plus-lighter;
}

[data-noise-on-hover].button:active .noise-on-hover, [data-noise-on-hover].project-item:active .noise-on-hover { opacity: 0 !important; }

html
{
	width: fit-content;
	height: fit-content;
	min-width: 100svw;
	min-height: 100svh;
	margin: 0;
	padding: 0;
	scroll-behavior: smooth;
	overflow: clip auto;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, 0.35) var(--clr-dark);
	scrollbar-gutter: stable;
}

body
{
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	overflow: clip;
}

a
{
	pointer-events: all;
	text-decoration: none;
}

a:hover { cursor: pointer; }