/* =========================================================
ODAI STUDIO
========================================================= */

*{
    box-sizing:border-box;
}

.studio_page{
    max-width:1600px;
    margin:0 auto;
    padding:30px 20px 60px;
}

/* =========================================================
HEADER
========================================================= */

.studio_header{
    text-align:center;
    margin:10px 0 45px;
}

.studio_subtitle{
    display:inline-block;
    margin-bottom:12px;
    color:#7a0f0f;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:4px;
    font-weight:600;
}

.studio_title{
    margin:0;
    font-size:56px;
    font-family:Georgia, serif;
    font-weight:400;
    color:#111;
    letter-spacing:2px;
}

/* =========================================================
EMPTY STATE
========================================================= */

.studio_empty{
    min-height:65vh;
    display:flex;
    align-items:center;
    justify-content:center;
}

.studio_empty_box{
    max-width:850px;
    margin:auto;
    text-align:center;
    padding:50px;
}

.studio_empty_box h2{
    margin:0 0 25px;
    font-size:52px;
    font-family:Georgia, serif;
    font-weight:400;
    color:#222;
}

.studio_empty_box p{
    margin:0;
    color:#666;
    line-height:2;
    font-size:18px;
}

/* =========================================================
MASONRY GALLERY
========================================================= */

.studio_gallery{
    width:100%;
}

.studio_grid{
    column-count:4;
    column-gap:18px;
}

.studio_item{
    display:inline-block;
    width:100%;
    margin:0 0 18px;
    cursor:pointer;
    break-inside:avoid;
    -webkit-column-break-inside:avoid;
    position:relative;
}

.studio_item_inner{
    position:relative;
    overflow:hidden;
    border-radius:14px;
    background:#111;
}

.studio_item img{
    width:100%;
    display:block;
    transition:transform .55s ease;
    user-select:none;
    -webkit-user-drag:none;
    pointer-events:none;
}

.studio_item_overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(
        to top,
        rgba(0,0,0,.45),
        rgba(0,0,0,0)
    );
    opacity:0;
    transition:.35s;
    display:flex;
    align-items:center;
    justify-content:center;
}

.studio_zoom_icon{
    width:60px;
    height:60px;
    border-radius:50%;
    background:rgba(255,255,255,.18);
    backdrop-filter:blur(8px);
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-size:38px;
    font-weight:300;
    transform:scale(.8);
    transition:.3s;
}

.studio_item:hover img{
    transform:scale(1.06);
}

.studio_item:hover .studio_item_overlay{
    opacity:1;
}

.studio_item:hover .studio_zoom_icon{
    transform:scale(1);
}

/* =========================================================
PAGINATION
========================================================= */

.studio_pagination{
    margin:55px auto 10px;
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
}

.studio_page_btn{
    width:48px;
    height:48px;
    border-radius:50%;
    border:1px solid #e2e2e2;
    background:#fff;
    color:#222;
    text-decoration:none;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:15px;
    transition:.25s;
}

.studio_page_btn:hover{
    background:#111;
    color:#fff;
    border-color:#111;
}

.studio_page_btn.active{
    background:#7a0f0f;
    border-color:#7a0f0f;
    color:#fff;
}

/* =========================================================
MODAL
========================================================= */

.studio_modal{
    position:fixed;
    inset:0;
    z-index:999999;
    display:none;
    opacity:0;
    transition:opacity .35s ease;
}

.studio_modal.active{
    display:block;
    opacity:1;
}

.studio_modal_backdrop{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.94);
    backdrop-filter:blur(18px);
}

/* =========================================================
TOP BAR
========================================================= */

.studio_modal_top{
    position:absolute;
    top:22px;
    left:25px;
    right:25px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    z-index:20;
    color:#fff;
}

.studio_modal_logo{
    font-size:20px;
    font-family:Georgia, serif;
    letter-spacing:3px;
}

.studio_modal_counter{
    font-size:14px;
    opacity:.8;
    letter-spacing:1px;
}

/* =========================================================
IMAGE
========================================================= */

.studio_modal_content{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-52%);
    width:92%;
    height:72vh;
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:15;
}

.studio_modal_content img{
    max-width:100%;
    max-height:100%;
    display:block;
    border-radius:16px;
    box-shadow:0 25px 80px rgba(0,0,0,.45);
    animation:studioFade .35s ease;
    user-select:none;
    -webkit-user-drag:none;
    pointer-events:none;
}

@keyframes studioFade{
    from{
        opacity:0;
        transform:scale(.96);
    }
    to{
        opacity:1;
        transform:scale(1);
    }
}

/* =========================================================
BUTTONS
========================================================= */

.studio_close,
.studio_prev,
.studio_next{
    border:none;
    cursor:pointer;
    background:rgba(255,255,255,.08);
    backdrop-filter:blur(8px);
    color:#fff;
    transition:.25s;
}

.studio_close:hover,
.studio_prev:hover,
.studio_next:hover{
    background:rgba(255,255,255,.18);
}

.studio_close{
    width:52px;
    height:52px;
    border-radius:50%;
    font-size:34px;
    line-height:52px;
}

.studio_prev,
.studio_next{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:60px;
    height:60px;
    border-radius:50%;
    font-size:34px;
    z-index:25;
}

.studio_prev{
    left:25px;
}

.studio_next{
    right:25px;
}

/* =========================================================
THUMBNAILS
========================================================= */

.studio_modal_thumbs{
    position:absolute;
    left:0;
    right:0;
    bottom:18px;
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    overflow-x:auto;
    padding:10px 20px;
    z-index:20;
    scrollbar-width:none;
}

.studio_modal_thumbs::-webkit-scrollbar{
    display:none;
}

.studio_thumb{
    width:72px;
    height:72px;
    border-radius:10px;
    overflow:hidden;
    cursor:pointer;
    border:2px solid transparent;
    opacity:.6;
    transition:.25s;
    flex-shrink:0;
}

.studio_thumb.active{
    border-color:#fff;
    opacity:1;
    transform:scale(1.08);
}

.studio_thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    pointer-events:none;
    user-select:none;
    -webkit-user-drag:none;
}

/* =========================================================
LOADER EFFECT
========================================================= */

.studio_item img{
    background:#f2f2f2;
}

.studio_item::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:14px;
    pointer-events:none;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
}

/* =========================================================
RESPONSIVE
Le style Pinterest est conservé sur mobile
========================================================= */

@media (max-width:1200px){

    .studio_grid{
        column-count:3;
    }

}

@media (max-width:768px){

    .studio_page{
        padding:20px 12px 50px;
    }

    .studio_title{
        font-size:40px;
    }

    .studio_grid{
        column-count:2;
        column-gap:10px;
    }

    .studio_item{
        margin-bottom:10px;
    }

    .studio_modal_top{
        top:12px;
        left:12px;
        right:12px;
    }

    .studio_modal_logo{
        font-size:15px;
    }

    .studio_modal_counter{
        font-size:12px;
    }

    .studio_modal_content{
        width:96%;
        height:68vh;
    }

    .studio_prev,
    .studio_next{
        width:46px;
        height:46px;
        font-size:26px;
    }

    .studio_prev{
        left:8px;
    }

    .studio_next{
        right:8px;
    }

    .studio_close{
        width:42px;
        height:42px;
        font-size:28px;
        line-height:42px;
    }

    .studio_thumb{
        width:54px;
        height:54px;
    }

}

@media (max-width:480px){

    .studio_grid{
        column-count:2;
        column-gap:8px;
    }

    .studio_item{
        margin-bottom:8px;
    }

    .studio_modal_content{
        height:62vh;
    }

    .studio_modal_thumbs{
        gap:6px;
        padding:8px 10px;
    }

    .studio_thumb{
        width:48px;
        height:48px;
    }

}