.page {
    background-color: white;
}

/* Home */
.page-home .block-text {
    margin: 0.75rem;
}

.page-home .block-text-text {
    margin: 15vh 0;
}

/* 
    Projects 
*/

.page-projects {
    position: relative;
    background-color: white;
}

.page-projects-list,
.page-projects-gallery {
    display: none;
}

.page-projects-list.active,
.page-projects-gallery.active {
    display: block;
}

.page-projects-toggle {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 0.75rem;
    z-index: 100;
    color: white;
    mix-blend-mode: difference;
}

.page-projects-toggle span {
    display: none;
}

.page-projects-toggle span.active {
    display: block;
}

/* 
    Project 
*/

.page-project {
    max-height: 100svh;
    scroll-snap-type: y mandatory;
    overflow-y: auto;
    position: relative;
    -ms-overflow-style: none; /* Internet Explorer 10+ */
    scrollbar-width: none; /* Firefox */
    background-color: black;
}

.page-project::-webkit-scrollbar {
    display: none; /* Safari and Chrome */
}

.page-project-back {
    display: block;
    position: fixed;
    left: 0;
    bottom: 0;
    padding: 0.75rem;
    z-index: 10;
    mix-blend-mode: difference;
    color: white;
    transition: 300ms;
}

.page-project-back.hide {
    opacity: 0;
    pointer-events: none;
}

/* Project */
.project {
    position: relative;
    scroll-snap-align: center;
    height: 100vh;
    height: 100svh;
}

.project-cover {
    height: 100vh;
    height: 100svh;
    transition: 300ms;
}

.project-cover.active {
    /* opacity: 0.5; */
    filter: brightness(0.6);
}

.project-cover-slideshow-mobile {
    height: 100%;
    width: 100%;
}

.project-cover-slideshow-desktop {
    display: none;
}

/* Phased Image Loading */
.project-cover img {
    display: none;
}

.project.visible .project-cover .slideshow-slides img {
    display: block;
}


/* Content */
.project-content {
    position: absolute;
    top: calc(50% - 0.5rem);
    left: 0;
    right: 0;
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    grid-template-rows: 1fr auto 1fr;
    gap: 0.75rem;
    padding: 0 0.75rem;

    height: 2rem;
    max-height: 3rem;
    
    z-index: 10;
    color: white;
    mix-blend-mode: difference;
    transition: 300ms;
}

.project-content.active {
    mix-blend-mode: normal;
    color: white;
}

.project-content-title {
    grid-column: 1 / 4;
}

.project-content-info {
    display: none;
}

/* Content mobile */
.project-content-mobile {
    display: none;
    grid-column: 4/-2;
    translate: 0 -50%;
}

.project-content-mobile.active {
    display: block;
}

.project-content-mobile-label {
    font-size: 11px;
}


/* Button */
.project-details-button {
    grid-column: -2/-1;
    height: fit-content;
}

.project-details-button .hide {
    display: none;
}

.project-details-button .show {
    display: block;
}

.project-details-button.active .hide {
    display: block;
}

.project-details-button.active .show {
    display: none;
}

@media screen and (min-width: 48rem) {
    .project-cover-slideshow-mobile {
        display: none;  
    }

    .project-cover-slideshow-desktop {
        display: block;
        width: 100%;
        height: 100%;
    }

    .project-content {
        grid-template-columns: repeat(18, 1fr);
        grid-template-rows: 1fr;
    }

    .project-content-title {
        grid-column: 1/7;
        grid-row: 1;
    }

    .project-content.active .project-content-title {
        grid-row: 1;   
    }

    .project-content-mobile.active,
    .project-content-mobile {
        display: none;
    }

    .project-content-info {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: 1rem;
        padding-right: 0.5rem;
        height: fit-content;   
        padding-right: 2rem;
        grid-column: span 6;
        grid-row: 1;
    }

    .project-content-info:nth-child(3) {
        grid-column: span 4;
    }

    .project-content-info.active {
        display: grid;
    }

    .project-content-info-label {
        font-size: 0.825rem;
        grid-column: 1;
    }

    .project-content-info-label:first-child {
        margin-bottom: 0;
    }

    .project-content-info-value {
        grid-column: 2;
        margin-bottom: 0;
        max-width: 250px;
    }

    /* Details */
    .project-details {
        display: none;
    }

    .project-details.active {
        display: block;
    }

    .project-details-button {
        grid-column: -3/-1;
        grid-row: 1;
        height: fit-content;
        text-align: right;
    }


}


/* 
    Rocks Page
*/
.page-rocks {
    background-color: #DBDBDB;
}

.page-rocks.grid {
    position: static;
    max-height: unset;
    display: grid;
    padding: 3rem 2rem 3rem;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    min-height: 100svh;
    align-items: center;
}

/* .page-rocks.grid:hover .rock-cover {
    opacity: 0.5;
} */

.page-rocks-view-button {
    position: fixed;
    bottom: 0;
    left: 0;
    padding: 0.75rem;
    z-index: 100;
}

.page-rocks-view-button.hide {
    opacity: 0;
    pointer-events: none;
}

/* Button */
.page-rocks-view-button .single-view,
.page-rocks-view-button .grid-view {
    display: none;
}

.page-rocks-view-button .single-view.active,
.page-rocks-view-button .grid-view.active {
    display: block;
}

/* Tablet (>640px) */
@media screen and (min-width: 40rem) {
    .page-rocks.grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 2rem;
    }
}

/* Tablet (>768px) */
@media screen and (min-width: 48rem) {
    .page-rocks.grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

/* Tablet (>1024px) */
@media screen and (min-width: 64rem) {
    .page-rocks.grid {
        grid-template-columns: repeat(6, 1fr);
    }
}

body.snap-contents,
body.snap-contents * {
    scroll-snap-type: y mandatory;
}

.snap-contents .rock {
    scroll-snap-type: none;
    scroll-snap-align: center;
}

/* 
    Page Default 
*/

@media screen and (min-width: 48rem) {
    .page-default {
        display: grid;
        grid-template-columns: repeat(18, 1fr);
        gap: 15vh 0.75rem;
        padding: 15vh 0.75rem;
    }

    .page-default .block-heading {
        grid-column: 1/7;
        margin: 0 !important;
    }

    .page-default .block-text {
        grid-column: 7/13;
        padding: 0;
        margin: 0;
    }
}

/* 
    Rock Component
*/

.rock {
    display: block;
    overflow: visible;
    position: relative;
    aspect-ratio: 1 / 1;
}

.rock-cover {
    position: relative;
    transition: 300ms;
    display: none;
    background-color: #DBDBDB;
}


.page-rocks.grid .rock-cover {
    display: block;
}

.page-rocks.grid .rock-cover.active {
    opacity: 1 !important;
}

.page-rocks.grid .rock-cover-picture,
.page-rocks.grid .rock-cover-picture-image {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    object-position: var(--focus, 50% 50%);
}

.rock-slideshow {
    width: calc(100vw - (100vw - 100%));
    height: 100vh;
    
}

.page-rocks.grid .rock-slideshow {
    display: none;
}

.rock-gray-shadow {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    box-shadow: inset 0 0 8px 4px #DBDBDB;
}

/* Content */
.rock-content {
    position: absolute;
    top: calc(50% - 0.5rem);
    left: 0.75rem;
    right: 0.75rem;
    opacity: 1;
    transition: 300ms;
    display: grid;
    grid-template-columns: 1fr auto;
    pointer-events: none;   
    color: white;
    mix-blend-mode: difference;
    z-index: 10;
}

.page-rocks.grid .rock-content {
    display: none;
}

.rock-content-info {
    display: none;
}

.rock-details-button {
    grid-column: 3;
    text-align: right;
}

.page-rocks.grid .rock-content.active {
    opacity: 1;
    z-index: 1;
    transition: 300ms;
}


/* Desktop (> 768px) */
@media screen and (min-width: 48rem) {
    .rock {
        position: relative;
    }

    .page-rocks.grid .rock {
        position: static;
    }

    .rock-content {
        position: absolute;
        opacity: 1;
        display: grid;
        pointer-events: none;
        grid-template-columns: repeat(18, 1fr);
        transition: 300ms;
        z-index: 10;
    }

    .page-rocks.grid .rock-content {
        position: fixed;
        opacity: 0;
    }

    .page-rocks.grid .rock-content.active {
        display: grid;
        opacity: 1;
        pointer-events: none;
    }

    .rock-content-title {
        grid-column: 1 / 7;
    }

    .rock-content-info {
        grid-column: span 6;
        display: none;
        grid-template-columns: auto 1fr;
        gap: 0 1rem;
    }

    .page-rocks.grid .rock-content-info {
        display: grid;
    }

    .rock-content-info:nth-child(3) {
        grid-column: span 4;
    }

    .rock-content-info-label {
        grid-column: 1;
    }

    .rock-content-info-value {
        grid-column: 2;
    }

    .rock-content-link {
        grid-column: -3/-1;
        text-align: right;
    }

    .page-rocks.grid .rock-content-link {
        display: none;
    }
}


/* 
    Rock Page (.page-rock)
*/


.page-rock {
    position: relative;
    scroll-snap-align: center;
}

.page-rock-cover {
    height: 100vh;
    height: 100svh;
    transition: 300ms;
}

.page-rock-cover.active {
    opacity: 0.5;
    filter: brightness(1);
}

.page-rock-cover-slideshow-mobile {
    height: 100%;
    width: 100%;
}

.page-rock-cover-slideshow-desktop {
    display: none;
}


/* Phased Image Loading */
.page-rock-cover img {
    display: none;
}

.page-rock.visible .page-rock-cover .slideshow-slides img {
    display: block;
}


/* Rock Content */
.page-rock-content {
    position: absolute;
    top: calc(50% - 0.5rem);
    left: 0;
    right: 0;
    height: 2rem;
    max-height: 3rem;
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    padding: 0 0.75rem;
    z-index: 10;
    color: white;
    mix-blend-mode: difference;
}

.page-rock-content.active {
    gap: 0;
    mix-blend-mode: normal;
    color: black;
}

.page-rock-content-title {
    grid-column: 1 / 4;
    height: fit-content;
}

.page-rock-content-title-mobile {
    display: none;
}

.page-rock-content.active .page-rock-content-title-mobile {
    display: block;
}

@media screen and (min-width: 48rem) {
    .page-rock-content-title-mobile {
        display: none !important;
    }
    
}

/* Content Info */
.page-rock-content-info.active,
.page-rock-content-info {
    display: none;
}

.page-rock-content-mobile {
    display: none;
    grid-column: 4/-2;
    translate: 0 -50%;
}

.page-rock-content-mobile-label {
    font-size: 11px;
}

.page-rock-content-mobile.active {
    display: block;
}

.page-rock-details-button {
    grid-column: -2/-1;
    text-align: right;
}


.page-rock-back {
    position: fixed;
    left: 0;
    bottom: 0;
    padding: 0.75rem;
    z-index: 10;
    transition: 300ms;
}

.page-rock-back.hide {
    opacity: 0;
    pointer-events: none;
}

.page-rock-details {
    display: none;
}

.page-rock-details.active {
    display: block;
}

/* Button */
.page-rock-details-button {
    height: fit-content;
    text-align: right;
    white-space: nowrap;
    display: flex;
    justify-content: flex-end;
}

.page-rock-details-button .hide {
    display: none;
}

.page-rock-details-button .show {
    display: block;
}

.page-rock-details-button.active .hide {
    display: block;
}

.page-rock-details-button.active .show {
    display: none;
}

/* Desktop (768px) */
@media screen and (min-width: 48rem) {
    .page-rock-cover-slideshow-mobile {
        display: none;  
    }

    .page-rock-cover-slideshow-desktop {
        display: block;
        width: 100%;
        height: 100%;
    }

    .page-rock-content-mobile.active,
    .page-rock-content-mobile {
        display: none;
    }

    .page-rock-content {
        position: absolute;
        top: calc(50% - 0.75rem);
        left: 0;
        right: 0;
        translate: 0;
        display: grid;
        grid-template-columns: repeat(18, 1fr);
        grid-template-rows: 1fr;
        gap: 0.75rem;
        padding: 0 0.75rem;
        z-index: 10;
        color: white;
        mix-blend-mode: difference;   
    }

    .page-rock-content.active {
        translate: 0;
        gap: 0.75rem;
    }

    .page-rock-content.active .page-rock-content-title,
    .page-rock-content-title {
        grid-column: 1/7;
        grid-row: 1;
    }

    .page-rock-content-info.active,
    .page-rock-content-info {
        grid-column: unset;
        display: grid;
        grid-template-columns: auto 1fr;
        gap: 0.75rem;
        height: fit-content;
    }

    .page-rock-content-info {
        grid-column: span 6;
    }

    .page-rock-content-info.active,
    .page-rock-content-info {
        grid-column: span 6;
    }

    .page-rock-content-info.active:nth-child(3),
    .page-rock-content-info:nth-child(3) {
        grid-column: span 4;
    }

    .page-rock-content-info-label {
        grid-column: 1;
        font-size: 0.825rem;
    }

    .page-rock-content-info-label:first-child {
        margin: 0;
    }

    .page-rock-content-info-value {
        grid-column: 2;
    }

    .page-rock-content-info-value:not(:last-child) {
        margin: 0;
    }

    .page-rock-details-button {
        grid-column: -3/-1;
        grid-row: 1;
    }
}

/* Page About */
.page-about {
    padding-top: 15vh;
    background-color: white;
}

.page-about-desktop {
    display: none;
    margin-bottom: 15vh;
}

@media screen and (min-width: 48rem) {
    .page-about-desktop {
        display: block;
    }

    .page-about-mobile {
        display: none;
    }
}


/* 
    Transitionsing  (Barba.js)
*/

.transitioning {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
    pointer-events: none;
}

/* .transitioning * {
    overflow: hidden;
} */

.transitioning.current {
    z-index: 1;
}

.transitioning.prev,
.transitioning.next {
    z-index: 2;
}