@import url("https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&family=Host+Grotesk:ital,wght@0,300..800;1,300..800&display=swap");
@font-face {
  src: url("https://fonts.cdnfonts.com/css/pp-neue-montreal") format("woff2");
  font-family: "PP Neue Montreal", sans-serif;
  font-weight: 400;
}
:root {
  --base-100: #ffffff;
  --base-200: #efece5;
  --base-300: #0a0a0a;
  --base-secondary-dark: #686560;
  --base-secondary-fade: rgba(249, 244, 235, 0.15);
  --accent-1: #6e94ff;
  --accent-2: #ff8d8d;
  --accent-3: #faf636;
  --scroll-thumb-color: var(--base-300);
  --space-1: clamp(0.5rem, 0.36rem + 0.45vw, 0.9rem);
  --space-2: clamp(0.9rem, 0.65rem + 0.75vw, 1.4rem);
  --space-3: clamp(1.4rem, 1rem + 1.2vw, 2.3rem);
  --space-4: clamp(2rem, 1.45rem + 1.9vw, 3.5rem);
  --space-5: clamp(2.8rem, 2rem + 2.8vw, 5rem);
  --warm-off-black: #1a1917;
  --warm-off-white: #f8f5f2;
/* Colors Ã¢â‚¬â€ OKLCH */
	--c-bg: oklch(96% 0.005 90);
	--c-fg: oklch(15% 0 0);
	--c-fg-soft: oklch(15% 0 0 / 0.6);
	--c-line: oklch(15% 0 0);
	--c-accent: oklch(88% 0.22 125);
	--c-accent-2: oklch(70% 0.22 35);

	/* Typography */
	--ff-display: "Archivo Black", ui-sans-serif, system-ui, sans-serif;
	--ff-body: "Archivo", ui-sans-serif, system-ui, sans-serif;
	--ff-mono: "JetBrains Mono", ui-monospace, monospace;

	/* Modular spacing */
	--s-1: 0.25rem;
	--s-2: 0.5rem;
	--s-3: 0.75rem;
	--s-4: 1rem;
	--s-5: 1.5rem;
	--s-6: 2rem;
	--s-7: 3rem;
	--s-8: 5rem;
	--s-9: 8rem;
	--s-10: 12rem;

	/* Borders */
	--bw: 1px;
	--bw-thick: 0.125rem;

	/* Container */
	--pad-x: var(--s-4);

	/* Scrollbar */
	--sbw: 0.5rem;
}

@media (min-width: 48rem) {
	:root {
		--pad-x: var(--s-5);
	}
}
@media (min-width: 80rem) {
	:root {
		--pad-x: var(--s-6);
	}
}
@media (min-width: 120rem) {
	:root {
		--pad-x: var(--s-7);
	}
}

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

::-webkit-scrollbar {
	width: var(--sbw);
}
::-webkit-scrollbar-track {
	background-color: var(--c-accent);
}
::-webkit-scrollbar-thumb {
	background-color: var(--c-fg);
}
::-webkit-scrollbar-corner {
	background-color: transparent;
}

::selection {
	background: var(--c-accent);
	color: var(--c-fg);
}

html {
  background-color: var(--base-100);
  overflow-y: auto;
  overflow-x: clip;
}

body {
  font-family: "Host Grotesk";
  background-color: var(--base-100);
  color: var(--base-300);
  min-height: 100svh;
  overflow-y: auto;
  overflow-x: clip;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

/* Animated noise effect */
body::before {
  content: "";
  position: fixed;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: transparent
    url("https://assets.iceable.com/img/noise-transparent.png") repeat 0 0;
  background-size: 300px 300px;
  animation: noise-animation 0.3s steps(5) infinite;
  opacity: 0.9;
  will-change: transform;
  z-index: 100;
  pointer-events: none;
}

@keyframes noise-animation {
  0% {
    transform: translate(0, 0);
  }

  10% {
    transform: translate(-2%, -3%);
  }

  20% {
    transform: translate(-4%, 2%);
  }

  30% {
    transform: translate(2%, -4%);
  }

  40% {
    transform: translate(-2%, 5%);
  }

  50% {
    transform: translate(-4%, 2%);
  }

  60% {
    transform: translate(3%, 0);
  }

  70% {
    transform: translate(0, 3%);
  }

  80% {
    transform: translate(-3%, 0);
  }

  90% {
    transform: translate(2%, 2%);
  }

  100% {
    transform: translate(1%, 0);
  }
}

/* Dust/Scratches background effect for the entire site */
body::after {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("https://img.freepik.com/premium-photo/white-dust-scratches-black-background_279525-2.jpg?w=640");
  background-repeat: repeat;
  opacity: 0.5;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 999;
}

html.custom-scrollbar-enabled,
body.custom-scrollbar-enabled {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

html.custom-scrollbar-enabled::-webkit-scrollbar,
body.custom-scrollbar-enabled::-webkit-scrollbar {
  width: 0;
  height: 0;
}
.neuve {
  font-family: "PP Neue Montreal", sans-serif;
  font-weight: 700;
  font-size: 1.8rem;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-transform: uppercase;
  letter-spacing: -0.03em;
}
.alt-bg {
  background-color: var(--warm-off-black);
  color: var(--warm-off-white);
}
.scrollbar-overlay {
  position: fixed;
  top: 0;
  right: 0;
  width: 12px;
  height: 100svh;
  pointer-events: none;
  z-index: 9999;
  opacity: 0;
  transition: opacity 180ms ease;
}

.custom-scrollbar-enabled .scrollbar-overlay {
  opacity: 1;
}

.scrollbar-overlay-thumb {
  position: absolute;
  top: 0;
  right: 0;
  width: 8px;
  margin: 4px 2px;
  border-radius: 999px;
  background: var(--scroll-thumb-color);
  transform: translate3d(0, 0, 0);
  transition: background-color 220ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms ease;
  will-change: transform, height;
}

img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  -webkit-user-select: none;
  user-select: none;
}

h1,
h2,
h3,
h4 {
  text-transform: uppercase;
  font-family: "Barlow Condensed";
  font-weight: 900;
  line-height: 0.82;
  letter-spacing: -0.03em;
}

h1 {
  font-size: clamp(4rem, 13vw, 11rem);
}

h2 {
  font-size: clamp(3rem, 9vw, 8rem);
}

h3 {
  font-size: clamp(2.4rem, 7vw, 6rem);
}

h4 {
  font-size: clamp(1.6rem, 3.2vw, 2.7rem);
}

a {
  text-decoration: none;
}

button {
	font: inherit;
	color: inherit;
	background: none;
	border: 0;
	cursor: pointer;
}
p {
  font-family: "Host Grotesk";
  font-family: "DM Mono";
  font-size: clamp(1rem, 0.94rem + 0.18vw, 1.15rem);
  line-height: 1.2;
}

p.md {
  font-size: clamp(.9rem, .7rem + 0.35vw, 1.45rem);
}

p.lg {
  font-size: clamp(1.2rem, 1.06rem + 0.45vw, 1.65rem);
}

p.xxlp {
  font-size: clamp(1.2rem, 2.06rem + 0.45vw, 1.65rem);
  margin-bottom: 1rem;
}

p.mono {
  text-transform: uppercase;
  font-family: "DM Mono";
  font-size: clamp(0.75rem, 0.72rem + 0.08vw, 0.88rem);
  font-weight: 500;
  letter-spacing: 0.03em;
}

p.mono span,
a span {
  position: relative;
  top: -0.1rem;
}

.container:not(.py-5 .container) {
  width: 100%;
  height: 100%;
  padding: var(--space-4);
  max-width: 2000px;
  margin: 0 auto;
}

.symbols-container {
  display: flex;
  gap: 0.5rem;
  height: 1.125rem;
  z-index: 1;
}

.symbols-container .symbol {
  width: 1.125rem;
  filter: brightness(0) invert(1);
}

.project-overview-copy h2 {
  text-transform: none;
    font-size: clamp(2rem, 6vw, 3rem);
  font-weight: 700;
    margin: 30px 0;
    line-height: 5.5rem;
}

.project-overview-copy h3 {
  text-transform: none;
    font-size: clamp(1.4rem, 5vw, 1.5rem);
    line-height: 2.1rem;
    margin-bottom: .5rem;
    color: #0a0a0a;
  font-weight: 400;
  opacity: 0.7;
}
.project-overview-copy h4 {
  text-transform: none;
    font-size: clamp(1.4rem, 5vw, 1.5rem);
    line-height: 1.4rem;
    margin-bottom: .5rem;
    color: #0a0a0a;
  font-weight: 600;
  opacity: 0.7;
}
.project-overview-copy a {
    font-weight: 600;
    color: #0a0a0a;
}
.project-overview-copy ol,
.project-overview-copy ul {
    margin: 40px 0px 32px 20px;
}
.project-overview-copy ol li, 
.project-overview-copy ul li{
  font-family: "DM Mono";
  font-size: clamp(1rem, 0.94rem + 0.18vw, 1.15rem);
  line-height: 1.2;
    margin-bottom: 8px;
}
.project-overview-copy  hr {
    margin: 30px 0;
}
.project-overview-copy p {
    margin: 30px 0;
}
@media (max-width: 1000px) {
  .container {
    padding: var(--space-3);
  }
}

.mt-15 {
    margin-top: 15px!important
}

.mt-30 {
    margin-top: 30px!important
}

.mt-50 {
    margin-top: 50px!important
}

.mt-70 {
    margin-top: 70px!important
}

.mt-100 {
    margin-top: 100px!important
}

.mb-15 {
    margin-bottom: 15px!important
}

.mb-30 {
    margin-bottom: 30px!important
}

.mb-50 {
    margin-bottom: 50px!important
}

.mb-70 {
    margin-bottom: 70px!important
}

.mb-100 {
    margin-bottom: 100px!important
}

.ml-15 {
    margin-left: 15px!important
}

.ml-30 {
    margin-left: 30px!important
}

.ml-50 {
    margin-left: 50px!important
}

.mr-15 {
    margin-right: 15px!important
}

.mr-30 {
    margin-right: 30px!important
}

.mr-50 {
    margin-right: 50px!important
}
.order-btn {
      padding: .875rem 0;
    font-size: 1.1rem;
    align-items: center;
    background: #000;
    justify-content: center;
    width: auto;
    text-align: center;
    position: relative;
    border-radius: 6px;
    box-sizing: border-box;
    color: #fff;
    display: block;
}
table.table {
    text-align: left;
}

.blue-bg {
	background-color: var(--accent-1);
}
.red-bg {
	background-color: var(--accent-2);
}

.yellow-bg {
	background-color: var(--accent-3);
}



.u-mono {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}
.u-sr {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.topbar {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--s-4);
	padding: var(--s-4) var(--pad-x);
	color: white;
	mix-blend-mode: difference;
	pointer-events: none;
}
.topbar > * {
	pointer-events: auto;
}

.topbar__brand {
	font-family: var(--ff-display);
	font-size: 1.125rem;
	letter-spacing: -0.02em;
	text-transform: uppercase;
}
.topbar__brand::after {
	content: " Ã¢â€”Â";
	color: var(--c-accent);
}

.topbar__nav {
	display: none;
	gap: var(--s-5);
}
@media (min-width: 48rem) {
	.topbar__nav {
		display: flex;
	}
}
.topbar__nav a {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	position: relative;
}
.topbar__nav a::before {
	content: "Ã¢â€ Â³ ";
	opacity: 0.5;
}
.topbar__nav a:hover {
	color: var(--c-accent);
}

.topbar__meta {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.hero-x {
	min-height: 100dvh;
	padding: var(--s-7) var(--pad-x) 0;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: var(--s-6);
	border-bottom: var(--bw) solid var(--c-line);
	position: relative;
}

.hero__meta {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-4);
	padding-top: var(--s-5);
}
@media (min-width: 30rem) {
	.hero__meta {
		gap: var(--s-5);
	}
}
.hero__meta div {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	line-height: 1.6;
}
.hero__meta div span {
	display: block;
	opacity: 0.5;
	margin-bottom: var(--s-1);
}
.hero__meta strong {
	font-weight: 500;
}

.hero__title {
	font-family: var(--ff-display);
	font-size: clamp(3.5rem, 18cqi, 22rem);
	line-height: 0.82;
	letter-spacing: -0.045em;
	text-transform: uppercase;
	margin: 0;
	align-self: center;
}
.hero__title em {
	font-style: normal;
	background: var(--c-accent);
	padding: 0 0.1em;
	display: inline-block;
}
.hero__title sup {
	font-size: 0.18em;
	font-family: var(--ff-mono);
	font-weight: 400;
	vertical-align: top;
	margin-left: 0.2em;
	letter-spacing: 0;
	text-transform: uppercase;
}

.hero__sub {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-4);
	padding-bottom: var(--s-5);
}
@media (min-width: 48rem) {
	.hero__sub {
		grid-template-columns: 2fr 1fr;
		align-items: end;
	}
}
.hero__lede {
	font-family: var(--ff-body);
	font-size: clamp(1rem, 1.5cqi, 1.25rem);
	line-height: 1.35;
	max-width: 45ch;
	margin: 0;
}
.hero__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--s-3);
	align-self: end;
	justify-self: start;
	padding: var(--s-3) var(--s-4);
	border: var(--bw-thick) solid var(--c-line);
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	background: var(--c-bg);
	transition: background 120ms, color 120ms;
}
.hero__cta:hover {
	background: var(--c-fg);
	color: var(--c-bg);
}
.hero__cta::after {
	content: "Ã¢â€ â€”";
}

.marquee {
	border-block: var(--bw) solid var(--c-line);
	background: var(--c-fg);
	color: var(--c-bg);
	overflow: hidden;
	white-space: nowrap;
	font-family: var(--ff-display);
	font-size: clamp(1.5rem, 4cqi, 3rem);
	text-transform: uppercase;
	letter-spacing: -0.02em;
	padding: var(--s-3) 0;
}
.marquee__track {
	display: inline-block;
	animation: marquee 40s linear infinite;
	padding-left: 100%;
}
.marquee__track span {
	padding-inline: 0.5em;
}
.marquee__track span.dot {
	color: var(--accent-3);
}

@keyframes marquee {
	to {
		transform: translateX(-100%);
	}
}

.section-head {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-3);
	padding: var(--s-7) var(--pad-x) var(--s-5);
	border-bottom: var(--bw) solid var(--c-line);
}
@media (min-width: 48rem) {
	.section-head {
		grid-template-columns: auto 1fr auto;
		align-items: end;
	}
}
.section-head__num {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	opacity: 0.5;
}
.section-head__title {
	font-family: var(--ff-display);
	font-size: clamp(2rem, 6cqi, 4.5rem);
	line-height: 0.9;
	letter-spacing: -0.03em;
	text-transform: uppercase;
	margin: 0;
}
.section-head__count {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	opacity: 0.5;
}

.mosaic {
	display: grid;
	grid-template-columns: repeat(var(--mosaic-cols, 6), 1fr);
	gap: var(--bw);
	background: var(--c-line);
	border-bottom: var(--bw) solid var(--c-line);
}

.tile {
	position: relative;
	aspect-ratio: 1;
	background: var(--c-bg);
	overflow: hidden;
	cursor: pointer;
	display: none;
}

.tile:nth-child(-n + 48) {
	display: block;
}

@media (min-width: 48rem) {
	.mosaic {
		--mosaic-cols: 8;
	}
	.tile:nth-child(-n + 64) {
		display: block;
	}
}
@media (min-width: 64rem) {
	.mosaic {
		--mosaic-cols: 10;
	}
	.tile:nth-child(-n + 80) {
		display: block;
	}
}
@media (min-width: 80rem) {
	.mosaic {
		--mosaic-cols: 12;
	}
	.tile:nth-child(-n + 96) {
		display: block;
	}
}
@media (min-width: 100rem) {
	.mosaic {
		--mosaic-cols: 14;
	}
	.tile:nth-child(-n + 112) {
		display: block;
	}
}
@media (min-width: 120rem) {
	.mosaic {
		--mosaic-cols: 16;
	}
	.tile:nth-child(-n + 128) {
		display: block;
	}
}

.tile img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 300ms;
}
.tile:hover img {
	transform: scale(1.08);
	filter: contrast(1.1) saturate(0.9);
}

.tile__label {
	position: absolute;
	inset: auto 0 0 0;
	padding: var(--s-2);
	font-family: var(--ff-mono);
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--c-bg);
	background: linear-gradient(to top, oklch(15% 0 0 / 0.85), transparent);
	opacity: 0;
	transition: opacity 200ms;
	display: flex;
	justify-content: space-between;
	pointer-events: none;
}
.tile:hover .tile__label,
.tile:focus-visible .tile__label {
	opacity: 1;
}

@media (max-width: 47.99rem) {
	.tile__label {
		display: none;
	}
}

.services {
	border-bottom: var(--bw) solid var(--c-line);
}
.services__list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.services__item {
	border-bottom: var(--bw) solid var(--c-line);
	transition: background 200ms, color 200ms;
}
.services__item:last-child {
	border-bottom: 0;
}
.services__item[data-open="true"] {
	background: var(--c-fg);
	color: var(--c-bg);
}
.services__item[data-open="true"] .services__num {
	color: var(--c-accent);
}
.services__item[data-open="true"] .services__arrow {
	transform: rotate(45deg);
}

.services__trigger {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--s-4);
	width: 100%;
	padding: var(--s-5) var(--pad-x);
	text-align: left;
	font: inherit;
	color: inherit;
	background: transparent;
	border: 0;
	cursor: pointer;
}
.services__item:not([data-open="true"]) .services__trigger:hover {
	background: var(--c-fg);
	color: var(--c-bg);
}
.services__item:not([data-open="true"])
	.services__trigger:hover
	.services__num {
	color: var(--c-accent);
}

.services__num {
	font-family: var(--ff-mono);
	font-size: clamp(1rem, 2cqi, 1.5rem);
	font-weight: 500;
	transition: color 200ms;
}
.services__name {
	font-family: var(--ff-display);
	font-size: clamp(2rem, 7cqi, 6rem);
	line-height: 0.9;
	letter-spacing: -0.04em;
	text-transform: uppercase;
}
.services__arrow {
	font-family: var(--ff-mono);
	font-size: clamp(1.25rem, 2.5cqi, 2rem);
	display: inline-block;
	transition: transform 300ms cubic-bezier(0.2, 0.8, 0.2, 1);
	line-height: 1;
}

.services__panel {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 400ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
.services__item[data-open="true"] .services__panel {
	grid-template-rows: 1fr;
}
.services__panel-inner {
	overflow: hidden;
	min-height: 0;
}
.services__panel-content {
	padding: var(--s-4) var(--pad-x) var(--s-6);
	border-top: var(--bw) solid var(--c-bg);
	display: grid;
	gap: var(--s-5);
}
@media (min-width: 64rem) {
	.services__panel-content {
		grid-template-columns: 1.4fr 1fr auto;
		align-items: end;
		gap: var(--s-6);
	}
}

.services__desc {
	font-family: var(--ff-body);
	font-size: clamp(0.9375rem, 1.4cqi, 1.125rem);
	line-height: 1.45;
	margin: 0;
	max-width: 50ch;
}
.services__sublist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-2) var(--s-4);
}
.services__sublist li {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.services__sublist li::before {
	content: "Ã¢â€ Â³ ";
	opacity: 0.5;
}

.services__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: var(--s-3) var(--s-4);
	border: var(--bw-thick) solid var(--c-bg);
	color: var(--c-bg);
	align-self: end;
	justify-self: start;
	white-space: nowrap;
	transition: background 150ms, color 150ms, border-color 150ms;
}
.services__cta:hover {
	background: var(--c-accent);
	color: var(--c-fg);
	border-color: var(--c-accent);
}
.services__cta::after {
	content: "Ã¢â€ â€™";
}

.contact {
	border-bottom: var(--bw) solid var(--c-line);
}
.contact__head {
	padding: var(--s-7) var(--pad-x) var(--s-5);
	border-bottom: var(--bw) solid var(--c-line);
}
.contact__head h2 {
	font-family: var(--ff-display);
	font-size: clamp(2.5rem, 10cqi, 9rem);
	line-height: 0.85;
	letter-spacing: -0.045em;
	text-transform: uppercase;
	margin: 0 0 var(--s-4);
}
.contact__head h2 em {
	font-style: normal;
	background: var(--accent-3);
	padding: 0 0.1em;
	display: inline-block;
}
.contact__head p {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0;
	max-width: 60ch;
	opacity: 0.7;
}

.contact__grid {
	display: grid;
	grid-template-columns: 1fr;
}
@media (min-width: 64rem) {
	.contact__grid {
		grid-template-columns: 1fr 1fr;
	}
}

.form {
	padding: var(--s-6) var(--pad-x);
	border-bottom: var(--bw) solid var(--c-line);
	/* display: grid; */
	/* gap: var(--s-4); */
	/* grid-template-rows: 1fr 1fr 1fr 1fr 1fr; */
}
@media (min-width: 64rem) {
	.form {
		border-bottom: 0;
		border-right: var(--bw) solid var(--c-line);
	}
}
.form__row {
	display: grid;
	gap: var(--s-2);
	grid-template-rows: auto 1fr auto;
}
.form__row--split {
	grid-template-columns: 1fr 1fr;
	gap: var(--s-2);
}
.form__row--split .form__field {
	grid-column: span 1;
	min-width: 0;
}
@media (min-width: 30rem) {
	.form__row--split {
		gap: var(--s-3);
	}
}

.form__label {
	font-family: var(--ff-mono);
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	display: block;
}

.form__hint {
	font-family: var(--ff-mono);
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	display: block;
	text-align: right;
	opacity: 0.5;
	margin-top: calc(var(--s-2) * -1 + 0.125rem);
}
.form__label span:last-child {
	opacity: 0.4;
}
.form__row--split > div {
	display: grid;
	gap: var(--s-2);
	align-content: start;
}

.form__field {
	font-family: var(--ff-mono);
	font-size: 0.8125rem;
	padding: var(--s-3) var(--s-2);
	background: var(--c-bg);
	border: var(--bw-thick) solid var(--c-line);
	color: var(--c-fg);
	width: 100%;
	min-width: 0;
	border-radius: 0;
	outline-offset: 2px;
}
@media (min-width: 30rem) {
	.form__field {
		font-size: 0.875rem;
		padding: var(--s-3);
	}
}
.form__field:focus {
	outline: var(--bw-thick) solid var(--c-accent);
}
.form__field--area {
	resize: vertical;
	min-height: 8rem;
	font-family: var(--ff-mono);
}
select.form__field {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--c-fg) 50%),
		linear-gradient(-45deg, transparent 50%, var(--c-fg) 50%);
	background-position: calc(100% - 1.25rem) 50%, calc(100% - 0.75rem) 50%;
	background-size: 0.5rem 0.5rem;
	background-repeat: no-repeat;
	padding-right: 2.5rem;
}

.form__submit {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: var(--s-4);
	background: var(--c-fg);
	color: var(--c-bg);
	border: var(--bw-thick) solid var(--c-line);
	cursor: pointer;
	transition: background 150ms, color 150ms;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.form__submit:hover {
	background: var(--c-accent);
	color: var(--c-fg);
}
.form__submit:disabled {
	opacity: 0.5;
	cursor: wait;
}
.form__submit::after {
	content: "→";
}

.form__status {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: var(--s-3);
	border: var(--bw-thick) solid var(--c-line);
	display: none;
}
.form__status[data-state="ok"] {
	display: block;
	background: var(--c-accent);
}
.form__status[data-state="error"] {
	display: block;
	background: var(--c-accent-2);
	color: var(--c-bg);
}

.map {
	position: relative;
	background: oklch(96% 0.005 90);
	min-height: 30rem;
	display: grid;
	grid-template-rows: 1fr auto;
}
.map__svg {
	width: 100%;
	height: 100%;
	min-height: 0;
	display: block;
}
.map__legend {
	border-top: var(--bw) solid var(--c-line);
	padding: var(--s-4) var(--pad-x);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--s-3);
	font-family: var(--ff-mono);
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.map__legend dt {
	opacity: 0.4;
}
.map__legend dd {
	margin: 0;
	font-weight: 500;
}
.map__legend > div {
	display: flex;
	flex-direction: column;
	gap: var(--s-1);
}





.detail {
	position: fixed;
	inset: 0;
	z-index: 200;
	background: var(--c-bg);
	overflow-y: auto;
	display: none;
}
.detail[data-open="true"] {
	display: block;
}

.detail__close {
	position: fixed;
	top: var(--s-4);
	right: var(--pad-x);
	z-index: 10;
	width: 3rem;
	height: 3rem;
	border: var(--bw-thick) solid var(--c-line);
	background: var(--c-bg);
	font-family: var(--ff-mono);
	font-size: 1rem;
	display: grid;
	place-items: center;
	transition: background 150ms;
}
.detail__close:hover {
	background: var(--c-accent);
}

.detail__inner {
	display: grid;
	grid-template-columns: 1fr;
	min-height: 100dvh;
}
@media (min-width: 64rem) {
	.detail__inner {
		grid-template-columns: 1.4fr 1fr;
	}
}

.detail__visual {
	background: var(--c-fg);
	position: relative;
	display: grid;
	place-items: center;
	padding: var(--s-7) var(--pad-x);
	min-height: 60vh;
}
@media (min-width: 64rem) {
	.detail__visual {
		min-height: 100dvh;
		position: sticky;
		top: 0;
	}
}
.detail__hero-img {
	width: 100%;
	max-width: 50rem;
	aspect-ratio: 1;
	object-fit: cover;
	display: block;
}
.detail__visual-meta {
	position: absolute;
	bottom: var(--s-4);
	left: var(--pad-x);
	right: var(--pad-x);
	font-family: var(--ff-mono);
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--c-bg);
	display: flex;
	justify-content: space-between;
	opacity: 0.6;
}

.detail__body {
	padding: var(--s-7) var(--pad-x);
	display: grid;
	gap: var(--s-6);
	align-content: start;
}

.detail__crumb {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	opacity: 0.5;
}

.detail__title {
	font-family: var(--ff-display);
	font-size: clamp(2.5rem, 7cqi, 5rem);
	line-height: 0.85;
	letter-spacing: -0.04em;
	text-transform: uppercase;
	margin: 0;
}

.detail__meta {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s-3);
	border-block: var(--bw) solid var(--c-line);
	padding-block: var(--s-3);
}
.detail__meta div {
	font-family: var(--ff-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.detail__meta div span {
	display: block;
	opacity: 0.4;
	margin-bottom: var(--s-1);
}

.detail__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
}
.detail__tags span {
	font-family: var(--ff-mono);
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: var(--s-2) var(--s-3);
	border: var(--bw) solid var(--c-line);
}
.detail__tags span:first-child {
	background: var(--c-accent);
}

.detail__section h4 {
	font-family: var(--ff-mono);
	font-size: 0.6875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	opacity: 0.5;
	margin: 0 0 var(--s-2);
}
.detail__section p {
	font-family: var(--ff-body);
	font-size: 1rem;
	line-height: 1.5;
	margin: 0 0 var(--s-3);
}
.detail__section p:last-child {
	margin-bottom: 0;
}

.detail__related {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--bw);
	background: var(--c-line);
	border: var(--bw) solid var(--c-line);
}
.detail__related img {
	aspect-ratio: 1;
	object-fit: cover;
	width: 100%;
	height: 100%;
	background: var(--c-bg);
}

@supports (view-transition-name: x) {
	::view-transition-old(hero-image),
	::view-transition-new(hero-image) {
		animation-duration: 600ms;
		animation-timing-function: cubic-bezier(0.65, 0, 0.35, 1);
	}
	::view-transition-old(hero-image) {
		animation-name: vt-fade-out;
	}
	::view-transition-new(hero-image) {
		animation-name: vt-fade-in;
	}
}
@keyframes vt-fade-out {
	to {
		opacity: 1;
	}
}
@keyframes vt-fade-in {
	from {
		opacity: 1;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
	}
	.marquee__track {
		animation: none;
	}
}



.map-txt {
							font-family: 'JetBrains Mono', monospace;
							fill: oklch(15% 0 0);
							stroke: oklch(96% 0.005 90);
							stroke-width: 4;
							paint-order: stroke fill;
							stroke-linejoin: round;
							letter-spacing: 0.05em;
							text-transform: uppercase;
						}

						.map-txt--inv {
							fill: oklch(96% 0.005 90);
							stroke: oklch(15% 0 0);
						}
						
						
						
