:root{
    --bg:#F8FAFC;
    --card:#FFFFFF;
    --card-light:#F1F5F9;
    --accent:#2563EB;
    --text:#0F172A;
    --muted:#64748B;
}
/* ================================================================================================================================================ */
.ppsmf-entry{
    width:100%;
    display:flex;
    justify-content:center;
    margin:90px 0;
}
#ppsmfOpen{
    padding:16px 36px;
    background:var(--accent);
    color:white;
    border:none;
    border-radius:14px;
    font-size:15px;
    font-weight:600;
    cursor:pointer;
    transition:.3s ease;
    box-shadow:0 10px 30px rgba(37,99,235,.25);
}
#ppsmfOpen:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 50px rgba(37,99,235,.35);
}
/* ================================================================================================================================================ */
.ppsmf-modal{
    position:fixed;
    inset:0;
    background:rgba(3,7,18,.92);
    backdrop-filter:blur(16px);
    z-index:999999;
    display:none;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:40px 0;
}
.ppsmf-viewer{
    width:min(1200px,92%);
    height:auto;
    height:85vh;
    background:var(--card);
    border-radius:28px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    box-shadow:0 60px 140px rgba(0,0,0,.45);
    border:1px solid rgba(0, 191, 255, 1);
}
.ppsmf-image{
    position:relative;
    background:#0b0f1a;
    overflow:hidden;
}
.ppsmf-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    animation:imgIn .7s ease;
    transition: filter .35s ease, opacity .35s ease, transform .35s ease;
}
.ppsmf-image.is-exit img{
    opacity: 0;
    filter: blur(14px);
    transform: scale(1.04);
}
.ppsmf-image.is-enter img{
    opacity: 1;
    filter: blur(0px);
    transform: scale(1);
}
.ppsmf-main{
    display:grid;
    grid-template-columns:1.6fr 1fr;
    min-height:85vh;
}
@keyframes imgIn{
    from{
        transform:scale(1.08);
        opacity:.3;
    }
    to{
        transform:scale(1);
        opacity:1;
    }
}
.ppsmf-image::after{
    content:"";
    position:absolute;
    top:-20%;
    left:-50%;
    width:40%;
    height:140%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), rgba(255,255,255,.18), rgba(255,255,255,.08), transparent);
    transform:skewX(-10deg);
    filter:blur(10px);
    opacity:0;
}
.ppsmf-image.glow-next::after{
    animation: sweepRight 1.8s ease;
    opacity:1;
}
.ppsmf-image.glow-prev::after{
    animation: sweepLeft 1.8s ease;
    opacity:1;
}
@keyframes sweepRight {
    from {
        left: -60%;
        opacity: 0;
    }
    20% {
        opacity: 1;
    }
    to {
        left: 160%;
        opacity: 0;
    }
}
@keyframes sweepLeft {
    from {
        left: 160%;
        opacity: 0;
    }
    20% {
        opacity: 1;
    }
    to {
        left: -60%;
        opacity: 0;
    }
}
/* ================================================================================================================================================ */
.ppsmf-info{
    padding:54px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    color:var(--text);
    background:linear-gradient(to bottom, #fff, #f8fafc);
}
#ppsmfCat{
    display:inline-flex;
    width:max-content;
    padding:10px 16px;
    border-radius:999px;
    background:rgba(37,99,235,.10);
    color:var(--accent);
    font-size:12px;
    letter-spacing:2px;
    text-transform:uppercase;
    font-weight:600;
}
#ppsmfTitle{
    margin-top:22px;
    font-size:38px;
    line-height:1.15;
    font-weight:700;
}
#ppsmfDesc{
    margin-top:18px;
    color:var(--muted);
    font-size:16px;
    line-height:1.7;
}
/* ================================================================================================================================================ */
.ppsmf-meta{
    margin-top:34px;
    gap:14px;
}
.ppsmf-meta div{
    padding:18px;
    background:var(--card-light);
    border:1px solid #e2e8f0;
    border-radius:16px;
}
.ppsmf-meta strong{
    display:block;
    font-size:11px;
    letter-spacing:2px;
    text-transform:uppercase;
    color:var(--accent);
    margin-bottom:6px;
}
.ppsmf-meta p{
    margin:0;
    font-size:15px;
    color:var(--text);
}
/* ================================================================================================================================================ */
.ppsmf-close,
.ppsmf-prev,
.ppsmf-next{
    position:absolute;
    width:54px;
    height:54px;
    border:none;
    border-radius:50%;
    background:rgba(255,255,255,.10);
    backdrop-filter:blur(14px);
    color:white;
    font-size:22px;
    cursor:pointer;
    transition:.25s ease;
}
.ppsmf-close{
    top:22px;
    right:22px;
}
.ppsmf-prev{
    left:22px;
    top:50%;
    transform:translateY(-50%);
}
.ppsmf-next{
    right:22px;
    top:50%;
    transform:translateY(-50%);
}
.ppsmf-close:hover,
.ppsmf-prev:hover,
.ppsmf-next:hover{
    background:var(--accent);
    transform:translateY(-50%) scale(1.08);
}
.ppsmf-close:hover{
    transform:scale(1.08);
}
/* ================================================================================================================================================ */
@media (max-width: 900px){
    .ppsmf-viewer{ grid-template-columns:1fr; height:90vh; }
    .ppsmf-info{ padding:28px; }
    #ppsmfTitle{ font-size:28px; }
    .ppsmf-meta{ grid-template-columns:1fr; }
    .ppsmf-prev,
    .ppsmf-next{ top:auto; bottom:20px; transform:none; }
    .ppsmf-prev{ left:20px; }
    .ppsmf-next{ right:20px; }
}
/* ================================================================================================================================================ */
.ppsmf-thumbs{
    width:min(1200px,92%);
    margin-top:16px;
    display:flex;
    gap:12px;
    padding:14px;
    background:rgba(255,255,255,.06);
    backdrop-filter:blur(18px);
    border-radius:18px;
    overflow-x:auto;
    overflow-y:hidden;
    justify-content:flex-start;
    scroll-behavior:smooth;
    flex-shrink:0;
    scroll-snap-type: x mandatory;
}
.ppsmf-thumbs::-webkit-scrollbar{
    display:none;
}
.ppsmf-thumb{
    position:relative;
    width:110px;
    height:70px;
    flex-shrink:0;
    border-radius:12px;
    overflow:hidden;
    cursor:pointer;
    border:2px solid transparent;
    transition:.25s ease;
}
.ppsmf-thumb{
    scroll-snap-align: center;
}
.ppsmf-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.ppsmf-thumb:hover{
    transform:translateY(-3px);
}
.ppsmf-thumb.active{
    border-color:var(--accent);
}
.ppsmf-thumb::after{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    height:3px;
    width:0%;
    background:var(--accent);
    transition:width .35s ease;
}
.ppsmf-thumb.active::after{
    width:100%;
}
/* ================================================================================================================================================ */
