.container-page-shortPlayer .short-image-stage,
.container-page-shortPlayer .short-text-stage {
    display: none;
}

.container-page-shortPlayer.is-image-post .short-videoPlayer,
.container-page-shortPlayer.is-text-post .short-videoPlayer {
    display: none;
}

.container-page-shortPlayer.is-image-post .short-image-stage,
.container-page-shortPlayer.is-text-post .short-text-stage {
    display: flex;
}

.container-page-shortPlayer.is-image-post .video-volume,
.container-page-shortPlayer.is-text-post .video-volume,
.container-page-shortPlayer.is-image-post .videoTimeCurrent,
.container-page-shortPlayer.is-image-post .videoTimeTotal,
.container-page-shortPlayer.is-image-post .video-progress,
.container-page-shortPlayer.is-text-post .videoTimeCurrent,
.container-page-shortPlayer.is-text-post .videoTimeTotal,
.container-page-shortPlayer.is-text-post .video-progress {
    display: none !important;
}

.container-page-shortPlayer.is-image-post .player-corners,
.container-page-shortPlayer.is-text-post .player-corners {
    width: min(720px, calc(100vw - 140px));
    height: calc(100vh - 20px);
    background: #050505;
}

.short-image-stage,
.short-text-stage {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.short-image-track {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.short-image-slide {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.35s ease;
    will-change: transform;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.08), transparent 35%),
        linear-gradient(180deg, rgba(24, 24, 24, 0.98), rgba(7, 7, 7, 1));
}

.short-image-slide img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.short-carousel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.48);
    color: #fff;
    z-index: 3;
}

.short-carousel-nav.prev {
    left: 12px;
}

.short-carousel-nav.next {
    right: 12px;
}

.short-carousel-nav.is-hidden,
.short-carousel-dots.is-hidden {
    display: none !important;
}

.short-carousel-dots {
    position: absolute;
    left: 50%;
    bottom: 102px;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    gap: 7px;
    z-index: 5;
    width: min(82%, 460px);
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(7, 10, 14, 0.56);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(18px);
    pointer-events: auto;
}

.short-carousel-dot {
    position: relative;
    flex: 1 1 0;
    min-width: 14px;
    height: 6px;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    padding: 0;
    overflow: hidden;
}

.short-carousel-dot-fill {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #f9f7ee 0%, #ffffff 68%, #efe6bf 100%);
    transition: width 0.28s ease, opacity 0.28s ease, transform 0.28s ease, box-shadow 0.28s ease;
    opacity: 0.42;
}

.short-carousel-dot.is-completed .short-carousel-dot-fill,
.short-carousel-dot.is-active .short-carousel-dot-fill {
    width: 100%;
}

.short-carousel-dot.is-completed .short-carousel-dot-fill {
    opacity: 0.68;
}

.short-carousel-dot.is-active {
    background: rgba(255, 255, 255, 0.22);
}

.short-carousel-dot.is-active .short-carousel-dot-fill {
    opacity: 1;
    transform: scaleY(1.15);
    box-shadow: 0 0 14px rgba(255, 248, 214, 0.42);
}

.short-carousel-ellipsis {
    flex: 0 0 auto;
    color: rgba(255, 255, 255, 0.5);
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.12em;
    user-select: none;
}

.short-carousel-status {
    flex: 0 0 auto;
    margin-left: 4px;
    color: rgba(255, 255, 255, 0.92);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.short-text-stage {
    align-items: center;
    justify-content: center;
    padding: 24px;
    background:
        radial-gradient(circle at 15% 15%, rgba(255, 168, 76, 0.18), transparent 25%),
        radial-gradient(circle at 85% 20%, rgba(77, 191, 180, 0.16), transparent 24%),
        radial-gradient(circle at 50% 100%, rgba(255, 255, 255, 0.08), transparent 30%),
        linear-gradient(165deg, #171c26 0%, #0e1219 52%, #090b10 100%);
}

.short-text-card {
    position: relative;
    width: min(540px, 100%);
    max-height: 100%;
    padding: 28px 24px 24px;
    border-radius: 28px;
    overflow: auto;
    color: #fff;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.05));
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.36);
    backdrop-filter: blur(16px);
    overscroll-behavior: contain;
}

.short-text-card::before {
    content: "\201C";
    position: absolute;
    top: 6px;
    left: 16px;
    font-size: 72px;
    line-height: 1;
    color: rgba(255, 255, 255, 0.14);
}

.short-text-eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.82);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.short-text-body {
    margin-top: 18px;
    font-size: clamp(20px, 2.8vw, 30px);
    line-height: 1.45;
    white-space: pre-wrap;
    word-break: break-word;
}

.short-text-meta {
    margin-top: 20px;
    color: rgba(255, 255, 255, 0.64);
    font-size: 13px;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.container-page-shortPlayer.is-image-post .video-title,
.container-page-shortPlayer.is-text-post .video-title {
    opacity: 1;
    z-index: 4;
    pointer-events: auto;
}

@media (max-width: 576px) {
    .container-page-shortPlayer.is-image-post .player-corners,
    .container-page-shortPlayer.is-text-post .player-corners {
        width: calc(100vw - 20px);
    }

    .short-text-stage {
        padding: 14px;
    }

    .short-text-card {
        width: 100%;
        padding: 22px 18px 20px;
        border-radius: 22px;
    }

    .short-carousel-nav {
        width: 34px;
        height: 34px;
    }

    .short-carousel-dots {
        bottom: 92px;
        width: min(82%, 360px);
        padding: 9px 12px;
        gap: 6px;
    }

    .short-carousel-dot {
        min-width: 12px;
        height: 5px;
    }

    .short-carousel-status {
        font-size: 11px;
    }

    .short-carousel-ellipsis {
        font-size: 12px;
    }
}
