::selection {
    background: rgba(0, 0, 0, 0.25);
}

:root {
    --bg-color: #f2f2f7;
    --text-color: rgba(0, 0, 0, 1);
    --header-color: white;
    --translateX: 0px;
    --translateY: 0px;
}

body {
    background: var(--bg-color);
    cursor: url("img/cursor.svg"), auto;
}

html,
body {
    overflow-x: hidden;
}

#mastodonVerify {
    display: none;
}

#bannerSection {
    display: flex;
    height: 750px;
    width: 100%;
    max-height: 90vh;
    align-content: center;
    align-items: center;
    background-attachment: scroll;
    background-size: cover;
    user-select: none;
    position: relative;
    overflow: hidden;
}

#bannerCanvas,
#bannerCanvasPlay {
    display: block;
    width: 100vw;
    height: 750px;
}

#bannerWithTextSection {
    display: flex;
    justify-content: left;
    align-items: center;
    overflow: hidden;
}

#bannerTextImg {
    padding: 64pt;
    padding-bottom: 14pt;
    width: 500px;
    view-transition-name: bannerText;
    transition: filter 1s, opacity 1s, scale 1.3s, top 0.2s;
    transform-origin: center center;
    position: absolute;
    z-index: 120;

    @starting-style {
        filter: blur(25px);
        opacity: 0;
        scale: 0.5;
    }

    transition-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
        0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

#bannerBG {
    height: 750px;
    width: 100%;
    align-content: center;
    align-items: center;
    background-attachment: scroll;
    background-size: cover;
    user-select: none;
    position: relative;
    box-sizing: border-box;
}

#bannerSection::after,
#playTop::after,
#storeTop::after {
    content: "";
    background-image: url("img/grain.webp");
    height: 750px;
    width: 100%;
    opacity: 0.2;
    position: absolute;
    mix-blend-mode: soft-light;
    animation: grain 0.6s steps(1) infinite;
}

#bannerSection::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: top;
    z-index: -1;
}

#bannerTextImgPlay1,
#bannerTextImgPlay2,
#bannerTextImgPlay3,
#bannerTextImgPlay4 {
    height: 100px;
    margin-left: -35px;
    padding: 0;
}

#bannerTextImgPlay1 {
    animation: moveRotate1 6s infinite linear;
}

#bannerTextImgPlay2 {
    animation: moveRotate2 7s infinite linear;
}

#bannerTextImgPlay3 {
    animation: moveRotate3 5s infinite linear;
}

#bannerTextImgPlay4 {
    animation: moveRotate4 6s infinite linear;
}

#playLetters {
    width: 100px;
    display: flex;
    flex-wrap: nowrap;
    transition: filter 0.3s;
    padding-bottom: 12pt;
    gap: 20px;
    margin-left: 35px;
}

#banner {
    display: block;

}

#bannerVid {
    height: 600px;
    width: 100%;
    object-fit: cover;
}

#bannerTextStacked {
    display: flex;
    flex-direction: column;
}

a {
    text-decoration: none;
    text-rendering: optimizeLegibility;
    cursor: url("img/hand cursor.svg"), auto;

}

@font-face {
    font-family: InterVariable;
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url("fonts/InterVariable.woff2") format("woff2");
}

@font-face {
    font-family: InterVariable;
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url("fonts/InterVariable-Italic.woff2") format("woff2");
}

* {
    font-family: InterVariable, sans-serif;
    font-feature-settings: "ss03", "cv08", "cv05", "cv10";
}

p {
    text-decoration: none;
    text-rendering: optimizeLegibility;
    opacity: 0.8;
}

p,
input,
textarea {
    cursor: url("img/ibeam.svg"), auto;
}

#bannerText {
    padding-left: 64pt;
    position: absolute;
}

#bannerTextImgSecond {
    padding: 64pt;
    padding-top: 14pt;
    width: 250px;
    view-transition-name: bannerTextSecond;

    transition: filter 0.3s, opacity 0.3s, scale 0.3s;

    @starting-style {

        filter: blur(15px);
        opacity: 0;
        scale: 0.9;
    }
}

h1 {
    font-size: 22pt;
    font-feature-settings: "ss03", "cv08", "cv05";
}

h2 {
    font-size: 16pt;
    font-feature-settings: "ss03", "cv08", "cv05";
}

body {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

#spacer {
    height: 74pt;
}

#spacerSmall {
    height: 24pt;
}

#spacerMedium {
    height: 42pt;
}

#spacerLinks {
    height: 74pt;
}

.collabPopupContainer {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(255, 255, 255, 0);
    user-select: none;
    pointer-events: none;
    z-index: 1000000;
    position: fixed;
    transition: scale 0.4s,
        opacity 0.4s,
        filter 0.4s,
        backdrop-filter 0.4s,
        background-color 0.4s,
        transform 0.4s;
    transition-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

.collabPopupsTogether::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 28px;
    mask-border: url("img/mask@2x.png") 49% fill / 42px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(0, 0, 0, 0.03);
    box-shadow: 0 6px 34px 0 rgba(0, 0, 0, 0.05), 0 3px 6px -3px rgba(0, 0, 0, 0.07), inset 0 -3px 3px -1px rgba(255, 255, 255, 0.4), inset 0 2px 7px -1px rgba(255, 255, 255, 0.60), inset 0 -12px 43px -3px rgba(0, 0, 0, 0.04);
    background-size: cover;
    background-position: center;
    will-change: auto;
    backdrop-filter: blur(45px) saturate(200%) brightness(105%);
    z-index: -1231;
}

.collabPopupsTogether {
    display: flex;
    flex-direction: column;
    padding-left: 12pt;
    padding-right: 12pt;
    transition: scale 0.4s, opacity 0.4s, filter 0.4s, transform 0.4s;
    transition-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
    opacity: 0;
    scale: 0.6;
    max-width: 600px;
    padding-bottom: 12pt;
    min-width: 300px;
    border-radius: 28px;
    box-sizing: border-box;
    margin-left: 24px;
    margin-right: 24px;
    box-shadow: 0 16px 34px 0 rgba(0, 0, 0, 0.05), 0 3px 6px -3px rgba(0, 0, 0, 0.05);
    transition: scale 0.4s, opacity 0.4s, filter 0.4s, transform 0.4s;
    transition-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

.collabPopup {
    border-radius: 28px;
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
    z-index: 10000000;
    position: relative;
}

.collabPopupDescription {
    border-radius: 28px;
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    padding: 24pt;
    margin-top: 6pt;
    z-index: 20000000;
}

.collabDivider {
    width: calc(100% - 44pt);
    height: 2px;
    background-color: black;
    margin-right: 22pt;
    margin-left: 22pt;
    border-radius: 1px;
    margin-top: 18pt;
    z-index: 1232;
    opacity: 0.12;
    transition: opacity 0.3s, filter 0.3s, transform 0.3s, scale 0.3s, background 0.3s;
}

#collabClose {
    scale: 1;
    opacity: 1;
    pointer-events: all;
    filter: blur(0px);
    cursor: url("img/close picture.svg"), auto;
    user-select: none;
    -webkit-user-drag: none;
    user-drag: none;
    z-index: 10000;
    border-radius: 100%;
    transition: scale 0.4s, opacity 0.4s, filter 0.4s, transform 0.05s linear;
    box-shadow: inset -2px -1px 5px -4px rgba(255, 255, 255, 0.15), inset 0.5px 0.5px 0.5px 0 rgba(255, 255, 255, 0.15), inset 1px 1px 5px -1px rgba(255, 255, 255, 0.4);
}

#collabCloseWithSpacer {
    margin-top: 12pt;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 12pt;
}

#collabTitle {

    margin-left: 24pt;
    margin-top: 18pt;
    margin-bottom: 0;
}

#collabClose:hover {
    scale: 1.2;

    background-image: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
            rgba(255, 255, 255, 1) 0%,
            rgba(255, 255, 255, 0) 100%);
}

#collabClose:active {
    scale: 0.8;
    background-image: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
            rgba(255, 255, 255, 1) 0%,
            rgba(255, 255, 255, 0) 100%);
}

.collabRow {
    display: flex;
    margin-left: 12pt;
    margin-right: 12pt;

    padding-left: 12pt;
    padding-right: 12pt;
    font-size: 14pt;
    font-weight: 400;
    text-decoration: none;
    color: black;
    opacity: 0.8;
    mask-border: url("img/mask@2x.png") 49% fill / 28px;
    will-change: transform;

    border-radius: 14pt;

    transition: scale 0.3s, opacity 0.3s, background-color 0.3s, transform 0.075s linear;
    cursor: url("img/link.svg"), auto !important;
    position: relative;
}


.collabRow:hover {
    opacity: 1;
    background-color: rgba(0, 0, 0, 0.1);
    scale: 1.02;
}

.collabRow:active {
    background-color: rgba(0, 0, 0, 0.2);
    scale: 0.95;
}

.collabRowText {
    padding-top: 0pt;
    padding-bottom: 0pt;
    cursor: url("img/link.svg"), auto !important;
}

#collabDesc {
    padding-bottom: 0;
}

.thumbnail:hover:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
            rgba(255, 255, 255, 1) 0%,
            rgba(255, 255, 255, 0) 100%);
    transition: opacity 0.3s, scale 0.3s;
    opacity: 0.1;
    pointer-events: none;
    z-index: 400000;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: inset 0 15px 53px 0 rgba(255, 255, 255, 0.05), inset 0 21px 43px 0 rgba(0, 0, 0, 0.07), inset 0 1px 1px -1px rgba(255, 255, 255, 0.50), inset 0 -1px 1px -1px rgba(255, 255, 255, 0.50), inset 0 -8px 13px -3px rgba(255, 255, 255, 0.08);
    mix-blend-mode: overlay;
}

#storeHeader {
    display: flex;
}

#headerGoBack {
    cursor: url("img/back.svg"), auto;
    padding: 12pt;
    padding-left: 8px;
    font-size: 14pt;
    font-weight: 400;
    text-overflow: ellipsis;
    text-decoration: none;
    color: var(--text-color);
    opacity: 1;
    width: 100%;
    border-radius: 18px;
    margin: 4px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

#backBtn {
    cursor: url("img/back.svg"), auto;
    display: flex;
    transition: opacity 0.3s, filter 0.3s, transform 0.3s, scale 0.3s, background 0.3s;
    border-radius: 18px;
    opacity: 0.6;
}

#backIcon {
    width: 12px;
    padding: 12pt;
    padding-right: 0;
}

#backDivider {
    width: 12px;
    height: 18px;
    opacity: 0.4;
    transform: translateY(32px);
    filter: blur(15px);
    transition: opacity 0.3s, filter 0.3s, transform 0.3s, scale 0.3s, background 0.3s;
}

#backBtn:hover~#backDivider {
    opacity: 0;
}

.uiuxCurrent {
    text-wrap: nowrap;
    text-overflow: clip;
}

#grid {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding: 22pt;
    justify-content: center;
    box-sizing: border-box;
    max-width: 2560px;
}

#gridInline {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding-left: 32pt;
    padding-right: 32pt;
    justify-content: center;
    box-sizing: border-box;
}

#linksGrid {
    max-width: 1200px;
    display: flex;
    flex-wrap: wrap;
    padding: 12px;
    justify-content: center;
    box-sizing: border-box;
}

#linksGridWrapper,
#gridWrapper {
    height: 100%;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.thumbnail {
    display: flex;
    align-content: left;
    justify-content: left;
    align-items: end;
    aspect-ratio: 157/192 !important;
    flex: 1 1 300px;
    margin: 18pt;
    position: relative;
    overflow: hidden;
    transition: scale 0.3s, opacity 0.6s, filter 0.5s;
    user-select: none;
    mask-border: url("img/mask@2x.png") 49% fill / 42px;
    will-change: transform;
    border-radius: 28px;
}

.thumbnailPlaceholder {
    display: flex;
    align-content: left;
    justify-content: left;
    align-items: end;
    aspect-ratio: 157/192 !important;
    flex: 1 1 300px;
    margin: 18pt;
    position: relative;
    overflow: hidden;
    cursor: url("img/cursor.svg"), auto;
}

.thumbnailPlaceholderPhoto {
    background: transparent;
    display: flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    aspect-ratio: 157/192;
    flex: 1 1 300px;
    margin: 18pt;
    position: relative;
    overflow: hidden;
    cursor: url("img/cursor.svg"), auto;

}

.background-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    pointer-events: none;
    transition: opacity 0.1s ease-in-out;
    opacity: 0;
}

.video-thumb .thumbTextBoth {
    position: relative;
    z-index: 2;
}

.thumbnail::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0);
    z-index: 1;
    pointer-events: none;
    transition: background 0.3s;
}

.thumbnail:hover {
    scale: 1.05;
}

.thumbnail:hover::after {
    background: rgba(0, 0, 0, 0.25);
    z-index: 1;
    pointer-events: none;
}

.thumbnail:hover .thumbTextBoth {
    opacity: 1;
    scale: 1.0;
}

.thumbnail:hover {
    opacity: 1;
}

.thumbnail:hover {
    background-color: rgba(0, 0, 0, 0.6);
}

.thumbnail:active {
    scale: 0.95;
}

.thumbText {
    font-size: 18pt;
    font-weight: 600;
    color: white;
    opacity: 1;
    scale: 0.97;
    transition: opacity 0.3s, scale 0.3s;
    z-index: 3;
    text-align: left;
}

.thumbTextCategory {
    font-size: 12pt;
    font-weight: 400;
    color: white;
    mix-blend-mode: plus-lighter;
    filter: blur(8px);
    opacity: 0;
    scale: 0.97;
    transition: opacity 0.3s, scale 0.3s, transform 0.3s;
    z-index: 3;

}

.brightThumbText {
    color: black;
}

.thumbnail:hover .thumbTextBoth {
    transform: translateY(0px);

}

.thumbnail:hover .thumbTextCategory {
    opacity: 0.7;
    filter: blur(0px);
}

.thumbTextBoth {
    padding-bottom: 16pt;
    padding-left: 16pt;
    transform: translateY(20px);
    transition: opacity 0.3s, scale 0.3s, transform 0.3s, filter 0.3s;
    animation-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

.thumbTextSingle {
    padding-bottom: 16pt;
    padding-left: 16pt;
    transition: opacity 0.3s, scale 0.3s, transform 0.3s, filter 0.3s;
    animation-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

#project1 {
    background-image: url("img/thumbnails/shattered mirrors.webp");
    background-size: cover;
}

#project2 {
    background-image: url("img/thumbnails/animation.webp");
    background-size: cover;
}

#project3 {
    background-image: url("img/thumbnails/emoji.webp");
    background-size: cover;
}

#project4 {
    background-image: url("img/thumbnails/photography.webp");
    background-size: cover;
}

#project5 {
    background-image: url("img/thumbnails/digital art.webp");
    background-size: cover;
}

#project6 {
    background-image: url("img/thumbnails/little things.webp");
    background-size: cover;
}

#project7 {
    background-image: url("img/thumbnails/station eleven.webp");
    background-size: cover;
}

#project8 {
    background-image: url("img/thumbnails/painting.webp");
    background-size: cover;
}

#project9 {
    background-image: url("img/thumbnails/throw.webp");
    background-size: cover;
}

#project10 {
    background-image: url("img/thumbnails/bhn.webp");
    background-size: cover;
}

#project11 {
    background-image: url("img/thumbnails/toys.webp");
    background-size: cover;
}

#project12 {
    background-image: url("img/thumbnails/rundown.webp");
    background-size: cover;
}

#project13 {
    background-image: url("img/thumbnails/off the road.webp");
    background-size: cover;
}

#project14 {
    background-image: url("img/thumbnails/snowfall.webp");
    background-size: cover;
}

#project15 {
    background-image: url("img/thumbnails/warped.webp");
    background-size: cover;
}

#project16 {
    background-image: url("img/thumbnails/bubbles.webp");
    background-size: cover;
}

#project17 {
    background-image: url("img/thumbnails/neon lights.webp");
    background-size: cover;
}

#project18 {
    background-image: url("img/thumbnails/museum.webp");
    background-size: cover;
}

#project26 {
    background-image: url("img/thumbnails/multiverse.webp");
    background-size: cover;
}

#project19 {
    background-image: url("img/thumbnails/spiritedaway.webp");
    background-size: cover;
}

#project20 {
    background-image: url("img/thumbnails/render1.webp");
    background-size: cover;
}

#project21 {
    background-image: url("img/thumbnails/render2.webp");
    background-size: cover;
}

#project22 {
    background-image: url("img/thumbnails/universe.webp");
    background-size: cover;
}

#project23 {
    background-image: url("img/thumbnails/xanadu.webp");
    background-size: cover;
}

#project24 {
    background-image: url("img/thumbnails/pulse.webp");
    background-size: cover;
}

#project25 {
    background-image: url("img/thumbnails/animal.webp");
    background-size: cover;
}

#project27 {
    background-image: url("img/thumbnails/altIcons.webp");
    background-size: cover;
}

#project28 {
    background-image: url("img/thumbnails/cmu housing.webp");
    background-size: cover;
}

#project29 {
    background-image: url("img/thumbnails/osf.webp");
    background-size: cover;
}

#project30 {
    background-image: url("img/thumbnails/art store.webp");
    background-size: cover;
}

#project31 {
    background-image: url("img/thumbnails/ourcity.webp");
    background-size: cover;
}

#project32 {
    background-image: url("img/thumbnails/pillar.webp");
    background-size: cover;
}

#photoThumb1 {
    background-image: url("img/thumbnails/photo-classytrashy.webp");
    background-size: cover;
}

#photoThumb2 {
    background-image: url("img/thumbnails/photo-phone.webp");
    background-size: cover;
}

#photoThumb3 {
    background-image: url("img/thumbnails/photo-nighttime.webp");
    background-size: cover;
}

#photoThumb4 {
    background-image: url("img/thumbnails/photo-pencil.webp");
    background-size: cover;
}

#photoThumb5 {
    background-image: url("img/thumbnails/photo-reflections.webp");
    background-size: cover;
}

#photoThumb6 {
    background-image: url("img/thumbnails/photo-transitions.webp");
    background-size: cover;
}

.textBlock {
    max-width: 700px;
    min-width: 250px;
    padding-left: 42pt;
    padding-right: 42pt;
    padding-bottom: 12pt;
    display: flex;
    flex-direction: column;
}

.textBlockWide {
    max-width: 850px;
    padding-left: 42pt;
    padding-right: 42pt;
    padding-bottom: 12pt;
    display: flex;
    flex-direction: column;
}

#animationStyle {
    padding-top: 44pt;
}

.textBlockUltrawide {
    max-width: 1250px;
    padding-left: 42pt;
    padding-right: 42pt;
    padding-bottom: 12pt;
    display: flex;
    flex-direction: column;
}

.year,
.tools {
    opacity: 0.4;
}

.projectName {
    text-wrap: pretty;
    line-height: 26pt;
}

.projectNameTitle {
    line-height: 26pt;
    font-size: 26pt;
}

.description,
.year,
.tools {
    padding-bottom: 12pt;
    text-wrap: pretty;
    line-height: 18pt;
    margin: 0px;
}

.videoContainer2-1 {
    display: flex;
    width: 100%;
    aspect-ratio: 2 / 1;
    align-content: center;
    justify-content: center;
    justify-items: center;
    align-items: center;
    margin-bottom: 44pt;
}

.video {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    margin-right: 44pt;
    margin-left: 44pt;
}

.video2 {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.videoContainer16-9 {
    display: flex;
    width: 100%;
    aspect-ratio: 16 / 9;
    align-content: center;
    justify-content: center;
    justify-items: center;
    align-items: center;
    margin-bottom: 42pt;
}

.videoContainer2 {
    display: flex;
    width: 100%;
    aspect-ratio: 16 / 9;
    align-content: center;
    justify-content: center;
    justify-items: center;
    align-items: center;
    margin: 0;
    padding: 0;
}

.videoContainerBig {
    display: flex;
    width: 100%;
    aspect-ratio: 1920 / 924;
    align-content: center;
    justify-content: center;
    align-items: center;
    margin-bottom: 42pt;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

.videoContainerMultiverse {
    display: flex;
    width: calc(100% - 88pt);
    aspect-ratio: 1920 / 1247;
    align-content: center;
    justify-content: center;
    align-items: center;
    margin-bottom: 42pt;
    margin-left: 44pt;
    margin-right: 44pt;
    box-sizing: border-box;
}

.videoContainerRundown {
    display: flex;
    width: calc(100% - 88pt);
    aspect-ratio: 1920 / 940;
    align-content: center;
    justify-content: center;
    align-items: center;
    margin-bottom: 42pt;
    margin-left: 44pt;
    margin-right: 44pt;
    box-sizing: border-box;
    position: relative;

    mask-image: url("img/rundown/main\ mask.webp");
    mask-size: cover;
}

.videoContainerWarped {
    display: flex;
    width: calc(100% - 88pt);
    aspect-ratio: 16 / 9;
    align-content: center;
    justify-content: center;
    align-items: center;
    margin-bottom: 42pt;
    margin-left: 44pt;
    margin-right: 44pt;
    box-sizing: border-box;
    position: relative;
    mask-image: url("img/warped/matte.webp");
    mask-size: cover;
}

.videoContainerAnimal {
    display: flex;
    width: 100%;
    aspect-ratio: 1920 / 1242;
    align-content: center;
    justify-content: center;
    align-items: center;
    margin-bottom: 42pt;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

.gallery {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding-left: 44pt;
    padding-right: 44pt;
    gap: 12pt;
    justify-content: space-between;
    box-sizing: border-box;
    user-select: none;
}

.galleryUniverse {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding-left: 44pt;
    padding-right: 44pt;
    gap: 12pt;
    justify-content: space-between;
    box-sizing: border-box;
    user-select: none;
    margin-bottom: 42pt;
}

#morePhotos {
    column-count: 5;
}

#photoProject {
    column-count: 4;
}

#photoProject4 {
    column-count: 4;
}

#normal {
    aspect-ratio: 3024/1964;
}

#wide {
    aspect-ratio: 3024/2160;
}

#square {
    aspect-ratio: 1/1;
}

#med {
    aspect-ratio: 3840/2160;
}

.galleryImgRender {
    width: 100%;
    height: auto;
    margin-bottom: 12pt;
}

.photographyGallery,
.rendersGallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    grid-auto-rows: 1fr;
    gap: 12pt;
    width: 100%;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

#ourCityGallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    grid-auto-rows: 1fr;
    gap: 12pt;
    width: 100%;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

#ourCityGalleryTop {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    grid-auto-rows: 1fr;
    gap: 12pt;
    width: 100%;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

#classytrashyGallery,
#lovehateGallery,
#nighttimeGallery,
#pencilGallery,
#reflectionsGallery,
#transitionsGallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    grid-auto-rows: 1fr;
    gap: 12pt;
    width: 100%;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

.miscPhoto,
.miscPhotoL,
.miscPhotoS {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: filter 0.3s, opacity 0.3s, scale 0.3s;

    @starting-style {

        filter: blur(15px);
        opacity: 0;
        scale: 0.9;
    }

}

.galleryAbstractRender {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    aspect-ratio: 3/2;
}

.miscPhoto {
    aspect-ratio: 3 / 4;
}

.miscPhotoL {
    aspect-ratio: 4 / 3;
}

.miscPhotoS {
    aspect-ratio: 1 / 1;
}

.breakdownImage {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
    user-select: none;
}

#breakdownImg {
    width: 100%;
    padding-bottom: 22pt;
    user-select: none;
}

.museumImgs2 {
    width: 100%;
    display: flex;
    padding-left: 36pt;
    padding-right: 36pt;
    box-sizing: border-box;
}

.museumImgs3 {
    width: 100%;
    display: flex;
    padding-left: 36pt;
    padding-right: 36pt;
    box-sizing: border-box;
}

.museumColumn {
    width: 50%;
    padding: 4pt;
    padding-bottom: 22pt;
}

.artStoreWideColumn {
    width: 64%;
    padding: 4pt;
    padding-bottom: 22pt;
}

.artStoreNarrowColumn {
    width: 36%;
    padding: 4pt;
    padding-bottom: 22pt;
}

.museumColumn3 {
    width: 33.333%;
    padding: 4pt;
    padding-bottom: 22pt;
}

.OurCityRow1 {
    padding-bottom: 0 !important;
}

.link {
    color: black;
    text-decoration: underline;
    text-decoration-color: rgba(0, 0, 0, 0.3);
    transition: text-decoration-color 0.3s, font-weight 0.3s, background-color 0.3s, padding 0.3s, margin 0.3s;
    cursor: url("img/link.svg"), auto;
    border-radius: 20px;
}

.link:hover {

    text-decoration-color: rgba(0, 0, 0, 0.8);

}

.link:active {
    text-decoration-color: rgba(0, 0, 0, 0);

}

.textAndImage {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding-bottom: 12pt;
}

#multiverseLogo {
    min-width: 250px;
    max-width: 800px;
    aspect-ratio: inherit;
    object-fit: contain;
    padding-left: 60px;
    padding-right: 60px;
}

.imageContainer {
    display: flex;
    width: 100%;
    align-content: center;
    justify-content: center;
    justify-items: center;
    align-items: center;
    margin-bottom: 42pt;
    box-sizing: border-box;
}

#imageContainerPNGRundown,
#imageContainerGifRundown {
    max-width: 100%;
    height: auto;
}

#imageContainerPainting {
    max-width: 100%;
    height: auto;
    transition: scale 0.3s;
}

#imageContainerPNGRundown {
    flex-grow: calc(2290/1680);
}

#imageContainerGifRundown {
    flex-grow: calc(1200/1301);
}

#imageContainerPNGWarped,
#imageContainerGifWarped {
    max-width: 100%;
    height: auto;
}

#imageContainerPNGWarped {
    flex-grow: calc(2614/2160);
}

#imageContainerGifWarped {
    flex-grow: calc(795/1400);
}

.imageAndText {
    display: flex;
    padding-left: 44pt;
    padding-right: 44pt;
    padding-bottom: 44pt;
    padding-top: 44pt;
    flex-wrap: nowrap;
    justify-content: space-between;
}

#portalPaintings {
    aspect-ratio: 2/1;
    display: flex;
    gap: 12pt;
    transition: scale 0.3s;
}

.bigImg {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding-right: 44pt;
    padding-left: 44pt;
    box-sizing: border-box;
}

#bigVid {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

#bigVidMaskedRundown {
    width: 100%;
    height: 100%;
    object-fit: contain;
    mask-image: url('..img/rundown/mask.png');
    mask-size: cover;
}

#bhn-1 {
    display: flex;
    padding-left: 44pt;
    padding-right: 44pt;
    padding-bottom: 44pt;
    gap: 44pt;
    align-items: start;
}

#bhn1-r {
    flex-grow: calc(3379/3024);
    width: 100%;
    height: 100%;
}

#bhnCaption {
    flex-grow: calc(3379/3024);
    width: 100%;
    height: 100%;
}

#bhn1-l {
    flex-grow: calc(1851/3333);
    width: 100%;
    height: 100%;
}

#imageContainerPainting {
    flex-grow: calc(3000/4000);
    width: 100%;
    height: 100%;
    max-width: 800px;
}

#portalPainting {
    flex-grow: calc(2/1);
    width: 100%;
    height: 100%;
    max-width: 800px;
    transition: scale 0.3s;
}

#bhnCaption {
    display: flex;
    flex-direction: column
}

.bhnRainImgs {
    display: flex;
    padding-left: 44pt;
    padding-right: 44pt;
    padding-bottom: 44pt;
    gap: 44pt;
    justify-content: center;
    width: 100%;
    box-sizing: border-box;
}

#rain1,
#rain2,
#rain3 {
    flex-grow: calc(1080/1920);
    width: 33.33333333%;
    height: auto;
    aspect-ratio: 9/16;
    box-sizing: border-box;
}

#rainWrapper {
    padding-left: 44pt;
    padding-right: 44pt;
    box-sizing: border-box;
}

.imgRow {
    display: flex;
    padding-left: 44pt;
    padding-right: 44pt;
    padding-bottom: 44pt;
    gap: 12pt;
}

.imgRow img {
    display: block;
    flex-basis: 0px;
    width: 0px;
    height: auto;
}

.animationRow {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-grow: 1;
}

.animationBlock {
    flex-grow: 1;
}

.video:hover {
    cursor: url("img/hand cursor.svg"), auto;
}

#lightbox {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    max-width: 100vw;
    max-height: 100vh;
    min-height: -webkit-fill-available;
    margin: 0;
    padding: 0;
    border: none;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(255, 255, 255, 0);
    backdrop-filter: blur(0px);
    pointer-events: none;
    z-index: 1000000;
    cursor: url("img/close picture.svg"), auto;
    transition: backdrop-filter 0.3s, background-color 0.3s;
}

/* Lightbox active state */
#lightbox.active {
    background-color: RGBA(242, 242, 247, 0.8);
    backdrop-filter: blur(40px);
    pointer-events: all;
}

#lightboxPhotoContainer {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
}

#lightboxImage {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    box-sizing: border-box;
    padding: 20pt;
    display: inline-block;
    filter: blur(30px);
    opacity: 0;
    scale: 0.9;
    transition: scale 0.3s, filter 0.3s, opacity 0.3s;
}

#lightboxImage.visible {
    filter: blur(0px);
    opacity: 1;
    scale: 1;
}

#lightboxButtons {
    position: fixed;
    top: 24px;
    right: 24px;
    display: flex;
    gap: 8pt;
    filter: blur(10px);
    opacity: 0;
    pointer-events: none;
    z-index: 10000000;
    transition: scale 0.4s, opacity 0.4s, filter 0.4s, transform 0.05s linear;
}

#lightboxButtons.visible {
    opacity: 1;
    pointer-events: all;
    filter: blur(0px);
}

#lightboxClose {
    background-image: url(../img/closeBtn.svg);
    cursor: url(img/close\ picture.svg), auto !important;
}

#lightboxInfo,
#lightboxInfo.hidden {
    cursor: url(img/picture\ info.svg), auto !important;
    background-image: url(../img/infoBtn.svg);
}

#lightboxInfo.visible {
    background-image: url(../img/infoBtnDark.svg);
}

.lightboxBtn {
    width: 55px;
    aspect-ratio: 1/1;
    background-size: cover;
    backdrop-filter: blur(5px);
    border-radius: 100%;
    transition: scale 0.4s, opacity 0.4s, filter 0.4s, transform 0.05s linear;
}

.lightboxBtn:hover {
    scale: 1.2;
}

.lightboxBtn:active {
    scale: 0.8;
}

#lightboxInfoContainer {
    height: 100%;
    padding-right: 24pt;
    margin-top: 144pt;
    width: 0;
    transform: translateX(40px);
    transition: opacity 0.4s, filter 0.4s, width 0.4s, transform 0.4s;
    transition-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

#lightboxInfoContainer.visible {
    transform: translateX(0);
    width: 400px;
}

#lightboxInfoContainer.hidden {
    transform: translateX(40px);
    width: 0;
}


#lightboxInfoList {
    min-width: 400px;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.lightboxInfoBox {
    display: flex;
    padding: 8px 24px;
    border-radius: 16px;
    mask-border: url("img/mask@2x.png") 49% fill / 32px;
    background-color: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(0, 0, 0, 0.03);
    backdrop-filter: blur(15px);
    transition: opacity 0.4s, filter 0.4s, width 0.4s, transform 0.4s;
    transition-timing-function: linear(0, 0.02 2.1%, 0.081 4.7%, 0.467 15.7%, 0.645, 0.778 28.5%, 0.872 35.8%,
            0.909 40.1%, 0.938 44.9%, 0.977 56.5%, 0.994 72.3%, 1);
}

.lightboxInfoBox.visible {
    opacity: 1;
    filter: blur(0px);
}

.lightboxInfoBox.hidden {
    opacity: 0;
    filter: blur(45px);
}

.lightboxInfoText {
    font-family: "JetBrains Mono", monospace;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}

.allCaps {
    text-transform: uppercase;
}

#cameraInfoBox {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

#cameraNameAll {
    display: flex;
    flex-direction: row;
    gap: 4px;
}

#cameraStats {
    display: flex;
    flex-direction: row;
    gap: 4px;
    justify-content: space-between;
}

.cameraDivider {
    width: calc(100% - 12pt);
    height: 2px;
    background-color: black;
    margin-right: 6pt;
    margin-left: 6pt;
    border-radius: 1px;
    opacity: 0.12;
}

.rowItem {
    flex-grow: calc(3000 / 4000);
    max-width: 800px;
    transition: scale 0.3s;
}

@media (max-width: 1490px) and (min-width: 500px) {
    #lightboxInfoContainer {
        height: fit-content;
        position: absolute;
        right: 0;
        top: 0;
        bottom: auto;
        margin-top: 72pt;
    }

}

@media (max-width: 600px) {
    #lightboxInfoContainer {
        height: 0;
        position: relative;
        bottom: 24pt;
        padding-right: 12pt;
        padding-left: 12pt;
        margin: 0;
        width: 100%;
        top: auto;
        transform: translateX(0px) translateY(120px);
        transition: opacity 0.3s, filter 0.3s, transform 0.3s, height 0.3s;
    }

    #lightboxInfoContainer.visible {
        height: 400px;
        width: calc(100% - 24pt);
        margin-right: 12pt;
        margin-left: 12pt;
        transform: translateX(0px) translateY(0px);
    }

    #lightboxInfoContainer.hidden {
        height: 0;
        width: calc(100% - 24pt);
        margin-right: 12pt;
        margin-left: 12pt;
        transform: translateX(0px) translateY(120px);
    }

    #lightbox {
        flex-direction: column;
    }

    #lightboxButtons {
        width: calc(100% - 48px);
        justify-content: space-between;
    }


    #lightboxInfoList {
        min-width: 300px;
        max-width: 100%;
    }


}


.galleryImg {
    display: flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    aspect-ratio: 2/1;
    flex: 1 1 400px;
    position: relative;
    overflow: hidden;
    transition: scale 0.3s ease, border-radius 0.3s ease, transform 0.5s cubic-bezier(0.410, 0.350, 0.000, 1.000);
}

.galleryImgUniverse {
    display: flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    aspect-ratio: 3024/1964;
    flex: 1 1 400px;
    position: relative;
    overflow: hidden;
    transition: scale 0.3s ease, border-radius 0.3s ease, transform 0.5s cubic-bezier(0.410, 0.350, 0.000, 1.000);
}

.galleryImg,
.rowItem,
#imageContainerPainting,
.galleryImgRender,
#museumImg,
.galleryImgUniverse,
.miscPhoto,
.miscPhotoL,
.miscPhotoS,
.galleryAbstractRender {
    transition: scale 0.3s ease;
    view-transition-name: 'galleryImg';
}

.galleryImg:hover,
.rowItem:hover,
#imageContainerPainting:hover,
.galleryImgRender:hover,
#museumImg:hover,
.galleryImgUniverse:hover,
.miscPhoto:hover,
.miscPhotoL:hover,
.miscPhotoS:hover,
.galleryAbstractRender:hover {
    cursor: url("img/picture zoom.svg"), auto;
}

.galleryImg:active,
.rowItem:active,
#imageContainerPainting:active,
.galleryImgRender:active,
#museumImg:active,
.galleryImgUniverse:active,
.miscPhoto:active,
.miscPhotoL:active,
.miscPhotoS:active,
.galleryAbstractRender:active {
    scale: 0.98;
    z-index: 200;
}

label {
    font-size: 16pt;
    font-feature-settings: "ss03", "cv08";
}

#multiverseDesc {
    margin-bottom: 12px;
}

#playDescription {
    color: black;
    font-size: 14pt;
    text-align: left;
    font-weight: 500;
    max-width: 500px;
    user-select: none;
    cursor: url("img/cursor.svg"), auto;
}

#playText {
    display: flex;
    flex-direction: column;
    margin-left: 84pt;
    margin-right: 44pt;
    position: absolute;
    z-index: 120;
}

.pdf {
    margin-top: 24px;
    width: 100%;
    aspect-ratio: 8.5/11;
    height: auto;
    border-radius: 24pt;
}

#thumbExternal {
    cursor: url("img/link.svg"), auto;
}

html {
    cursor: url("img/cursor.svg"), auto;
}

#notfoundpage {
    width: 100vw;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* SIZE MEDIA QUERIES  */
@media (max-width: 1200px) {
    #bannerSection {
        height: 600px;
    }
}

@media (max-width: 1050px) {
    #spacer {
        height: 74pt;
        margin-top: 18pt;
    }
}

@media (max-width: 900px) {

    #backBtn,
    #backDivider {
        display: none;
    }
}

@media (max-width: 800px) {

    .textAndImage {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        padding-bottom: 12pt;
    }
}

@media (min-width: 1950px) {
    .thumbnail {
        flex: 1 1 450px;
        margin: 22pt;
    }
}

@media (min-width: 300px) and (max-width: 1304px) {
    .imageAndText {
        flex-wrap: wrap;
    }
}

@media (min-width: 720px) and (max-width: 1199px) {
    #linksGrid {
        width: 712px;
    }
}

@media (max-width: 760px) {

    .museumImgs2,
    .museumImgs3,
    .videoContainerBig,
    .videoContainerAnimal,
    .gallery,
    .breakdownImage,
    .bigImg,
    .imageAndText,
    #bhn-1,
    #rainWrapper,
    .imgRow,
    #gridInline,
    #grid {
        padding-left: 12pt;
        padding-right: 12pt;
    }

    .videoContainerMultiverse,
    .videoContainerRundown,
    .videoContainerWarped {
        width: calc(100% - 24pt);
        margin-left: 12pt;
        margin-right: 12pt;
    }

    .museumColumn3 {
        padding: 6pt;
        gap: 6pt;
    }

    .photographyGallery,
    #miscGallery,
    #classytrashyGallery,
    #lovehateGallery,
    #nighttimeGallery,
    #pencilGallery,
    #reflectionsGallery,
    #transitionsGallery,
    #ourCityGalleryTop,
    #ourCityGallery {
        padding-left: 16pt;
        padding-right: 16pt;
    }

    #playText {
        margin-left: 64pt;
    }

    .bhnRainImgs {
        gap: 22pt;
        padding-left: 16pt;
        padding-right: 16pt;
        gap: 16pt;
    }

    #bannerTextImg {
        width: 250px;
        padding-left: 34pt;
    }

    #rainWrapper {
        padding-left: 16pt;
        padding-right: 16pt;
    }

    .video {
        margin-right: 16pt;
        margin-left: 16pt;
    }

    .museumImgs2,
    .museumImgs3 {
        flex-direction: column;
        width: 100%;
    }

    .museumImgs3 {
        align-items: center;
    }

    .museumColumn,
    .artStoreWideColumn,
    .artStoreNarrowColumn,
    .museumColumn3 {
        width: 100%;
        align-items: center;
        padding-left: 0;
        padding-right: 0;
    }
}

@media (max-width: 1305px) {
    .imageAndText {
        justify-content: center;
    }
}

/* KEYFRAMES  */
@keyframes grain {

    0%,
    100% {
        background-position-x: 0%;
        background-position-y: 0%;
    }

    10% {
        background-position-x: -5%;
        background-position-y: -10%;
    }

    20% {
        background-position-x: -15%;
        background-position-y: -5%;
    }

    30% {
        background-position-x: 7%;
        background-position-y: 25%;
    }

    40% {
        background-position-x: -5%;
        background-position-y: 25%;
    }

    50% {
        background-position-x: -15%;
        background-position-y: 10%;
    }

    60% {
        background-position-x: 5%;
        background-position-y: 0%;
    }

    70% {
        background-position-x: 0%;
        background-position-y: 15%;
    }

    80% {
        background-position-x: 3%;
        background-position-y: 35%;
    }

    90% {
        background-position-x: -10%;
        background-position-y: 10%;
    }
}

@keyframes moveRotate1 {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    20% {
        transform: translate(1px, -1px) rotate(2deg);
    }

    40% {
        transform: translate(-2px, -2px) rotate(4deg);
    }

    60% {
        transform: translate(2px, 1px) rotate(-2deg);
    }

    80% {
        transform: translate(-1px, -1px) rotate(-4deg);
    }

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

/* Second animation (used for the 2nd image) */
@keyframes moveRotate2 {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    20% {
        transform: translate(-1px, 1px) rotate(-3deg);
    }

    40% {
        transform: translate(2px, 0px) rotate(4deg);
    }

    60% {
        transform: translate(-2px, 1px) rotate(-3deg);
    }

    80% {
        transform: translate(2px, -2px) rotate(2deg);
    }

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

/* Third animation (used for the 3rd image) */
@keyframes moveRotate3 {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    20% {
        transform: translate(2px, 1px) rotate(4deg);
    }

    40% {
        transform: translate(-2px, -1px) rotate(-4deg);
    }

    60% {
        transform: translate(2px, 0px) rotate(5px);
    }

    80% {
        transform: translate(-1px, 2px) rotate(-4deg);
    }

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

/* Fourth animation (used for the 4th image) */
@keyframes moveRotate4 {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    20% {
        transform: translate(-1px, -2px) rotate(2deg);
    }

    40% {
        transform: translate(2px, 1px) rotate(-2deg);
    }

    60% {
        transform: translate(-2px, -1px) rotate(4deg);
    }

    80% {
        transform: translate(1px, 2px) rotate(-2deg);
    }

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

@keyframes move-out {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }

}

@keyframes move-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }

}