/* ======================================
   VIDEO PAGE
====================================== */

.video-page{
    padding:40px 0;
}

.video-page .video-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:26px;
}

.video-page .video-title-group{
    display:flex;
    flex-direction:column;
}

.video-page .video-heading{
    font-size:26px;
    font-weight:700;
    color:var(--primary);
    margin:0;
}

.video-page .video-heading::after{
    content:"";
    display:block;
    width:60px;
    height:3px;
    background:var(--accent);
    margin-top:8px;
    border-radius:2px;
}

.video-page .video-tagline{
    font-size:14px;
    color:var(--text-light);
    margin-top:6px;
}

/* WRAPPER */

.video-page .video-slider-wrapper{
    overflow:visible;
}

.video-page .video-slider-track{
    display:grid;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:24px;
}

/* CARD */

.video-page .video-card{
    border-radius:12px;
    overflow:hidden;
    position:relative;
    box-shadow:0 8px 25px rgba(0,0,0,.05);
    width:100%;
    cursor:pointer;
}

.video-page .video-card:hover{
    transform:none;
    box-shadow:0 8px 25px rgba(0,0,0,.05);
}

.video-page .video-image{
    aspect-ratio:16/10;
    position:relative;
    display:block;
    overflow:hidden;
    cursor:pointer;
    text-decoration:none;
    color:inherit;
}

.video-page .video-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.video-page .video-card:hover img{
    transform:none;
}

.video-page .video-overlay{
    gap:10px;
    position:absolute;
    inset:0;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    padding:16px;
    align-items:center;
    text-align:center;
    background:linear-gradient(
        to top,
        rgba(0,0,0,.8),
        rgba(0,0,0,.4),
        transparent
    );
    color:#fff;
    opacity:1;
}

.video-page .video-card:hover .video-overlay{
    transform:none;
}

/* BADGE */

.video-page .video-badge{
    position:absolute;
    top:12px;
    right:12px;
    background:#fff;
    color:#e53935;
    font-size:10px;
    font-weight:600;
    padding:4px 8px;
    border-radius:20px;
    box-shadow:0 2px 6px rgba(0,0,0,.12);
    pointer-events:none;
}

/* PLAY BUTTON */

.video-page .video-play{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:10px;
}

.video-page .video-play img{
    width:50px;
    height:50px;
    object-fit:contain;
    display:block;
    filter:drop-shadow(0 4px 10px rgba(0,0,0,.4));
}

.video-page .video-card:hover .video-play{
    transform:translate(-50%, -50%);
}

/* TITLE */

.video-page .video-title{
    font-size:16px;
    max-width:80%;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
    min-height:42px;
    color:#fff;
}

/* POPUP */

#video-popup{
    position:fixed;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(0,0,0,.85);
    opacity:0;
    visibility:hidden;
    transition:.35s;
    z-index:9999;
    padding:40px;
    backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);
}

#video-popup.active{
    opacity:1;
    visibility:visible;
}

.video-popup-content{
    position:relative;
    width:100%;
    max-width:900px;
    aspect-ratio:16/9;
    transform:scale(.9);
    transition:.35s ease;
}

#video-popup.active .video-popup-content{
    transform:scale(1);
}

.video-popup-player{
    width:100%;
    height:100%;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 30px 80px rgba(0,0,0,.5);
}

.video-popup-player iframe{
    width:100%;
    height:100%;
    border:0;
}

.video-popup-close{
    position:absolute;
    top:-45px;
    right:0;
    background:#fff;
    border:none;
    width:36px;
    height:36px;
    border-radius:50%;
    cursor:pointer;
    font-size:18px;
    font-weight:bold;
    transition:.25s;
}

.video-popup-close:hover{
    transform:scale(1.1);
}

/* RESPONSIVE */

@media (max-width:992px){
    .video-page .video-slider-track{
        grid-template-columns:repeat(2, minmax(0,1fr));
        gap:20px;
    }
}

@media (max-width:768px){
    .video-page{
        padding:30px 0;
    }

    .video-page .video-slider-track{
        display:grid !important;
        grid-template-columns:repeat(2, minmax(0,1fr));
        gap:16px;
    }

    .video-page .video-card{
        width:100%;
        flex:unset !important;
    }

    .video-page .video-title{
        font-size:12px;
        line-height:1.3;
        min-height:32px;
        max-width:90%;
    }

    .video-page .video-play img{
        width:36px;
        height:36px;
    }

    .video-page .video-play{
        top:42%;
    }

    #video-popup{
        padding:20px;
    }

    .video-popup-close{
        top:-40px;
    }
}

@media (max-width:520px){
    .video-page .video-slider-track{
        grid-template-columns:1fr;
        gap:18px;
    }
}