/* сетка карточек */

.wp-sjp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill,minmax(180px,1fr));
    gap: 16px;
}

.wp-sjp-card {
    background: #111;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    color: #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.4);
    transition: transform .15s ease, box-shadow .15s ease;
}

.wp-sjp-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(0,0,0,0.6);
}

.wp-sjp-thumb-wrapper {
    position: relative;
    background: #000;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.wp-sjp-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.wp-sjp-thumb-placeholder {
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:18px;
    background:#222;
    color:#eee;
}

.wp-sjp-badge-online {
    position:absolute;
    left:8px;
    top:8px;
    background:#e53935;
    color:#fff;
    padding:2px 6px;
    font-size:11px;
    border-radius:3px;
    text-transform:uppercase;
    letter-spacing:.03em;
}

.wp-sjp-badge-viewers {
    position:absolute;
    right:8px;
    bottom:8px;
    background:rgba(0,0,0,.7);
    color:#fff;
    padding:2px 6px;
    font-size:11px;
    border-radius:3px;
}

.wp-sjp-info {
    padding:8px 10px;
}

.wp-sjp-name {
    font-weight:600;
    font-size:14px;
    margin-bottom:2px;
}

.wp-sjp-username {
    font-size:12px;
    color:#aaa;
}

/* пагинация */

.wp-sjp-pagination {
    margin-top:16px;
    text-align:center;
}

.wp-sjp-page {
    display:inline-block;
    margin:0 4px;
    padding:4px 8px;
    font-size:13px;
    color:#eee;
    background:#222;
    border-radius:4px;
    text-decoration:none;
}

.wp-sjp-page.current {
    background:#e53935;
}

/* модалка */

.wp-sjp-modal {
    position:fixed;
    left:0; top:0;
    width:100%;
    height:100%;
    display:none;
    z-index:9999;
}

.wp-sjp-modal.active {
    display:block;
}

.wp-sjp-modal-backdrop {
    position:absolute;
    left:0; top:0;
    right:0; bottom:0;
    background:rgba(0,0,0,.8);
}

.wp-sjp-modal-dialog {
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    width:95%;
    max-width:1200px;
    max-height:90%;
    background:#121212;
    border-radius:10px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    box-shadow:0 0 0 1px rgba(255,255,255,.05);
}

.wp-sjp-modal-close {
    position:absolute;
    right:8px;
    top:8px;
    background:transparent;
    border:none;
    color:#fff;
    font-size:24px;
    cursor:pointer;
    z-index:2;
}

.wp-sjp-modal-header {
    padding:10px 40px 10px 14px;
    border-bottom:1px solid #1f1f1f;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.wp-sjp-modal-title {
    font-weight:600;
    font-size:15px;
    color:#fff;
}

.wp-sjp-modal-body {
    flex:1;
    display:flex;
    min-height:0;
}

.wp-sjp-modal-left,
.wp-sjp-modal-right {
    padding:10px;
    box-sizing:border-box;
}

.wp-sjp-modal-left {
    flex:2;
    display:flex;
    flex-direction:column;
}

.wp-sjp-profile-bar {
    margin-bottom:8px;
    font-size:13px;
    color:#eee;
}

.wp-sjp-profile-name {
    font-weight:600;
    margin-bottom:4px;
}

.wp-sjp-profile-meta span {
    margin-right:8px;
    font-size:12px;
    color:#bbb;
}

.wp-sjp-profile-bio {
    margin-top:4px;
    font-size:12px;
    color:#ccc;
}

.wp-sjp-player-wrapper {
    flex:1;
    background:#000;
    border-radius:6px;
    overflow:hidden;
}

.wp-sjp-player-video {
    width:100%;
    height:100%;
    background:#000;
}

.wp-sjp-modal-right {
    flex:1.2;
    border-left:1px solid #1f1f1f;
    display:flex;
    flex-direction:column;
}

/* чат внутри модалки */

.wp-sjp-chat-wrapper {
    display:flex;
    flex-direction:column;
    height:100%;
}

.wp-sjp-chat-tabs {
    display:flex;
    border-bottom:1px solid #1f1f1f;
}

.wp-sjp-chat-tab {
    flex:1;
    padding:6px 8px;
    font-size:12px;
    border:none;
    background:#181818;
    color:#aaa;
    cursor:pointer;
}

.wp-sjp-chat-tab.active {
    background:#262626;
    color:#fff;
    font-weight:600;
}

.wp-sjp-chat-room {
    flex:1;
    display:flex;
    flex-direction:column;
    min-height:0;
}

.wp-sjp-chat-messages {
    flex:1;
    padding:6px 8px;
    overflow-y:auto;
    font-size:12px;
    color:#eee;
}

.wp-sjp-chat-form {
    border-top:1px solid #1f1f1f;
    padding:6px 8px;
    display:flex;
    flex-direction:column;
    gap:4px;
}

.wp-sjp-chat-form input[type="text"],
.wp-sjp-chat-form textarea {
    width:100%;
    box-sizing:border-box;
    background:#111;
    border:1px solid #333;
    color:#eee;
    padding:4px 6px;
    font-size:12px;
    border-radius:3px;
}

.wp-sjp-chat-form textarea {
    resize:vertical;
}

.wp-sjp-chat-send {
    align-self:flex-end;
    padding:4px 10px;
    font-size:12px;
    border:none;
    border-radius:3px;
    cursor:pointer;
    background:#e53935;
    color:#fff;
}

.wp-sjp-chat-message {
    margin-bottom:3px;
}

.wp-sjp-chat-time {
    color:#888;
    margin-right:4px;
}

.wp-sjp-chat-name {
    font-weight:600;
    margin-right:4px;
}

.wp-sjp-chat-text {
    color:#f5f5f5;
}

/* адаптив */

@media (max-width: 900px) {
    .wp-sjp-modal-dialog {
        max-width:100%;
        max-height:100%;
        border-radius:0;
    }
    .wp-sjp-modal-body {
        flex-direction:column;
    }
    .wp-sjp-modal-right {
        border-left:none;
        border-top:1px solid #1f1f1f;
    }
}
