/* ==========================================================
   JAM PROJECTS
   SINGLE PROJECT PAGE
   V2.1 REFINED
========================================================== */

/* ==========================================================
   OUTER WRAPPER
========================================================== */

.jam-single-project{

width:100vw;

    background-color:#5b2277;

    background-image:
        linear-gradient(
            90deg,
            #5b2277 0%,
            #824f9b 40%,
            #d2aae6 100%
        );

    background-blend-mode:multiply;

    background-position:center;

    background-repeat:no-repeat;

    background-size:cover;

    max-width:100%;

    position:relative;

    padding:60px 20px 40px;

}

/* ==========================================================
   MAIN CONTENT CARD
========================================================== */

.jam-single-project__wrap{

    max-width:1100px;

    margin:0 auto;

    padding:64px;

    border-radius:30px;

    background:
        linear-gradient(
            180deg,
            #ece3f8 0%,
            #dcccf0 100%
        );

    box-shadow:
        0 18px 42px rgba(45,22,84,.08),
        inset 0 1px 0 rgba(255,255,255,.40);

}

/* ==========================================================
   PROJECT HEADER
========================================================== */

.jam-single-project__header{

    margin-bottom:64px;

}

.jam-single-project__eyebrows{

    display:flex;

    flex-direction:column;

    align-items:flex-start;

    gap:12px;

    margin-bottom:36px;

}

.jam-single-project__eyebrow{

    display:inline-flex;

    align-items:center;

    padding:9px 16px;

    border-radius:999px;

    background:rgba(255,255,255,.60);

    color:#522a8c;

    font-size:11px;

    font-weight:800;

    letter-spacing:.1em;

    text-transform:uppercase;

    border:1px solid rgba(255,255,255,.35);

}

.jam-single-project__title{

    margin:0 0 24px;

    font-size:clamp(58px,8vw,72px);

    line-height:.92;

    letter-spacing:-3px;

    font-weight:800;

    color:#2d1654;

}

.jam-single-project__lead{

    max-width:900px;

    margin:0;

    font-size:30px;

    line-height:1.65;

    font-weight:600;

    color:#522a8c;

}

/* ==========================================================
   META CARDS
========================================================== */

.jam-single-project__meta{

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:24px;

    margin:64px 0 80px;

}

.jam-single-project__meta-card{

    padding:34px;

    border-radius:22px;

    background:rgba(255,255,255,.55);

    border:1px solid rgba(255,255,255,.35);

    backdrop-filter:blur(10px);

    box-shadow:
        0 8px 22px rgba(45,22,84,.06);

}

.jam-single-project__meta-card strong{

    display:block;

    margin-bottom:12px;

    font-size:11px;

    font-weight:800;

    text-transform:uppercase;

    letter-spacing:.1em;

    color:#522a8c;

}

.jam-single-project__meta-card span{

    display:block;

    font-size:22px;

    line-height:1.35;

    font-weight:700;

    color:#2d1654;

}

/* ==========================================================
   HERO IMAGE
========================================================== */

.jam-single-project__hero{

    margin:0 0 80px;

    overflow:hidden;

    border-radius:28px;

    background:#ffffff;

    box-shadow:
        0 14px 30px rgba(45,22,84,.08);

}

.jam-single-project__hero img{

    display:block;

    width:100%;

    aspect-ratio:16/9;

    object-fit:cover;

}

/* ==========================================================
   SECTION HEADINGS
========================================================== */

.jam-single-project__comparison h2,
.jam-single-project__section h2{

    margin:0 0 24px;

    font-size:42px;

    line-height:1.05;

    font-weight:800;

    color:#2d1654;

}

/* ==========================================================
   BEFORE / AFTER
========================================================== */

.jam-single-project__comparison{

    margin:0 0 80px;

}

.jam-single-project__comparison-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:24px;

}

.jam-single-project__comparison-card{

    overflow:hidden;

    border-radius:24px;

    background:rgba(255,255,255,.75);

    box-shadow:
        0 12px 25px rgba(45,22,84,.06);

}

.jam-single-project__comparison-card h3{

    margin:0;

    padding:16px;

    text-align:center;

    font-size:15px;

    font-weight:800;

    color:#ffffff;

    background:
        linear-gradient(
            180deg,
            #6b37b5,
            #522a8c
        );

}

.jam-single-project__comparison-card img{

    width:100%;

    display:block;

}

/* ==========================================================
   CONTENT SECTIONS
========================================================== */

.jam-single-project__section{

    margin:0 0 60px;

    padding:56px;

    border-radius:24px;

    background:rgba(255,255,255,.55);

    border:1px solid rgba(255,255,255,.35);

    backdrop-filter:blur(10px);

    box-shadow:
        0 8px 22px rgba(45,22,84,.06);

}

.jam-single-project__section p{

    margin:0;

    max-width:900px;

    font-size:18px;

    line-height:2;

    color:#5f3f9c;

}

/* ==========================================================
   CTA
========================================================== */

.jam-single-project__cta{

    margin-top:90px;

    padding:70px;

    border-radius:28px;

    text-align:center;

    background:
        linear-gradient(
            180deg,
            #6b37b5,
            #522a8c
        );

    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.10),
        0 14px 28px rgba(45,22,84,.16);

}

.jam-single-project__cta h2{

    margin:0 0 18px;

    font-size:48px;

    line-height:1.05;

    font-weight:800;

    color:#ffffff;

}

.jam-single-project__cta p{

    max-width:700px;

    margin:0 auto 30px;

    font-size:18px;

    line-height:1.8;

    color:rgba(255,255,255,.92);

}

.jam-single-project__button{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    min-height:58px;

    padding:0 36px;

    border-radius:999px;

    text-decoration:none;

    background:#ffffff;

    color:#522a8c;

    font-size:15px;

    font-weight:700;

    transition:.2s ease;

}

.jam-single-project__button:hover{

    transform:translateY(-2px);

}

/* ==========================================================
   GALLERY READY
========================================================== */

.jam-single-project__gallery{

    margin:80px 0;

}

.jam-single-project__gallery-grid{

    display:grid;

    grid-template-columns:
        repeat(auto-fit,minmax(240px,1fr));

    gap:20px;

}

.jam-single-project__gallery-grid img{

    width:100%;

    display:block;

    border-radius:18px;

}

/* ==========================================================
   RELATED PROJECTS READY
========================================================== */

.jam-single-project__related{

    margin-top:80px;

}

/* ==========================================================
   TABLET
========================================================== */

@media(max-width:950px){

    .jam-single-project__wrap{

        padding:42px;

    }

    .jam-single-project__meta{

        grid-template-columns:repeat(2,1fr);

    }

}

/* ==========================================================
   MOBILE
========================================================== */

@media(max-width:767px){

    .jam-single-project{

        padding:40px 16px 60px;

    }

    .jam-single-project__wrap{

        padding:24px;

        border-radius:22px;

    }

    .jam-single-project__title{

        font-size:44px;

        line-height:1;

    }

    .jam-single-project__lead{

        font-size:20px;

        line-height:1.55;

    }

    .jam-single-project__comparison-grid{

        grid-template-columns:1fr;

    }

    .jam-single-project__section{

        padding:30px;

    }

    .jam-single-project__cta{

        padding:40px 24px;

    }

    .jam-single-project__comparison h2,
    .jam-single-project__section h2{

        font-size:30px;

    }

}

@media(max-width:520px){

    .jam-single-project__meta{

        grid-template-columns:1fr;

    }

}

/* ==========================================================
   RELATED PROJECTS
========================================================== */

.jam-single-project__related{

    margin:80px 0;

}

.jam-single-project__related h2{

    margin:0 0 30px;

    font-size:42px;

    font-weight:800;

    color:#2d1654;

}

/* ==========================================================
   PROJECT NAVIGATION
========================================================== */

.jam-single-project__navigation{

    display:grid;

    grid-template-columns:1fr auto 1fr;

    align-items:center;

    gap:20px;

    margin:60px 0 80px;

}

.jam-single-project__nav-link {
    text-decoration: none;
    color: #522a8c;
    font-weight: 700;
    font-size: 32px;
}

.jam-single-project__navigation a:last-child{

    text-align:right;

}

@media(max-width:767px){

    .jam-single-project__navigation{

        grid-template-columns:1fr;

        text-align:center;

    }

    .jam-single-project__navigation a:last-child{

        text-align:center;

    }

}

/* ==========================================================
   BEFORE / AFTER SLIDER
========================================================== */

.jam-ba-slider{

    position:relative;

    overflow:hidden;

    border-radius:28px;

    background:#ffffff;

    isolation:isolate;

    box-shadow:
        0 14px 30px rgba(45,22,84,.08);

}

.jam-ba-slider__after{

    display:block;

    width:100%;

    aspect-ratio:4/3;

    object-fit:cover;

}

.jam-ba-slider__before-wrap{

    position:absolute;

    top:0;
    left:0;

    width:50%;
    height:100%;

    overflow:hidden;

    will-change:width;

    transform:translateZ(0);

}

.jam-ba-slider__before{

    display:block;

    width:100%;

    height:100%;

    object-fit:cover;

}

.jam-ba-slider__handle{

    position:absolute;

    top:0;
    bottom:0;

    left:50%;

    width:4px;

    background:#ffffff;

    transform:translateX(-50%) translateZ(0);

    cursor:ew-resize;

    z-index:5;

    will-change:left;

}

.jam-ba-slider__handle::after{

    content:"⟷";

    position:absolute;

    top:50%;
    left:50%;

    width:42px;
    height:42px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:50%;

    background:#ffffff;

    color:#522a8c;

    font-size:18px;

    font-weight:800;

    box-shadow:
        0 6px 16px rgba(0,0,0,.18);

    transform:
        translate(-50%,-50%);

}

/* ==========================================================
   SLIDER LABELS
========================================================== */

.jam-ba-slider__label{

    position:absolute;

    top:16px;

    padding:8px 12px;

    border-radius:999px;

    background:#3d2673;

    color:#ffffff;

    font-size:11px;

    font-weight:800;

    text-transform:uppercase;

    letter-spacing:.08em;

    z-index:10;

    opacity:0;

    transform:translateY(-4px);

    transition:
        opacity .2s ease,
        transform .2s ease;

    pointer-events:none;

}

.jam-ba-slider__label--before{

    left:16px;

}

.jam-ba-slider__label--after{

    right:16px;

}

/* ==========================================================
   ACTIVE LABELS
========================================================== */

.jam-ba-slider.show-before
.jam-ba-slider__label--before{

    opacity:1;

    transform:translateY(0);

}

.jam-ba-slider.show-after
.jam-ba-slider__label--after{

    opacity:1;

    transform:translateY(0);

}
@media(max-width:767px){

    .jam-ba-slider__label{

        font-size:10px;

        padding:8px 12px;

    }

    .jam-ba-slider__handle span{

        width:44px;
        height:44px;

    }

}


.jam-ba-slider,
.jam-ba-slider *{

    user-select:none;
    -webkit-user-select:none;

}

.jam-ba-slider img{

    -webkit-user-drag:none;

    user-drag:none;

    pointer-events:none;

}

/* ==========================================================
   SLIDER INTRO ANIMATION
========================================================== */

.jam-ba-slider.intro-pulse
.jam-ba-slider__handle::after{

    animation:
        jamSliderPulse 2.2s ease 1;

}

@keyframes jamSliderPulse{

    0%{

        transform:
            translate(-50%,-50%)
            scale(1);

    }

    20%{

        transform:
            translate(-50%,-50%)
            scale(1.18);

    }

    40%{

        transform:
            translate(-50%,-50%)
            scale(1);

    }

    60%{

        transform:
            translate(-50%,-50%)
            scale(1.18);

    }

    100%{

        transform:
            translate(-50%,-50%)
            scale(1);

    }

}

/* ==========================================================
   LIGHTBOX
========================================================== */

.jam-gallery-image{

    cursor:pointer;

    transition:
        transform .2s ease;

}

.jam-gallery-image:hover{

    transform:scale(1.03);

}

.jam-lightbox{

    position:fixed;

    inset:0;

    display:none;

    align-items:center;

    justify-content:center;

    background:
        rgba(0,0,0,.92);

    z-index:99999;

}

.jam-lightbox.active{

    display:flex;

}

.jam-lightbox__image{

    max-width:90vw;

    max-height:85vh;

    border-radius:16px;

}

.jam-lightbox__close,
.jam-lightbox__prev,
.jam-lightbox__next{

    position:absolute;

    border:none;

    background:none;

    color:#ffffff;

    cursor:pointer;

}

.jam-lightbox__close{

    top:30px;
    right:40px;

    font-size:48px;

}

.jam-lightbox__prev{

    left:30px;

    font-size:70px;

}

.jam-lightbox__next{

    right:30px;

    font-size:70px;

}

