*,
:after,
:before {
	--tw-border-spacing-x: 0;
	--tw-border-spacing-y: 0;
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	--tw-pan-x: ;
	--tw-pan-y: ;
	--tw-pinch-zoom: ;
	--tw-scroll-snap-strictness: proximity;
	--tw-gradient-from-position: ;
	--tw-gradient-via-position: ;
	--tw-gradient-to-position: ;
	--tw-ordinal: ;
	--tw-slashed-zero: ;
	--tw-numeric-figure: ;
	--tw-numeric-spacing: ;
	--tw-numeric-fraction: ;
	--tw-ring-inset: ;
	--tw-ring-offset-width: 0px;
	--tw-ring-offset-color: #fff;
	--tw-ring-color: rgba(59, 130, 246, 0.5);
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
	--tw-shadow: 0 0 #0000;
	--tw-shadow-colored: 0 0 #0000;
	--tw-blur: ;
	--tw-brightness: ;
	--tw-contrast: ;
	--tw-grayscale: ;
	--tw-hue-rotate: ;
	--tw-invert: ;
	--tw-saturate: ;
	--tw-sepia: ;
	--tw-drop-shadow: ;
	--tw-backdrop-blur: ;
	--tw-backdrop-brightness: ;
	--tw-backdrop-contrast: ;
	--tw-backdrop-grayscale: ;
	--tw-backdrop-hue-rotate: ;
	--tw-backdrop-invert: ;
	--tw-backdrop-opacity: ;
	--tw-backdrop-saturate: ;
	--tw-backdrop-sepia: ;
	--tw-contain-size: ;
	--tw-contain-layout: ;
	--tw-contain-paint: ;
	--tw-contain-style: ;
}
::backdrop {
	--tw-border-spacing-x: 0;
	--tw-border-spacing-y: 0;
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	--tw-pan-x: ;
	--tw-pan-y: ;
	--tw-pinch-zoom: ;
	--tw-scroll-snap-strictness: proximity;
	--tw-gradient-from-position: ;
	--tw-gradient-via-position: ;
	--tw-gradient-to-position: ;
	--tw-ordinal: ;
	--tw-slashed-zero: ;
	--tw-numeric-figure: ;
	--tw-numeric-spacing: ;
	--tw-numeric-fraction: ;
	--tw-ring-inset: ;
	--tw-ring-offset-width: 0px;
	--tw-ring-offset-color: #fff;
	--tw-ring-color: rgba(59, 130, 246, 0.5);
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
	--tw-shadow: 0 0 #0000;
	--tw-shadow-colored: 0 0 #0000;
	--tw-blur: ;
	--tw-brightness: ;
	--tw-contrast: ;
	--tw-grayscale: ;
	--tw-hue-rotate: ;
	--tw-invert: ;
	--tw-saturate: ;
	--tw-sepia: ;
	--tw-drop-shadow: ;
	--tw-backdrop-blur: ;
	--tw-backdrop-brightness: ;
	--tw-backdrop-contrast: ;
	--tw-backdrop-grayscale: ;
	--tw-backdrop-hue-rotate: ;
	--tw-backdrop-invert: ;
	--tw-backdrop-opacity: ;
	--tw-backdrop-saturate: ;
	--tw-backdrop-sepia: ;
	--tw-contain-size: ;
	--tw-contain-layout: ;
	--tw-contain-paint: ;
	--tw-contain-style: ;
} /*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/
*,
:after,
:before {
	box-sizing: border-box;
	border: 0 solid #e5e7eb;
}
:after,
:before {
	--tw-content: "";
}
:host,
html {
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
	-moz-tab-size: 4;
	-o-tab-size: 4;
	tab-size: 4;
	font-family: Arial, Helvetica, sans-serif;
	font-feature-settings: normal;
	font-variation-settings: normal;
	-webkit-tap-highlight-color: transparent;
}
body {
	margin: 0;
	line-height: inherit;
}
hr {
	height: 0;
	color: inherit;
	border-top-width: 1px;
}
abbr:where([title]) {
	-webkit-text-decoration: underline dotted;
	text-decoration: underline dotted;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	font-weight: inherit;
}
a {
	color: inherit;
	text-decoration: inherit;
}
b,
strong {
	font-weight: bolder;
}
code,
kbd,
pre,
samp {
	font-family:
		ui-monospace,
		SFMono-Regular,
		Menlo,
		Monaco,
		Consolas,
		Liberation Mono,
		Courier New,
		monospace;
	font-feature-settings: normal;
	font-variation-settings: normal;
	font-size: 1em;
}
small {
	font-size: 80%;
}
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}
sub {
	bottom: -0.25em;
}
sup {
	top: -0.5em;
}
table {
	text-indent: 0;
	border-color: inherit;
	border-collapse: collapse;
}
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-feature-settings: inherit;
	font-variation-settings: inherit;
	font-size: 100%;
	font-weight: inherit;
	line-height: inherit;
	letter-spacing: inherit;
	color: inherit;
	margin: 0;
	padding: 0;
}
button,
select {
	text-transform: none;
}
button,
input:where([type="button"]),
input:where([type="reset"]),
input:where([type="submit"]) {
	-webkit-appearance: button;
	background-color: transparent;
	background-image: none;
}
:-moz-focusring {
	outline: auto;
}
:-moz-ui-invalid {
	box-shadow: none;
}
progress {
	vertical-align: baseline;
}
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
	height: auto;
}
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}
::-webkit-search-decoration {
	-webkit-appearance: none;
}
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}
summary {
	display: list-item;
}
blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
	margin: 0;
}
fieldset {
	margin: 0;
}
fieldset,
legend {
	padding: 0;
}
menu,
ol,
ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
dialog {
	padding: 0;
}
textarea {
	resize: vertical;
}
input::-moz-placeholder,
textarea::-moz-placeholder {
	opacity: 1;
	color: #9ca3af;
}
input::placeholder,
textarea::placeholder {
	opacity: 1;
	color: #9ca3af;
}
[role="button"],
button {
	cursor: pointer;
}
:disabled {
	cursor: default;
}
audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
	display: block;
	vertical-align: middle;
}
img,
video {
	max-width: 100%;
	height: auto;
}
[hidden]:where(:not([hidden="until-found"])) {
	display: none;
}
body {
	cursor:
		url(../img/cursors/cursor.png) 16 16,
		auto;
}
*,
body {
	margin: 0;
	padding: 0;
	font-family: Arial, Helvetica, sans-serif;
}
a {
	--tw-text-opacity: 1;
	color: rgb(0 0 0 / var(--tw-text-opacity, 1));
	text-decoration-line: none;
}
a:hover {
	cursor:
		url(../img/cursors/cursor-eyes.png) 16 16,
		pointer;
}
.container {
	width: 100%;
}
@media (min-width: 640px) {
	.container {
		max-width: 640px;
	}
}
@media (min-width: 768px) {
	.container {
		max-width: 768px;
	}
}
@media (min-width: 1024px) {
	.container {
		max-width: 1024px;
	}
}
@media (min-width: 1280px) {
	.container {
		max-width: 1280px;
	}
}
@media (min-width: 1536px) {
	.container {
		max-width: 1536px;
	}
}
.heading-primary {
	font-size: 48px;
	font-weight: 400;
	line-height: 68px;
	letter-spacing: 14px;
}
.box {
	padding-top: 1.5rem;
}
@media (max-width: 670px) {
	.heading-primary {
		font-size: 30px;
		line-height: 50px;
		letter-spacing: 4px;
	}
}
.cursor-eyes {
	cursor:
		url(../img/cursors/cursor-eyes.png) 16 16,
		auto;
}
.cursor-projects,
a.cursor-projects:hover {
	cursor:
		url(../img/cursors/cursor-projects.png) 16 16,
		auto;
}
.cursor-about,
a.cursor-about:hover {
	cursor:
		url(../img/cursors/cursor-about.png) 16 16,
		auto;
}
.cursor-contact,
a.cursor-contact:hover {
	cursor:
		url(../img/cursors/cursor-contact.png) 16 16,
		auto;
}
.marquee {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	overflow: hidden;
	pointer-events: auto;
}
.marquee,
.marquee * {
	cursor: inherit;
}
.marquee__inner {
	position: relative;
	display: flex;
	width: -moz-fit-content;
	width: fit-content;
	--offset: 1rem;
	--move-initial: calc(-25% + var(--offset));
	--move-final: calc(-50% + var(--offset));
	transform: translate3d(var(--move-initial), 0, 0);
	animation: marquee 1s linear infinite;
	animation-play-state: paused;
	opacity: 0;
}
.runningbutton:hover .marquee__inner {
	animation-play-state: running;
	opacity: 1;
	transition-duration: 0.4s;
}
.runningbutton:hover > span:first-child {
	visibility: hidden;
}
.marquee span {
	white-space: nowrap;
	text-align: center;
	font-style: italic;
}
@keyframes marquee {
	0% {
		transform: translate3d(var(--move-initial), 0, 0);
	}
	to {
		transform: translate3d(var(--move-final), 0, 0);
	}
}
.runningbutton {
	pointer-events: auto;
	position: relative;
	margin: 0;
	display: inline-block;
	border-style: none;
	--tw-bg-opacity: 1;
	background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
	font-family: Arial, Helvetica, sans-serif;
	text-transform: uppercase;
	font-size: 48px;
	line-height: 68px;
	letter-spacing: 14px;
	cursor: inherit;
}
@media (max-width: 670px) {
	.runningbutton {
		font-size: 30px;
		line-height: 50px;
		letter-spacing: 4px;
	}
}
.card-table {
	width: 100%;
	border-width: 2px;
	--tw-border-opacity: 1;
	border-color: rgb(0 0 0 / var(--tw-border-opacity, 1));
}
.card-table:hover {
	--tw-shadow: 6px 6px 0 #000;
	--tw-shadow-colored: 6px 6px 0 var(--tw-shadow-color);
	box-shadow:
		var(--tw-ring-offset-shadow, 0 0 #0000),
		var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	transition-property: all;
	transition-duration: 0.2s;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.card-hair {
	margin-top: -30px;
}
.card-hair--hover {
	margin-top: -33px;
}
@supports (-moz-appearance: none) {
	.card-hair {
		margin-top: -27px;
	}
	.card-hair--hover {
		margin-top: -32px;
	}
}
.scrollable-content {
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: #212121 #fff;
}
.scrollable-content::-webkit-scrollbar {
	width: 6px;
	height: 6px;
}
.scrollable-content::-webkit-scrollbar-track {
	background: #fff;
}
.scrollable-content::-webkit-scrollbar-thumb {
	background-color: #212121;
	border: 0 solid #fff;
}
.lose {
	background-image: url(../img/cursors/lose.png);
}
.lose,
.win {
	width: 52px;
	background-size: contain;
	background-size: 200%;
	background-position: 50%;
	background-repeat: no-repeat;
}
.win {
	background-image: url(../img/cursors/win.png);
}
.shimmer {
	display: inline-block;
	max-width: 200px;
	font-size: 50px;
	--tw-text-opacity: 1;
	color: rgb(156 163 175 / var(--tw-text-opacity, 1));
	-webkit-mask: linear-gradient(-60deg, #000 30%, #0005, #000 70%) right/500%
		100%;
	background-repeat: no-repeat;
	animation: shimmer 1.5s;
}
@keyframes shimmer {
	to {
		-webkit-mask-position: left;
	}
}
#primary-menu {
	width: 100%;
}
#primary-menu li {
	margin: 0 0 0.5rem;
	height: 108px;
	list-style-type: none;
	border-width: 2px;
	--tw-border-opacity: 1;
	border-color: rgb(0 0 0 / var(--tw-border-opacity, 1));
	padding: 0;
	text-align: center;
	font-weight: 700;
}
#primary-menu a,
#primary-menu li {
	display: flex;
	align-items: center;
	justify-content: center;
}
#primary-menu a {
	height: 100%;
	width: 100%;
}
#primary-menu li:hover {
	--tw-shadow: 6px 6px 0 #000;
	--tw-shadow-colored: 6px 6px 0 var(--tw-shadow-color);
	box-shadow:
		var(--tw-ring-offset-shadow, 0 0 #0000),
		var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	transition-property: all;
	transition-duration: 0.2s;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}
.pointer-events-none {
	pointer-events: none;
}
.visible {
	visibility: visible;
}
.collapse {
	visibility: collapse;
}
.fixed {
	position: fixed;
}
.absolute {
	position: absolute;
}
.relative {
	position: relative;
}
.sticky {
	position: sticky;
}
.bottom-0 {
	bottom: 0;
}
.left-0 {
	left: 0;
}
.right-0 {
	right: 0;
}
.right-\[-10px\] {
	right: -10px;
}
.top-0 {
	top: 0;
}
.z-10 {
	z-index: 10;
}
.mx-0 {
	margin-left: 0;
	margin-right: 0;
}
.my-1 {
	margin-top: 0.25rem;
	margin-bottom: 0.25rem;
}
.-mt-\[27px\] {
	margin-top: -27px;
}
.-mt-\[32px\] {
	margin-top: -32px;
}
.mb-2 {
	margin-bottom: 0.5rem;
}
.mb-4 {
	margin-bottom: 1rem;
}
.mb-6 {
	margin-bottom: 1.5rem;
}
.ml-0 {
	margin-left: 0;
}
.ml-1 {
	margin-left: 0.25rem;
}
.ml-2 {
	margin-left: 0.5rem;
}
.mr-\[6px\] {
	margin-right: 6px;
}
.mt-2 {
	margin-top: 0.5rem;
}
.block {
	display: block;
}
.inline-block {
	display: inline-block;
}
.inline {
	display: inline;
}
.flex {
	display: flex;
}
.grid {
	display: grid;
}
.hidden {
	display: none;
}
.h-\[1em\] {
	height: 1em;
}
.h-\[2px\] {
	height: 2px;
}
.h-\[38px\] {
	height: 38px;
}
.h-\[512px\] {
	height: 512px;
}
.h-auto {
	height: auto;
}
.h-full {
	height: 100%;
}
.max-h-\[72vh\] {
	max-height: 72vh;
}
.w-\[10\%\] {
	width: 10%;
}
.w-\[14px\] {
	width: 14px;
}
.w-\[95\%\] {
	width: 95%;
}
.w-full {
	width: 100%;
}
.min-w-\[256px\] {
	min-width: 256px;
}
.min-w-\[96px\] {
	min-width: 96px;
}
.max-w-\[128px\] {
	max-width: 128px;
}
.max-w-\[512px\] {
	max-width: 512px;
}
.max-w-none {
	max-width: none;
}
.flex-1 {
	flex: 1 1 0%;
}
.transform {
	transform: translate(var(--tw-translate-x), var(--tw-translate-y))
		rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y))
		scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.grid-cols-1 {
	grid-template-columns: repeat(1, minmax(0, 1fr));
}
.flex-col {
	flex-direction: column;
}
.flex-wrap {
	flex-wrap: wrap;
}
.flex-wrap-reverse {
	flex-wrap: wrap-reverse;
}
.items-start {
	align-items: flex-start;
}
.justify-start {
	justify-content: flex-start;
}
.justify-between {
	justify-content: space-between;
}
.gap-4 {
	gap: 1rem;
}
.overflow-hidden {
	overflow: hidden;
}
.overflow-y-auto {
	overflow-y: auto;
}
.overflow-x-hidden {
	overflow-x: hidden;
}
.whitespace-nowrap {
	white-space: nowrap;
}
.break-words {
	overflow-wrap: break-word;
}
.rounded-lg {
	border-radius: 0.5rem;
}
.border {
	border-width: 1px;
}
.border-2 {
	border-width: 2px;
}
.border-4 {
	border-width: 4px;
}
.border-b-2 {
	border-bottom-width: 2px;
}
.border-r-0 {
	border-right-width: 0;
}
.border-t-0 {
	border-top-width: 0;
}
.border-black {
	--tw-border-opacity: 1;
	border-color: rgb(0 0 0 / var(--tw-border-opacity, 1));
}
.bg-black {
	--tw-bg-opacity: 1;
	background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}
.bg-white {
	--tw-bg-opacity: 1;
	background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.object-cover {
	-o-object-fit: cover;
	object-fit: cover;
}
.p-2 {
	padding: 0.5rem;
}
.p-3 {
	padding: 0.75rem;
}
.p-8 {
	padding: 2rem;
}
.px-0 {
	padding-left: 0;
	padding-right: 0;
}
.px-6 {
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}
.py-3 {
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}
.pb-2 {
	padding-bottom: 0.5rem;
}
.pl-2 {
	padding-left: 0.5rem;
}
.pr-4 {
	padding-right: 1rem;
}
.pt-\[13px\] {
	padding-top: 13px;
}
.text-center {
	text-align: center;
}
.text-\[18px\] {
	font-size: 18px;
}
.text-\[24px\] {
	font-size: 24px;
}
.text-\[36px\] {
	font-size: 36px;
}
.text-\[48px\] {
	font-size: 48px;
}
.font-bold {
	font-weight: 700;
}
.font-light {
	font-weight: 300;
}
.font-normal {
	font-weight: 400;
}
.leading-\[1\.5\] {
	line-height: 1.5;
}
.leading-\[38px\] {
	line-height: 38px;
}
.tracking-\[4px\] {
	letter-spacing: 4px;
}
.shadow-\[6px_6px_0_\#000000\] {
	--tw-shadow: 6px 6px 0 #000;
	--tw-shadow-colored: 6px 6px 0 var(--tw-shadow-color);
	box-shadow:
		var(--tw-ring-offset-shadow, 0 0 #0000),
		var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.filter {
	filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast)
		var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert)
		var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.transition {
	transition-property:
		color,
		background-color,
		border-color,
		text-decoration-color,
		fill,
		stroke,
		opacity,
		box-shadow,
		transform,
		filter,
		-webkit-backdrop-filter;
	transition-property:
		color, background-color, border-color, text-decoration-color, fill,
		stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-property:
		color,
		background-color,
		border-color,
		text-decoration-color,
		fill,
		stroke,
		opacity,
		box-shadow,
		transform,
		filter,
		backdrop-filter,
		-webkit-backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 0.15s;
}
.transition-all {
	transition-property: all;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 0.15s;
}
.duration-200 {
	transition-duration: 0.2s;
}
.skip-link {
	position: absolute;
	top: -2.5rem;
	left: 0;
	z-index: 9999;
	--tw-bg-opacity: 1;
	background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
	padding: 0.5rem 1rem;
	--tw-text-opacity: 1;
	color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.skip-link:focus {
	top: 0;
}
.sr-only {
	position: absolute;
	margin: -1px;
	height: 1px;
	width: 1px;
	overflow: hidden;
	white-space: nowrap;
	border-width: 0;
	padding: 0;
	clip: rect(0, 0, 0, 0);
}
:focus-visible {
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #000;
}
.hover\:italic:hover {
	font-style: italic;
}
.hover\:shadow-\[6px_6px_0_\#000000\]:hover {
	--tw-shadow: 6px 6px 0 #000;
	--tw-shadow-colored: 6px 6px 0 var(--tw-shadow-color);
	box-shadow:
		var(--tw-ring-offset-shadow, 0 0 #0000),
		var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.focus\:outline-2:focus {
	outline-width: 2px;
}
.focus\:outline-black:focus {
	outline-color: #000;
}
@media (min-width: 640px) {
	.sm\:grid-cols-2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (min-width: 768px) {
	.md\:sticky {
		position: sticky;
	}
	.md\:top-\[40px\] {
		top: 40px;
	}
	.md\:ml-2 {
		margin-left: 0.5rem;
	}
	.md\:h-\[90vh\] {
		height: 90vh;
	}
	.md\:max-h-\[calc\(100vh-40px\)\] {
		max-height: calc(100vh - 40px);
	}
	.md\:w-\[40\%\] {
		width: 40%;
	}
	.md\:flex-nowrap {
		flex-wrap: nowrap;
	}
	.md\:items-start {
		align-items: flex-start;
	}
	.md\:self-start {
		align-self: flex-start;
	}
	.md\:overflow-y-auto {
		overflow-y: auto;
	}
	.md\:border-2 {
		border-width: 2px;
	}
	.md\:border-b-0 {
		border-bottom-width: 0;
	}
	.md\:border-l-2 {
		border-left-width: 2px;
	}
	.md\:border-r-2 {
		border-right-width: 2px;
	}
	.md\:border-black {
		--tw-border-opacity: 1;
		border-color: rgb(0 0 0 / var(--tw-border-opacity, 1));
	}
}
@media (min-width: 1024px) {
	.lg\:grid-cols-3 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}
