@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;
    --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);
    --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;
    --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;
    --bw: 1px;
    --bw-thick: 0.125rem;
    --pad-x: var(--s-4);
    --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: #fff0
}

::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
}
/*
body::before {
    content: "";
    position: fixed;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: #fff0 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: .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)
    }
}

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: .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: -.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(.22,1,.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: .82;
    letter-spacing: -.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-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: .03em
}

p.mono span,a span {
    position: relative;
    top: -.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: .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: 3.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: .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: .7
}

.project-overview-copy a {
    font-weight: 600;
    color: #0a0a0a
}

.project-overview-copy ol,.project-overview-copy ul {
    margin: 40px 0 32px 20px
}

.project-overview-copy ol li,.project-overview-copy ul li {
    font-size: clamp(1rem, 0.94rem + 0.18vw, 1.15rem);
    line-height: 1.2;
    margin-bottom: 8px;
    list-style-type: disclosure-closed;
}

.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;
    line-height: 1.2;
    margin-bottom: 40px;
}

.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: .75rem;
    letter-spacing: .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: #fff;
    mix-blend-mode: difference;
    pointer-events: none
}

.topbar>* {
    pointer-events: auto
}

.topbar__brand {
    font-family: var(--ff-display);
    font-size: 1.125rem;
    letter-spacing: -.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: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    position: relative
}

.topbar__nav a::before {
    content: "ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã‚ Ãƒâ€šÃ‚Â³ ";
    opacity: .5
}

.topbar__nav a:hover {
    color: var(--c-accent)
}

.topbar__meta {
    font-family: var(--ff-mono);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .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: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    line-height: 1.6
}

.hero__meta div span {
    display: block;
    opacity: .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: .82;
    letter-spacing: -.045em;
    text-transform: uppercase;
    margin: 0;
    align-self: center
}

.hero__title em {
    font-style: normal;
    background: var(--c-accent);
    padding: 0 .1em;
    display: inline-block
}

.hero__title sup {
    font-size: .18em;
    font-family: var(--ff-mono);
    font-weight: 400;
    vertical-align: top;
    margin-left: .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: .75rem;
    text-transform: uppercase;
    letter-spacing: .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: -.02em;
    padding: var(--s-3) 0
}

.marquee__track {
    display: inline-block;
    animation: marquee 40s linear infinite;
    padding-left: 100%
}

.marquee__track span {
    padding-inline:.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: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    opacity: .5
}

.section-head__title {
    font-family: var(--ff-display);
    font-size: clamp(2rem, 6cqi, 4.5rem);
    line-height: .9;
    letter-spacing: -.03em;
    text-transform: uppercase;
    margin: 0
}

.section-head__count {
    font-family: var(--ff-mono);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    opacity: .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(.2,.8,.2,1),filter 300ms
}

.tile:hover img {
    transform: scale(1.08);
    filter: contrast(1.1) saturate(.9)
}

.tile__label {
    position: absolute;
    inset: auto 0 0 0;
    padding: var(--s-2);
    font-family: var(--ff-mono);
    font-size: .625rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--c-bg);
    background: linear-gradient(to top,oklch(15% 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: #fff0;
    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: .9;
    letter-spacing: -.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(.2,.8,.2,1);
    line-height: 1
}

.services__panel {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 400ms cubic-bezier(.2,.8,.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: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em
}

.services__sublist li::before {
    content: "ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã‚ Ãƒâ€šÃ‚Â³ ";
    opacity: .5
}

.services__cta {
    display: inline-flex;
    align-items: center;
    gap: var(--s-2);
    font-family: var(--ff-mono);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .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: .85; */
    /* letter-spacing: -.045em; */
    /* text-transform: uppercase; */
    margin: 0 0 var(--s-4);
}

.contact__head h2 em {
    font-style: normal;
    background: var(--accent-3);
    padding: 0 .1em;
    display: inline-block
}

.contact__head p {
    font-family: var(--ff-mono);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin: 0;
    max-width: 60ch;
    opacity: .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)
}

@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: .6875rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    display: block
}

.form__hint {
    font-family: var(--ff-mono);
    font-size: .625rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    display: block;
    text-align: right;
    opacity: .5;
    margin-top: calc(var(--s-2) * -1 + 0.125rem)
}

.form__label span:last-child {
    opacity: .4
}

.form__row--split>div {
    display: grid;
    gap: var(--s-2);
    align-content: start
}

.form__field {
    font-family: var(--ff-mono);
    font-size: .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:.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: .5rem .5rem;
    background-repeat: no-repeat;
    padding-right: 2.5rem
}

.form__submit {
    font-family: var(--ff-mono);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .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: .5;
    cursor: wait
}

.form__submit::after {
    content: "Ã¢â€ â€™"
}

.form__status {
    font-family: var(--ff-mono);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .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% .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: .6875rem;
    text-transform: uppercase;
    letter-spacing: .05em
}

.map__legend dt {
    opacity: .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: .6875rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--c-bg);
    display: flex;
    justify-content: space-between;
    opacity: .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: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    opacity: .5
}

.detail__title {
    font-family: var(--ff-display);
    font-size: clamp(2.5rem, 7cqi, 5rem);
    line-height: .85;
    letter-spacing: -.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: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em
}

.detail__meta div span {
    display: block;
    opacity: .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: .6875rem;
    text-transform: uppercase;
    letter-spacing: .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: .6875rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .08em;
    opacity: .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(.65,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% .005 90);
    stroke-width: 4;
    paint-order: stroke fill;
    stroke-linejoin: round;
    letter-spacing: .05em;
    text-transform: uppercase
}

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