.site-topbar {
    background: #1e1e1e;
    padding: 15px 25px;
    margin: 18px 0 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    border-radius: 12px;
    border: 1px solid #2a313d;
}

.site-brand a {
    color: #fff;
    text-decoration: none;
    font-size: 24px;
    font-weight: 700;
}

.site-nav {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.site-nav-link {
    color: #d7dde8;
    text-decoration: none;
    padding: 8px 14px;
    border-radius: 999px;
    background: #171b22;
    border: 1px solid #2f3642;
}

.site-nav-link.active {
    background: linear-gradient(135deg, #90d060, #4CAF50);
    color: #0f141a;
    border-color: transparent;
    font-weight: 700;
}

.video-page {
    padding-bottom: 40px;
}

.video-hero,
.video-title-hero,
.video-admin-panel,
.video-admin-item,
.video-sidebar-card,
.video-player-shell,
.video-promo-card {
    background: linear-gradient(180deg, #1b1f28, #151922);
    border: 1px solid #2b3340;
    border-radius: 18px;
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.24);
}

.custom-player.is-mirrored video {
    transform: scaleX(-1);
}

.custom-player.is-upside-down video {
    transform: scaleY(-1);
}

.custom-player.is-mirrored.is-upside-down video {
    transform: scale(-1, -1);
}

.custom-player.is-rotated-90 video {
    object-fit: contain;
    transform: rotate(90deg) scale(1.7777778);
}

.custom-player.is-rotated-90.is-mirrored video {
    object-fit: contain;
    transform: rotate(90deg) scaleX(-1) scale(1.7777778);
}

.custom-player.is-rotated-90.is-upside-down video {
    object-fit: contain;
    transform: rotate(90deg) scaleY(-1) scale(1.7777778);
}

.custom-player.is-rotated-90.is-mirrored.is-upside-down video {
    object-fit: contain;
    transform: rotate(90deg) scale(-1, -1) scale(1.7777778);
}

.custom-player.is-rotated-minus-90 video {
    object-fit: contain;
    transform: rotate(-90deg) scale(1.7777778);
}

.custom-player.is-rotated-minus-90.is-mirrored video {
    object-fit: contain;
    transform: rotate(-90deg) scaleX(-1) scale(1.7777778);
}

.custom-player.is-rotated-minus-90.is-upside-down video {
    object-fit: contain;
    transform: rotate(-90deg) scaleY(-1) scale(1.7777778);
}

.custom-player.is-rotated-minus-90.is-mirrored.is-upside-down video {
    object-fit: contain;
    transform: rotate(-90deg) scale(-1, -1) scale(1.7777778);
}

.video-hero {
    padding: 28px;
    margin-bottom: 24px;
    background:
        radial-gradient(circle at top right, rgba(76, 175, 80, 0.18), transparent 28%),
        linear-gradient(180deg, #1b1f28, #151922);
}

.video-kicker {
    color: #90d060;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
    margin-bottom: 10px;
}

.video-subtitle {
    max-width: 760px;
    color: #9ba7bc;
}

.video-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 18px;
}

.video-catalog-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    align-items: start;
}

.video-card {
    overflow: hidden;
    border-radius: 18px;
    background: #171b22;
    border: 1px solid #2a313d;
    min-width: 0;
}

.video-catalog-grid .video-card {
    display: flex;
    flex-direction: column;
}

.video-poster-link {
    display: block;
}

.video-catalog-poster-shell {
    position: relative;
    overflow: hidden;
}

.video-poster,
.video-title-poster,
.video-admin-thumb {
    width: 100%;
    display: block;
    object-fit: cover;
    background: #12161d;
}

.video-poster {
    aspect-ratio: 2 / 3;
}

.video-catalog-overlay {
    position: absolute;
    inset: auto 0 0;
    padding: 42px 16px 18px;
    background: linear-gradient(180deg, rgba(4, 8, 14, 0) 0%, rgba(4, 8, 14, 0.88) 72%, rgba(4, 8, 14, 0.98) 100%);
    text-align: center;
}

.video-catalog-title {
    margin: 0;
    color: #fff;
    font-size: 1.05rem;
    line-height: 1.25;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
}

.video-catalog-count {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(8, 14, 24, 0.76);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    backdrop-filter: blur(10px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
}

.video-title-hero {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 20px;
    padding: 20px;
    margin-bottom: 24px;
}

.video-title-hero-wide {
    grid-template-columns: 180px minmax(0, 1fr);
    align-items: start;
}

.video-title-back-actions {
    margin-bottom: 16px;
}

.video-title-cover {
    min-width: 0;
}

.video-title-cover-button {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.video-title-poster {
    aspect-ratio: 2 / 3;
    border-radius: 14px;
}

.video-title-cover-count {
    position: absolute;
    right: 10px;
    bottom: 10px;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(8, 14, 24, 0.84);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    backdrop-filter: blur(10px);
}

.video-title-copy,
.video-card-body {
    padding: 18px;
}

.video-title-copy {
    display: grid;
    align-content: start;
    gap: 16px;
    text-align: left;
}

.video-catalog-grid .video-card-body {
    padding: 14px 16px 16px;
}

.video-title-copy p,
.video-card-body p,
.video-admin-titlebox p,
.video-empty {
    color: #9ba7bc;
}

.video-title-heading {
    margin: 0;
    width: 100%;
    justify-self: stretch;
    color: #fff;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
    text-align: left;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.video-title-description {
    margin: 0;
    max-width: 100%;
    line-height: 1.75;
}

.video-title-alternative-names {
    margin: -6px 0 0;
    max-width: 900px;
    color: #b8c4d8;
    font-size: 14px;
    font-weight: 650;
    line-height: 1.45;
}

.video-title-alternative-names::before {
    content: "";
    display: inline-block;
    width: 22px;
    height: 1px;
    margin-right: 9px;
    background: linear-gradient(90deg, rgba(141, 162, 198, 0.1), rgba(141, 162, 198, 0.82));
    vertical-align: middle;
}

.video-title-gallery-strip {
    margin-bottom: 24px;
    overflow: hidden;
}

.video-title-user-screenshots {
    margin-top: 24px;
    margin-bottom: 24px;
}

.video-title-user-screenshots-header p {
    margin: 8px 0 0;
    color: #93a3bc;
}

.video-title-user-screenshots-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.video-title-user-shot-card {
    position: relative;
    display: block;
    padding: 0;
    border: 1px solid #2a313d;
    border-radius: 16px;
    overflow: hidden;
    background: #11151d;
    cursor: pointer;
    text-align: left;
}

.video-title-user-shot-card img {
    display: block;
    width: 100%;
    aspect-ratio: 0.84;
    object-fit: cover;
}

.video-title-user-shot-overlay {
    position: absolute;
    inset: auto 10px 10px 10px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 10px 12px;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(4, 8, 16, 0.08), rgba(4, 8, 16, 0.82));
    color: #f5f7fb;
}

.video-title-user-shot-overlay strong,
.video-title-user-shot-overlay span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.video-title-user-shot-description {
    font-size: 11px;
    color: rgba(245, 247, 251, 0.7);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.video-title-user-shot-link,
.video-title-lightbox-meta a {
    color: #f5f7fb;
    text-decoration: none;
}

.video-title-user-shot-link:hover,
.video-title-lightbox-meta a:hover {
    text-decoration: underline;
}

.video-title-lightbox-meta a.is-disabled-link {
    pointer-events: none;
}

.video-title-gallery-marquee {
    overflow: hidden;
    cursor: pointer;
}

.video-title-gallery-track {
    display: flex;
    gap: 14px;
    width: max-content;
    animation: video-gallery-scroll 42s linear infinite;
}

.video-title-gallery-marquee:hover .video-title-gallery-track {
    animation-play-state: paused;
}

.video-title-gallery-card {
    flex: 0 0 auto;
    width: 260px;
    padding: 0;
    border: 1px solid #2a313d;
    border-radius: 16px;
    overflow: hidden;
    background: #11151d;
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.24);
}

.video-title-gallery-card img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.video-title-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.video-title-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(5, 8, 14, 0.88);
}

.video-title-lightbox-dialog {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr) 56px;
    align-items: center;
    gap: 18px;
    width: min(92vw, 1280px);
    height: 100%;
    margin: 0 auto;
}

.video-title-lightbox-content {
    min-width: 0;
}

.video-title-lightbox-figure {
    margin: 0;
}

.video-title-lightbox-figure img {
    display: block;
    width: 100%;
    max-height: 82vh;
    object-fit: contain;
    border-radius: 18px;
    background: #0e131c;
}

.video-title-lightbox-figure figcaption {
    margin-top: 12px;
    color: #d7dde8;
    text-align: center;
}

.video-title-lightbox-meta {
    margin-top: 16px;
    display: grid;
    gap: 8px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid #2b3340;
    background: rgba(12, 17, 24, 0.94);
    color: #dbe4f2;
}

.video-title-lightbox-meta.hidden {
    display: none;
}

.video-title-lightbox-desc-textarea {
    width: 100%;
    resize: vertical;
    margin-top: 6px;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid #2b3340;
    background: rgba(17, 24, 35, 0.85);
    color: #dbe4f2;
    font-size: 13px;
    font-family: inherit;
}

.video-title-lightbox-desc-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-top: 6px;
}

.video-title-lightbox-desc-count {
    font-size: 12px;
    color: rgba(219, 228, 242, 0.5);
}

.video-title-lightbox-desc-save {
    padding: 5px 14px;
    border-radius: 10px;
    border: 1px solid #2b3340;
    background: rgba(90, 140, 255, 0.18);
    color: #dbe4f2;
    font-size: 13px;
    cursor: pointer;
}

.video-title-lightbox-desc-save:hover {
    background: rgba(90, 140, 255, 0.32);
}

.video-title-lightbox-desc-save:disabled {
    opacity: 0.5;
    cursor: default;
}

.video-title-lightbox-desc-edit.hidden {
    display: none;
}

.video-title-user-shot-card.is-live-preview {
    opacity: 0.85;
}

.video-title-lightbox-close,
.video-title-lightbox-nav {
    border: 0;
    border-radius: 999px;
    background: rgba(17, 24, 35, 0.82);
    color: #fff;
    font-size: 32px;
    line-height: 1;
    cursor: pointer;
}

.video-title-lightbox-close {
    position: absolute;
    top: 22px;
    right: 22px;
    z-index: 2;
    width: 48px;
    height: 48px;
}

.video-title-lightbox-nav {
    width: 56px;
    height: 56px;
}

body.video-title-lightbox-open {
    overflow: hidden;
}

.video-admin-cover-trigger {
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.video-admin-title-image-strip {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 6px;
}

.video-admin-title-media-section {
    display: grid;
    gap: 10px;
}

.video-admin-section-inline-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.video-admin-section-inline-head form {
    margin: 0;
}

.video-admin-modal-body {
    gap: 12px;
}

.video-admin-accordion,
.video-admin-subdetails,
.video-admin-filter-details {
    border: 1px solid #27384d;
    border-radius: 14px;
    background: rgba(10, 15, 24, 0.48);
    overflow: hidden;
}

.video-admin-accordion[open],
.video-admin-subdetails[open],
.video-admin-filter-details[open] {
    border-color: rgba(95, 176, 255, 0.34);
    background: linear-gradient(180deg, rgba(16, 23, 34, 0.82), rgba(10, 15, 24, 0.62));
}

.video-admin-accordion-summary,
.video-admin-subdetails summary,
.video-admin-filter-details summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 48px;
    padding: 12px 14px;
    cursor: pointer;
    list-style: none;
    scroll-margin-top: 140px;
}

.video-admin-accordion-summary::-webkit-details-marker,
.video-admin-subdetails summary::-webkit-details-marker,
.video-admin-filter-details summary::-webkit-details-marker {
    display: none;
}

.video-admin-accordion-summary > span:first-child,
.video-admin-subdetails summary > span:first-child,
.video-admin-filter-details summary > span:first-child {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.video-admin-accordion-summary strong,
.video-admin-subdetails summary strong,
.video-admin-filter-details summary strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.video-admin-accordion-summary small,
.video-admin-subdetails summary small,
.video-admin-filter-details summary small {
    color: #93a3bc;
    font-size: 12px;
    line-height: 1.35;
}

.video-admin-accordion-summary::after,
.video-admin-subdetails summary::after,
.video-admin-filter-details summary::after {
    content: "";
    flex: 0 0 auto;
    width: 8px;
    height: 8px;
    border-right: 2px solid #90d060;
    border-bottom: 2px solid #90d060;
    transform: rotate(45deg);
    transition: transform 0.18s ease;
}

.video-admin-accordion[open] > .video-admin-accordion-summary::after,
.video-admin-subdetails[open] > summary::after,
.video-admin-filter-details[open] > summary::after {
    transform: rotate(-135deg) translate(-2px, -2px);
}

.video-admin-accordion-body,
.video-admin-subdetails-body {
    display: grid;
    gap: 12px;
    padding: 0 14px 14px;
}

.video-admin-section-form,
.video-admin-form-panel {
    display: grid;
    gap: 12px;
}

.video-admin-subdetails,
.video-admin-filter-details {
    background: rgba(9, 14, 22, 0.58);
}

.video-admin-create-subdetails {
    border-style: dashed;
}

.video-admin-filter-accordion-list {
    display: grid;
    gap: 8px;
}

.video-admin-filter-details summary > span:last-child {
    color: #90d060;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.video-admin-filter-details .video-admin-filter-values {
    padding: 0 12px 12px;
}

.video-admin-season-body {
    display: grid;
    gap: 12px;
    padding: 0 12px 12px;
}

.video-admin-season-body > .video-admin-form {
    padding: 0;
}

.video-admin-legacy-sync-note {
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px dashed rgba(255, 178, 102, 0.42);
    border-radius: 12px;
    background: rgba(70, 46, 16, 0.28);
}

.video-admin-legacy-sync-note strong {
    color: #ffd7ad;
}

.video-admin-legacy-sync-note span {
    color: #c8a77f;
    font-size: 12px;
    line-height: 1.45;
}

.video-admin-legacy-sync-note input[readonly] {
    opacity: 0.82;
}

.video-admin-inline-form {
    margin: 0;
}

.video-admin-deleted-episode-details.video-admin-accordion summary::before {
    content: none;
}

.video-admin-season-details {
    border: 1px solid #27384d;
    border-radius: 10px;
    background: rgba(10, 15, 24, 0.5);
    overflow: hidden;
}

.video-admin-season-details summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    cursor: pointer;
    list-style: none;
}

.video-admin-season-details summary::-webkit-details-marker {
    display: none;
}

.video-admin-season-details summary > span:first-child {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.video-admin-season-details summary strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.video-admin-season-details summary small {
    color: #93a3bc;
}

.video-admin-season-details .video-admin-form {
    padding: 0 12px 12px;
}

.video-admin-season-details .video-admin-season-body > .video-admin-form {
    padding: 0;
}

.video-admin-season-delete-form {
    display: grid;
    gap: 10px;
    padding: 12px !important;
    border: 1px solid rgba(255, 92, 92, 0.32);
    border-radius: 12px;
    background: rgba(70, 20, 24, 0.22);
}

.video-admin-season-delete-form small,
.video-admin-season-delete-disabled {
    color: #c9a0a4;
    font-size: 12px;
    line-height: 1.45;
}

.video-admin-season-delete-disabled {
    padding: 10px 12px;
    border: 1px dashed rgba(255, 92, 92, 0.25);
    border-radius: 12px;
}

.video-admin-deleted-episode-details {
    display: block;
}

.video-admin-deleted-episode-details summary {
    cursor: pointer;
    list-style: none;
}

.video-admin-deleted-episode-details summary::-webkit-details-marker {
    display: none;
}

.video-admin-deleted-episode-details summary::before {
    content: "▸";
    color: #93a3bc;
    font-size: 12px;
    transform: translateY(1px);
}

.video-admin-deleted-episode-details[open] summary::before {
    content: "▾";
}

.video-admin-deleted-episode-details summary strong span {
    color: #93a3bc;
    font-weight: 600;
}

.video-admin-deleted-episode-list {
    display: grid;
    gap: 6px;
    max-height: 280px;
    overflow: auto;
    padding-right: 6px;
}

.video-admin-deleted-episode-row {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 7px 9px;
    border: 1px dashed #32435a;
    border-radius: 8px;
    background: rgba(10, 15, 24, 0.45);
}

.video-admin-deleted-episode-row span {
    color: #93a3bc;
    font-size: 12px;
}

.video-admin-deleted-episode-row a {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #d7e5ff;
    font-weight: 600;
}

.video-admin-title-media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}

.video-admin-title-media-card {
    display: grid;
    gap: 8px;
    padding: 10px;
    border: 1px solid #2a313d;
    border-radius: 12px;
    background: #11151d;
}

.video-admin-title-image-thumb {
    width: 100%;
    height: 110px;
    border-radius: 10px;
    object-fit: cover;
    border: 1px solid #2a313d;
    background: #11151d;
}

.video-admin-title-media-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.video-admin-upload-progress {
    display: grid;
    gap: 8px;
    width: min(100%, 360px);
    margin-right: auto;
}

.video-admin-upload-progress.hidden {
    display: none;
}

.video-admin-upload-progress-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    color: #d7dde8;
    font-size: 13px;
}

.video-admin-upload-progress-bar {
    position: relative;
    overflow: hidden;
    height: 10px;
    border-radius: 999px;
    background: #11151d;
    border: 1px solid #2a313d;
}

.video-admin-upload-progress-bar > span {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #90d060, #4caf50);
    transition: width 0.18s ease;
}

.video-admin-media-status {
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid #2a313d;
    background: #11151d;
    color: #d7dde8;
}

.video-admin-media-status span {
    color: #9ba7bc;
    font-size: 13px;
}

@keyframes video-gallery-scroll {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(calc(-50% - 7px));
    }
}

.video-title-meta-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 10px;
    width: 100%;
}

.video-title-fact {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 10px 12px;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(14, 22, 37, 0.92), rgba(11, 17, 28, 0.9));
    border: 1px solid #273246;
}

.video-title-fact strong {
    color: #fff;
    font-size: 0.94rem;
    line-height: 1.25;
}

.video-title-fact-label {
    color: #8da2c6;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.video-title-fact-wide {
    grid-column: span 1;
}

.video-dubbing-switch {
    display: grid;
    gap: 14px;
}

.video-dubbing-switch-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 12px;
}

.video-dubbing-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
}

.video-dubbing-option {
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid rgba(126, 217, 87, 0.22);
    background: rgba(10, 16, 24, 0.72);
    color: #d9f4df;
    text-decoration: none;
}

.video-dubbing-option:hover,
.video-dubbing-option.active {
    border-color: rgba(126, 217, 87, 0.82);
    background: linear-gradient(180deg, rgba(26, 64, 49, 0.82), rgba(12, 24, 28, 0.88));
}

.video-dubbing-option small {
    color: #9fb3c8;
    font-size: 12px;
}

.video-latest-episode-notice {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
    padding: 14px 18px;
    border-color: rgba(126, 217, 87, 0.42);
    background:
        radial-gradient(circle at 8% 50%, rgba(126, 217, 87, 0.16), transparent 28%),
        linear-gradient(180deg, rgba(19, 38, 37, 0.96), rgba(13, 25, 31, 0.96));
    color: #fff;
    text-decoration: none;
    transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.video-latest-episode-notice:hover {
    transform: translateY(-1px);
    border-color: rgba(126, 217, 87, 0.88);
    box-shadow: 0 16px 34px rgba(3, 12, 18, 0.32);
}

.video-latest-episode-main {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.video-latest-episode-dot {
    flex: 0 0 auto;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #7ed957;
    box-shadow: 0 0 0 6px rgba(126, 217, 87, 0.13), 0 0 18px rgba(126, 217, 87, 0.58);
}

.video-latest-episode-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.video-latest-episode-copy > span {
    color: #9fb3c8;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.video-latest-episode-copy strong {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    color: #f3fff0;
    font-size: .95rem;
    line-height: 1.35;
}

.video-latest-episode-copy strong span {
    color: #6f8b87;
}

.video-latest-episode-action {
    flex: 0 0 auto;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(126, 217, 87, 0.16);
    color: #caffbd;
    font-size: 12px;
    font-weight: 700;
}

.video-title-meta,
.video-card-head,
.video-controls-row,
.video-control-group,
.video-admin-header,
.video-admin-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.video-title-meta,
.video-card-head,
.video-admin-header {
    justify-content: space-between;
}

.video-title-meta {
    justify-content: flex-start;
}

.video-card-head h2 {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.3;
}

.video-title-link {
    color: #fff;
    text-decoration: none;
}

.video-title-link:hover {
    color: #9fd0ff;
}

.video-strip-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin: 0 0 14px;
}

.video-strip-head h2 {
    margin: 0;
}

.video-strip-note {
    color: #8fa2c0;
    font-size: 13px;
}

.episode-card-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}

.episode-card-tile {
    min-width: 0;
}

.episode-card-link {
    display: block;
    overflow: hidden;
    text-decoration: none;
    color: #fff;
    border-radius: 16px;
    border: 1px solid #2a313d;
    background: #151a23;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.episode-card-link:hover {
    transform: translateY(-2px);
    border-color: #4d8dff;
    box-shadow: 0 12px 24px rgba(4, 9, 18, 0.3);
}

.episode-card-poster {
    position: relative;
    aspect-ratio: 16 / 9;
    background: #0c1118;
}

.episode-card-poster img,
.episode-card-poster .video-poster-fallback {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.episode-card-overlay {
    position: absolute;
    inset: auto 10px 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

.episode-card-number,
.episode-card-quality,
.video-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.episode-card-number {
    background: rgba(11, 16, 24, 0.74);
    color: #fff;
    backdrop-filter: blur(10px);
}

.episode-card-quality {
    background: rgba(77, 141, 255, 0.18);
    color: #c8ddff;
    backdrop-filter: blur(10px);
}

.episode-card-body {
    display: grid;
    gap: 8px;
    padding: 12px 14px 14px;
}

.episode-card-body strong {
    line-height: 1.35;
}

.episode-card-status {
    color: #8fa2c0;
    font-size: 12px;
    line-height: 1.4;
}

.video-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: #253348;
    color: #9fd0ff;
    font-size: 12px;
    font-weight: 700;
}

.video-empty {
    padding: 24px;
    border: 1px dashed #334155;
    border-radius: 16px;
    text-align: center;
}

.video-empty.small {
    padding: 14px;
}

.video-title-preview-notice {
    display: grid;
    gap: 4px;
    margin-bottom: 16px;
    padding: 14px 16px;
    border: 1px solid rgba(245, 158, 11, 0.56);
    border-radius: 16px;
    background: rgba(120, 53, 15, 0.28);
    color: #fde68a;
}

.video-title-preview-notice span {
    color: #fcd9a0;
    font-size: 13px;
    line-height: 1.5;
}

.video-player-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(280px, .9fr);
    gap: 20px;
}

.video-player-shell,
.video-sidebar-card {
    padding: 20px;
}

.video-player-frame {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    background: #090c11;
    margin: 18px 0;
}

.video-player-frame video {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
}

.video-play-overlay {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.34));
    color: #fff;
    font-size: 54px;
    display: grid;
    place-items: center;
    cursor: pointer;
}

.video-player-controls input[type="range"],
.video-player-controls select,
.video-admin-form input,
.video-admin-form textarea,
.video-admin-form select {
    width: 100%;
    background: #10141b;
    color: #fff;
    border: 1px solid #364152;
    border-radius: 10px;
    padding: 10px 12px;
}

.video-progress-row {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) 54px;
    gap: 10px;
    align-items: center;
}

.video-sidebar-card {
    display: grid;
    gap: 10px;
    overflow: hidden;
    align-self: start;
}

.video-episode-link {
    display: block;
    padding: 12px 14px;
    border-radius: 12px;
    text-decoration: none;
    background: #11161d;
    border: 1px solid transparent;
    color: #fff;
}

.video-episode-link span {
    display: block;
    font-size: 13px;
    color: #9ba7bc;
    margin-top: 4px;
}

.video-episode-link.active {
    border-color: #4CAF50;
    background: #172118;
}

.video-admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 18px;
    margin-bottom: 20px;
}

.video-admin-shell {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 18px;
    margin-bottom: 20px;
}

.video-admin-panel,
.video-admin-item,
.video-admin-card {
    padding: 18px;
}

.video-admin-panel-featured {
    background:
        radial-gradient(circle at top right, rgba(84, 199, 129, 0.14), transparent 28%),
        linear-gradient(180deg, #1b1f28, #151922);
}

.video-admin-panel-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
}

.video-admin-list {
    display: grid;
    gap: 18px;
}

.video-admin-title-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 16px;
}

.video-admin-toolbar {
    display: grid;
    gap: 12px;
    padding: 16px 18px;
    background: linear-gradient(180deg, #161b24, #11161e);
    border: 1px solid #2a313d;
    border-radius: 18px;
}

.video-admin-search {
    display: grid;
    gap: 6px;
}

.video-admin-title-jump {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    max-height: 108px;
    overflow-y: auto;
    padding-right: 4px;
}

.video-admin-title-chip {
    border: 1px solid #2f3642;
    border-radius: 999px;
    background: #10151d;
    color: #dce6f5;
    padding: 8px 12px;
    cursor: pointer;
}

.video-admin-title-chip:hover {
    border-color: #4d8dff;
}

.video-admin-title-tile {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid #2a313d;
    border-radius: 18px;
    background: linear-gradient(180deg, #161b24, #11161e);
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.24);
    color: #eef4ff;
    text-align: left;
    cursor: pointer;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.video-admin-title-tile.is-loading,
.video-admin-title-chip.is-loading {
  cursor: wait;
  opacity: 0.68;
}

.video-admin-title-tile:hover,
.video-admin-title-tile:focus-visible {
    transform: translateY(-2px);
    border-color: #4d8dff;
    box-shadow: 0 20px 42px rgba(0, 0, 0, 0.28);
}

.video-admin-title-tile-poster {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 2 / 3;
    border-radius: 14px;
    overflow: hidden;
    background: linear-gradient(180deg, #1b2532, #121821);
}

.video-admin-title-tile-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.video-admin-title-tile-poster.no-poster,
.video-admin-modal-poster.no-poster {
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(77, 141, 255, 0.25), rgba(126, 217, 87, 0.2));
}

.video-admin-title-tile-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(12, 17, 23, 0.38);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 800;
}

.video-admin-title-tile-body {
    display: grid;
    gap: 8px;
}

.video-admin-title-tile-name {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.35;
}

.video-admin-title-tile-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    color: #93a3bc;
    font-size: 12px;
}

.video-admin-title-tile-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 10px;
    border: 1px solid #2a313d;
    border-radius: 999px;
    background: rgba(12, 17, 23, 0.55);
}

.video-admin-modal-layer {
    position: fixed;
    inset: 0;
    z-index: 120;
}

body.video-admin-modal-open {
    overflow: hidden;
}

.video-admin-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(5, 8, 13, 0.78);
    backdrop-filter: blur(8px);
}

.video-admin-modal-shell {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    min-height: 100vh;
    padding: 24px;
}

.video-admin-modal-stack {
    width: min(1380px, calc(100vw - 40px));
    max-height: calc(100vh - 40px);
}

.video-admin-modal-card {
    display: grid;
    gap: 18px;
    max-height: calc(100vh - 40px);
    overflow: auto;
    padding: 22px;
    background: linear-gradient(180deg, #161b24, #11161e);
    border: 1px solid #2a313d;
    border-radius: 24px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.42);
}

.video-admin-modal-card[hidden] {
    display: none !important;
}

.video-admin-modal-card-head {
    position: sticky;
    top: 0;
    z-index: 2;
    gap: 14px;
    padding-bottom: 12px;
    background: linear-gradient(180deg, rgba(22, 27, 36, 0.98), rgba(22, 27, 36, 0.9));
    backdrop-filter: blur(10px);
}

.video-admin-modal-head-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    margin-left: auto;
}

.video-admin-modal-poster {
    display: inline-flex;
    width: 72px;
    height: 96px;
    border-radius: 12px;
    overflow: hidden;
    flex: 0 0 auto;
}

.video-admin-modal-titlebox {
    align-items: flex-start;
}

.video-admin-modal-titlebox h3 {
    margin-bottom: 6px;
}

.video-admin-modal-titlebox p {
    margin: 0;
    color: #9badc8;
    font-size: 13px;
    line-height: 1.45;
}

.video-admin-danger-zone {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    padding: 16px 18px;
    border: 1px solid rgba(198, 74, 74, 0.32);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(55, 19, 24, 0.95), rgba(33, 13, 17, 0.95));
}

.video-admin-danger-copy {
    display: grid;
    gap: 6px;
}

.video-admin-danger-copy strong {
    color: #ffd0d0;
}

.video-admin-danger-copy span {
    color: #f0b1b1;
    font-size: 13px;
    line-height: 1.45;
}

.video-admin-card {
    background: linear-gradient(180deg, #161b24, #11161e);
    border: 1px solid #2a313d;
    border-radius: 18px;
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.24);
}

.video-admin-card-body {
    display: grid;
    gap: 16px;
}

.video-admin-card-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
}

.video-admin-titlebox {
    display: flex;
    gap: 14px;
    align-items: center;
}

.video-admin-thumb {
    width: 90px;
    height: 120px;
    border-radius: 12px;
}

.video-admin-form {
    display: grid;
    gap: 12px;
}

.video-admin-form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.video-admin-form label {
    display: grid;
    gap: 6px;
}

.video-admin-time-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.video-admin-time-field {
    display: grid;
    gap: 6px;
}

.video-admin-time-inputs {
    display: flex;
    align-items: center;
    gap: 6px;
}

.video-admin-time-inputs > span {
    flex: 0 0 auto;
    color: #8fa4bf;
    font-weight: 700;
    font-size: 14px;
}

.video-admin-time-inputs > input {
    width: 68px;
    min-width: 0;
    text-align: center;
    padding-left: 10px;
    padding-right: 10px;
}

.video-admin-form span {
    color: #c6d2e2;
    font-size: 14px;
}

.video-admin-inline,
.video-admin-episodes {
    margin-top: 16px;
}

.video-admin-episodes {
    display: grid;
    gap: 14px;
}

.video-admin-episode-workspace {
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.video-admin-episode-list-wrap {
    display: grid;
    gap: 10px;
}

.video-admin-episode-filterbar {
    display: grid;
    gap: 8px;
    padding: 12px 14px;
    border: 1px solid #27303d;
    border-radius: 14px;
    background: linear-gradient(180deg, #10151d, #0d1218);
}

.video-admin-episode-dubbing-filter-field {
    display: grid;
    gap: 6px;
}

.video-admin-episode-dubbing-filter-field > span,
.video-admin-episode-dubbing-filter-count {
    color: #93a3bc;
    font-size: 12px;
    line-height: 1.45;
}

.video-admin-episode-dubbing-filter {
    width: 100%;
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid #334155;
    border-radius: 12px;
    background: #0b111b;
    color: #fff;
}

.video-admin-episode-bulkbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid #27303d;
    background: linear-gradient(180deg, #10151d, #0d1218);
}

.video-admin-episode-bulktext {
    display: grid;
    gap: 6px;
    color: #93a3bc;
    font-size: 12px;
    line-height: 1.45;
}

.video-admin-episode-selection-count {
    color: #fff;
    font-size: 13px;
    font-weight: 600;
}

.video-admin-episode-bulk-form {
    display: grid;
    margin: 0;
}

.video-admin-episode-bulk-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    gap: 8px;
}

.video-admin-episode-move-form,
.video-admin-episode-dubbing-move-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    margin: 0;
}

.video-admin-episode-bulk-season-select,
.video-admin-episode-bulk-dubbing-select {
    width: 100%;
    min-width: 0;
    max-width: 100%;
}

.video-admin-episode-bulk-move-submit,
.video-admin-episode-bulk-dubbing-submit,
.video-admin-episode-bulk-delete {
    width: 100%;
}

.video-admin-episode-renumber-form,
.video-admin-episode-range-delete-form {
    display: grid;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid #27303d;
    background: linear-gradient(180deg, #111721, #0d1218);
}

.video-admin-episode-range-delete-form {
    border-color: rgba(239, 68, 68, 0.45);
}

.video-admin-episode-renumber-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.video-admin-episode-renumber-grid label {
    display: grid;
    gap: 6px;
}

.video-admin-episode-renumber-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.video-admin-episode-renumber-hint {
    color: #93a3bc;
    font-size: 12px;
    line-height: 1.45;
}

.video-admin-episode-drag-hint {
    padding: 10px 12px;
    border: 1px dashed rgba(108, 185, 255, 0.35);
    border-radius: 12px;
    color: #8ea6c3;
    font-size: 12px;
    line-height: 1.45;
    background: rgba(16, 21, 29, 0.65);
}

.video-admin-episode-list {
    display: grid;
    gap: 10px;
    max-height: 560px;
    overflow-y: auto;
    padding-right: 4px;
    position: relative;
}

.video-admin-episode-picker {
    width: 100%;
    border: 1px solid #25303d;
    border-radius: 14px;
    background: linear-gradient(180deg, #10151d, #0c1118);
    color: #fff;
    text-align: left;
    padding: 14px;
    cursor: pointer;
    transition: border-color .18s ease, transform .18s ease, background .18s ease, box-shadow .18s ease;
    user-select: none;
}

.video-admin-episode-picker:hover {
    transform: translateY(-1px);
    border-color: #4d8dff;
}

.video-admin-episode-picker.active {
    border-color: #4CAF50;
    background: linear-gradient(180deg, #162118, #10161d);
    box-shadow: 0 14px 26px rgba(0, 0, 0, 0.22);
}

.video-admin-episode-picker.selected {
    border-color: #d97706;
    background: linear-gradient(180deg, #20160f, #11161d);
    box-shadow: 0 12px 22px rgba(0, 0, 0, 0.18);
}

.video-admin-episode-picker.active.selected {
    border-color: #7ed957;
    background: linear-gradient(180deg, #1f2a12, #14202a);
}

.video-admin-episode-picker.drag-armed {
    transform: scale(1.03);
    border-color: #82b7ff;
    box-shadow: 0 14px 34px rgba(77, 141, 255, 0.2);
}

.video-admin-episode-picker.dragging {
    position: fixed;
    z-index: 30;
    pointer-events: none;
    transform: scale(1.05);
    border-color: #7ed957;
    box-shadow: 0 22px 44px rgba(0, 0, 0, 0.36);
}

.video-admin-episode-picker.drag-group-member {
    transform: scale(1.02);
    opacity: 0.96;
}

.video-admin-episode-picker.drop-target-before {
    box-shadow: inset 0 3px 0 #7ed957;
}

.video-admin-episode-picker.drop-target-after {
    box-shadow: inset 0 -3px 0 #7ed957;
}

.video-admin-episode-picker-placeholder {
    border: 1px dashed rgba(126, 217, 87, 0.45);
    border-radius: 14px;
    background: rgba(126, 217, 87, 0.08);
}

.video-admin-episode-workspace.is-reordering .video-admin-episode-list {
    cursor: grabbing;
}

.video-admin-episode-workspace.is-reordering .video-admin-episode-picker:not(.dragging) {
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.video-admin-episode-picker-main {
    display: grid;
    gap: 6px;
}

.video-admin-episode-picker-main strong {
    line-height: 1.35;
}

.video-admin-episode-picker-main span {
    color: #93a3bc;
    font-size: 12px;
    line-height: 1.45;
}

.video-admin-episode-form,
.video-admin-episode-card {
    padding: 16px;
    background: linear-gradient(180deg, #10151d, #0d1218);
    border: 1px solid #27303d;
    border-radius: 14px;
}

.video-admin-episode-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
}

.video-admin-episode-status {
    margin-top: 8px;
}

.video-admin-episode-current-title {
    display: block;
    font-size: 1rem;
    line-height: 1.35;
}

.video-status-pill {
    background: rgba(77, 141, 255, 0.16);
    color: #c8ddff;
}

.video-status-pill.muted {
    background: rgba(143, 162, 192, 0.12);
    color: #96a6be;
}

.video-admin-meta {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 10px;
}

.video-flash-stack {
    display: grid;
    gap: 10px;
    margin-bottom: 16px;
}

.video-flash {
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid #2a313d;
}

.video-flash-success {
    background: #15271b;
    color: #87dd92;
}

.video-flash-error {
    background: #30161a;
    color: #ffb4be;
}

.video-promo {
    margin: 24px 0;
}

.video-promo-card {
    display: grid;
    gap: 16px;
    padding: 20px;
}

.video-promo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 14px;
}

.video-promo-item {
    text-decoration: none;
    color: #fff;
    background: #10141b;
    border: 1px solid #2a313d;
    border-radius: 14px;
    overflow: hidden;
}

.video-promo-item img,
.video-promo-item .video-poster-fallback {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.video-promo-item-copy {
    padding: 12px;
}

.video-poster-fallback {
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #2d3d59, #4CAF50);
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.video-watch-layout,
.video-watch-main {
    display: block;
}

.video-watch-main {
    min-width: 0;
}

.custom-player {
    position: relative;
    overflow: hidden;
    min-height: 320px;
    border-radius: 18px;
    border: 1px solid #30415c;
    background:
        radial-gradient(circle at top right, rgba(87, 130, 255, 0.22), transparent 30%),
        linear-gradient(180deg, #0d1420 0%, #0b1018 100%);
    box-shadow: 0 22px 60px rgba(2, 6, 16, 0.45);
}

.custom-player::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(180deg, rgba(9, 15, 27, 0.1) 0%, rgba(9, 15, 27, 0.8) 100%);
    pointer-events: none;
}

.player-poster-background {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.25;
    pointer-events: none;
}

.custom-player video {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
    z-index: 1;
    transform-origin: center;
}

.custom-player.is-playback-restricted {
    display: grid;
    min-height: 320px;
    aspect-ratio: 16 / 9;
    place-items: center;
}

.custom-player.is-playback-restricted video,
.custom-player.is-playback-restricted .player-error,
.custom-player.is-playback-restricted .player-cast-notice,
.custom-player.is-playback-restricted .center-play,
.custom-player.is-playback-restricted .player-skip-action,
.custom-player.is-playback-restricted .player-gradient,
.custom-player.is-playback-restricted .player-topline,
.custom-player.is-playback-restricted .player-controls {
    display: none !important;
}

.player-restriction {
    position: relative;
    z-index: 4;
    display: grid;
    width: min(calc(100% - 32px), 560px);
    gap: 8px;
    padding: 24px;
    border: 1px solid rgba(255, 124, 124, 0.32);
    border-radius: 18px;
    background: rgba(28, 12, 16, 0.9);
    color: #ffd4d8;
    text-align: center;
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(12px);
}

.player-restriction strong {
    color: #fff;
    font-size: clamp(1.15rem, 3vw, 1.55rem);
}

.player-restriction span {
    line-height: 1.55;
}

.custom-player:fullscreen,
.custom-player:-webkit-full-screen {
    width: 100vw;
    height: 100vh;
    max-width: 100vw;
    max-height: 100vh;
    border-radius: 0;
    border: 0;
    background: #000;
}

.custom-player:fullscreen::before,
.custom-player:-webkit-full-screen::before {
    opacity: 0;
}

.custom-player:fullscreen video,
.custom-player:-webkit-full-screen video {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    object-fit: contain;
    background: #000;
}

.center-play {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 3;
    width: 42px;
    height: 42px;
    margin: -21px 0 0 -21px;
    border: 0;
    display: grid;
    place-items: center;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    cursor: pointer;
    overflow: hidden;
    transition: transform .18s ease, opacity .18s ease;
}

.center-play:hover {
    transform: scale(1.04);
}

.center-play.is-suppressed {
    opacity: 0;
    pointer-events: none;
}

.player-skip-action {
    position: absolute;
    z-index: 4;
    min-width: 180px;
    max-width: min(42vw, 280px);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    padding: 12px 18px;
    background: rgba(11, 18, 30, 0.84);
    color: #fff;
    font: inherit;
    font-weight: 700;
    letter-spacing: 0.01em;
    backdrop-filter: blur(14px);
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.28);
    transition: opacity .18s ease, transform .18s ease, background .18s ease, border-color .18s ease;
}

.player-skip-action:hover {
    background: rgba(20, 30, 48, 0.94);
    border-color: rgba(255, 255, 255, 0.28);
}

.player-skip-action.hidden {
    opacity: 0;
    pointer-events: none;
}

.player-skip-action-intro {
    left: 22px;
    bottom: 128px;
}

.player-skip-action-next {
    right: 22px;
    bottom: 128px;
}

.icon-center-play {
    width: 34px;
    height: 34px;
    margin-left: 4px;
}

.player-gradient {
    position: absolute;
    inset: auto 0 0;
    height: 40%;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(7, 11, 18, 0) 0%, rgba(7, 11, 18, 0.88) 100%);
}

.player-error {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 4;
    transform: translate(-50%, -50%);
    max-width: min(80%, 520px);
    padding: 14px 16px;
    border-radius: 14px;
    background: rgba(28, 12, 16, 0.92);
    border: 1px solid rgba(255, 124, 124, 0.32);
    color: #ffd4d8;
    text-align: center;
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.35);
}

.player-cast-notice {
    position: absolute;
    left: 50%;
    top: 22px;
    z-index: 4;
    transform: translateX(-50%);
    width: min(calc(100% - 32px), 640px);
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(16, 22, 31, 0.94);
    border: 1px solid rgba(255, 211, 112, 0.35);
    color: #ffe6aa;
    text-align: center;
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(10px);
}

.player-cast-notice strong {
    display: block;
    margin-bottom: 4px;
    color: #fff4cf;
    font-size: 0.95rem;
}

.player-cast-notice span {
    display: block;
    color: #f5ddb0;
    font-size: 0.9rem;
    line-height: 1.45;
}

.hidden {
    display: none !important;
}

.player-btn[hidden],
.download-toggle[hidden],
.icon-btn[hidden] {
    display: none !important;
}

.player-topline {
    position: absolute;
    inset: 0 0 auto;
    z-index: 3;
    padding: 20px 22px 0;
    pointer-events: none;
}

.player-topline h2 {
    margin: 4px 0 0;
    color: #fff;
    font-size: clamp(1.2rem, 2vw, 1.9rem);
}

.player-cast-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    padding: 6px 10px;
    border: 1px solid rgba(126, 217, 87, 0.28);
    border-radius: 999px;
    background: rgba(126, 217, 87, 0.12);
    color: #ddffd2;
    font-size: 12px;
    font-weight: 700;
}

.eyebrow {
    color: #96b7ff;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.player-controls {
    position: absolute;
    inset: auto 0 0;
    z-index: 3;
    padding: 16px 18px 18px;
    transition: opacity .22s ease, transform .22s ease;
}

.controls-hidden .player-controls,
.controls-hidden .player-topline {
    opacity: 0;
    transform: translateY(8px);
}

.custom-player:fullscreen.controls-hidden,
.custom-player:-webkit-full-screen.controls-hidden,
.custom-player:fullscreen.controls-hidden video,
.custom-player:-webkit-full-screen.controls-hidden video {
    cursor: none;
}

.custom-player:fullscreen .player-controls,
.custom-player:-webkit-full-screen .player-controls,
.custom-player:fullscreen .player-topline,
.custom-player:-webkit-full-screen .player-topline {
    left: 0;
    right: 0;
}

.timeline-wrap {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) 52px;
    gap: 10px;
    align-items: center;
    margin-bottom: 14px;
}

.timeline-preview-host {
    position: relative;
    display: flex;
    align-items: center;
    min-width: 0;
    height: 20px;
}

.timeline-preview-host .timeline {
    flex: 1 1 auto;
}

.timeline-preview {
    --timeline-preview-x: 50%;
    position: absolute;
    left: var(--timeline-preview-x);
    bottom: calc(100% + 14px);
    z-index: 8;
    width: clamp(152px, 22vw, 196px);
    padding: 5px;
    border: 1px solid rgba(143, 188, 255, 0.32);
    border-radius: 10px;
    background: rgba(4, 9, 18, 0.94);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.45);
    pointer-events: none;
    transform: translateX(-50%);
    opacity: 1;
    visibility: visible;
    transition: opacity 0.12s ease, visibility 0.12s ease;
}

.timeline-preview-position-0 { --timeline-preview-x: 10%; }
.timeline-preview-position-1 { --timeline-preview-x: 14%; }
.timeline-preview-position-2 { --timeline-preview-x: 22%; }
.timeline-preview-position-3 { --timeline-preview-x: 30%; }
.timeline-preview-position-4 { --timeline-preview-x: 40%; }
.timeline-preview-position-5 { --timeline-preview-x: 50%; }
.timeline-preview-position-6 { --timeline-preview-x: 60%; }
.timeline-preview-position-7 { --timeline-preview-x: 70%; }
.timeline-preview-position-8 { --timeline-preview-x: 78%; }
.timeline-preview-position-9 { --timeline-preview-x: 86%; }
.timeline-preview-position-10 { --timeline-preview-x: 90%; }

.timeline-preview.hidden {
    display: block !important;
    opacity: 0;
    visibility: hidden;
}

.timeline-preview::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -6px;
    width: 10px;
    height: 10px;
    border-right: 1px solid rgba(143, 188, 255, 0.26);
    border-bottom: 1px solid rgba(143, 188, 255, 0.26);
    background: rgba(4, 9, 18, 0.94);
    transform: translateX(-50%) rotate(45deg);
}

.timeline-preview-media {
    --timeline-preview-surface-width: 100%;
    --timeline-preview-surface-height: 100%;
    --timeline-preview-rotation: 0deg;
    --timeline-preview-scale-x: 1;
    --timeline-preview-scale-y: 1;
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 7px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(143, 188, 255, 0.18), rgba(122, 245, 202, 0.12)), #050a13;
}

.timeline-preview-media.is-portrait {
    aspect-ratio: 9 / 16;
}

.timeline-preview-media.is-rotated-90 {
    --timeline-preview-surface-width: 177.78%;
    --timeline-preview-surface-height: 56.25%;
    --timeline-preview-rotation: 90deg;
}

.timeline-preview-media.is-rotated-minus-90 {
    --timeline-preview-surface-width: 177.78%;
    --timeline-preview-surface-height: 56.25%;
    --timeline-preview-rotation: -90deg;
}

.timeline-preview-media.is-mirrored {
    --timeline-preview-scale-x: -1;
}

.timeline-preview-media.is-upside-down {
    --timeline-preview-scale-y: -1;
}

.timeline-preview canvas,
.timeline-preview-fallback {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    width: var(--timeline-preview-surface-width);
    height: var(--timeline-preview-surface-height);
    object-fit: cover;
    transform: translate(-50%, -50%) rotate(var(--timeline-preview-rotation)) scale(var(--timeline-preview-scale-x), var(--timeline-preview-scale-y));
    transform-origin: center;
}

.timeline-preview-fallback {
    display: none;
    background-position: center;
    background-size: cover;
}

.timeline-preview.is-fallback canvas {
    display: none;
}

.timeline-preview.is-fallback .timeline-preview-fallback {
    display: block;
}

.timeline-preview-time {
    position: relative;
    z-index: 1;
    display: block;
    margin-top: 5px;
    color: #f7fbff;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    text-align: center;
}

.time-label {
    color: #f5f7fb;
    font-size: 12px;
    font-weight: 700;
    text-align: center;
}

.timeline,
.volume-wrap input[type="range"] {
    width: 100%;
    height: 4px;
    appearance: none;
    background: rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    outline: none;
}

.timeline::-webkit-slider-thumb,
.volume-wrap input[type="range"]::-webkit-slider-thumb {
    appearance: none;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 0 3px rgba(143, 188, 255, 0.25);
    cursor: pointer;
}

.timeline::-moz-range-thumb,
.volume-wrap input[type="range"]::-moz-range-thumb {
    width: 12px;
    height: 12px;
    border: 0;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 0 3px rgba(143, 188, 255, 0.25);
    cursor: pointer;
}

.controls-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.controls-group {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.controls-group-right {
    justify-content: flex-end;
}

.controls-group-right .quality-dropdown,
.controls-group-right .speed-dropdown {
    flex: 0 1 auto;
}

.player-btn {
    min-width: 44px;
    height: 44px;
    border: 1px solid rgba(151, 178, 255, 0.18);
    border-radius: 12px;
    background: rgba(14, 20, 31, 0.78);
    color: #fff;
    backdrop-filter: blur(12px);
    cursor: pointer;
    overflow: hidden;
    transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

.player-btn:hover {
    transform: translateY(-1px);
    border-color: rgba(151, 178, 255, 0.38);
    background: rgba(23, 32, 48, 0.94);
}

.player-btn:disabled {
    cursor: not-allowed;
    opacity: 0.58;
    transform: none;
}

.player-btn.is-cast-active {
    border-color: rgba(126, 217, 87, 0.45);
    background: linear-gradient(135deg, rgba(126, 217, 87, 0.28), rgba(71, 121, 255, 0.24));
    box-shadow: 0 0 0 1px rgba(126, 217, 87, 0.12), 0 10px 24px rgba(41, 72, 28, 0.28);
}

.icon-btn {
    display: grid;
    place-items: center;
    padding: 0;
}

.icon {
    width: 18px;
    height: 18px;
    display: block;
    filter: brightness(0) invert(1);
}

.center-play > img,
.player-btn > img,
.icon,
.icon-center-play {
    width: 18px !important;
    height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
    object-fit: contain;
    flex: 0 0 auto;
}

.center-play > .icon-center-play {
    width: 34px !important;
    height: 34px !important;
    max-width: 34px !important;
    max-height: 34px !important;
}

.volume-wrap {
    width: 126px;
    padding: 0 4px;
}

.quality-dropdown,
.speed-dropdown {
    position: relative;
}

.quality-toggle,
.speed-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-width: 122px;
    padding: 0 14px;
    font-weight: 700;
}

.speed-toggle {
    min-width: 76px;
}

.screenshot-toggle {
    min-width: 84px;
    justify-content: center;
}

.screenshot-toggle.is-saving {
    opacity: 0.72;
}

.episode-toggle {
    min-width: 220px;
    max-width: min(38vw, 360px);
}

.episode-toggle-label {
    color: #9fb2d3;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

#episode-current {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.quality-arrow {
    color: #9fb2d3;
    font-size: 12px;
}

.quality-menu,
.speed-menu {
    position: absolute;
    right: 0;
    bottom: calc(100% + 10px);
    min-width: 122px;
    background: rgba(13, 18, 28, 0.98);
    border: 1px solid rgba(151, 178, 255, 0.18);
    border-radius: 14px;
    padding: 8px;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.34);
}

.speed-menu {
    min-width: 86px;
}

.quality-menu.hidden,
.speed-menu.hidden {
    display: none;
}

.episode-menu {
    min-width: min(420px, 72vw);
    max-width: min(420px, 72vw);
    padding: 8px;
}

.episode-menu-list,
.video-admin-title-jump,
.video-admin-episode-list,
.video-admin-modal-card,
.catalog-filter-values {
    scrollbar-width: thin;
    scrollbar-color: #4CAF50 #0d1420;
}

.episode-menu-list {
    display: grid;
    gap: 8px;
    max-height: min(46vh, 420px);
    overflow-y: auto;
    padding-right: 6px;
    touch-action: pan-y;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.quality-option,
.speed-option {
    width: 100%;
    border: 0;
    border-radius: 10px;
    background: transparent;
    color: #fff;
    text-align: left;
    padding: 10px 12px;
    cursor: pointer;
}

.quality-option:hover,
.quality-option.active,
.speed-option:hover,
.speed-option.active {
    background: rgba(79, 130, 255, 0.18);
}

.episode-menu-list::-webkit-scrollbar,
.video-admin-title-jump::-webkit-scrollbar,
.video-admin-episode-list::-webkit-scrollbar,
.video-admin-modal-card::-webkit-scrollbar,
.catalog-filter-values::-webkit-scrollbar {
    width: 10px;
}

.episode-menu-list::-webkit-scrollbar-track,
.video-admin-title-jump::-webkit-scrollbar-track,
.video-admin-episode-list::-webkit-scrollbar-track,
.video-admin-modal-card::-webkit-scrollbar-track,
.catalog-filter-values::-webkit-scrollbar-track {
    background: linear-gradient(180deg, #0b121d, #0f1725);
    border-radius: 999px;
    border: 1px solid rgba(80, 109, 151, 0.18);
}

.episode-menu-list::-webkit-scrollbar-thumb,
.video-admin-title-jump::-webkit-scrollbar-thumb,
.video-admin-episode-list::-webkit-scrollbar-thumb,
.video-admin-modal-card::-webkit-scrollbar-thumb,
.catalog-filter-values::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(76, 175, 80, 0.92), rgba(50, 122, 194, 0.92));
    border: 2px solid #0d1420;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.episode-menu-list::-webkit-scrollbar-thumb:hover,
.video-admin-title-jump::-webkit-scrollbar-thumb:hover,
.video-admin-episode-list::-webkit-scrollbar-thumb:hover,
.video-admin-modal-card::-webkit-scrollbar-thumb:hover,
.catalog-filter-values::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(105, 214, 109, 0.96), rgba(74, 151, 255, 0.96));
}

.episode-link {
    display: block;
    padding: 10px;
    border-radius: 14px;
    background: #10161f;
    border: 1px solid transparent;
    text-decoration: none;
    color: #fff;
}

.episode-link.active,
.episode-link:hover {
    border-color: #4CAF50;
    background: #15201a;
}

.episode-link strong {
    display: block;
    line-height: 1.35;
}

.episode-link span {
    display: block;
    margin-top: 4px;
    color: #93a3bc;
    font-size: 13px;
}

@media (max-width: 900px) {
    .video-player-layout,
    .video-title-hero,
    .video-watch-layout {
        grid-template-columns: 1fr;
    }

    .video-admin-shell {
        grid-template-columns: 1fr;
    }

    .video-title-meta-grid {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .video-admin-episode-workspace {
        grid-template-columns: 1fr;
    }

    .video-admin-episode-list {
        max-height: 280px;
    }

    .video-catalog-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .episode-card-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .video-title-user-screenshots-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .site-topbar {
        padding: 14px 16px;
    }

    .video-page {
        padding-bottom: 24px;
    }

    .video-latest-episode-notice {
        align-items: flex-start;
        padding: 13px 14px;
    }

    .video-latest-episode-action {
        display: none;
    }

    .video-admin-header,
    .video-admin-titlebox,
    .video-admin-modal-head-actions,
    .video-admin-episode-bulkbar,
    .video-admin-episode-head,
    .video-admin-card-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .video-admin-modal-shell {
        padding: 10px;
    }

    .video-admin-modal-stack,
    .video-admin-modal-card {
        width: 100%;
        max-height: calc(100vh - 20px);
    }

    .video-admin-title-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .video-admin-deleted-episode-row {
        grid-template-columns: minmax(0, 1fr);
    }

    .video-admin-section-inline-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .video-admin-episode-renumber-grid {
        grid-template-columns: 1fr;
    }

    .video-admin-episode-renumber-foot {
        align-items: stretch;
    }

    .video-title-copy {
        gap: 14px;
    }

    .video-title-heading {
        font-size: clamp(1.7rem, 9vw, 2.2rem);
    }

    .video-title-meta-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .video-title-user-screenshots-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .video-title-fact-wide {
        grid-column: span 1;
    }

    .video-admin-toolbar {
        padding: 14px;
    }

    .video-admin-title-jump {
        max-height: 148px;
    }

    .custom-player {
        min-height: 0;
        border-radius: 14px;
    }

    .player-topline {
        display: none;
    }

    .player-controls {
        padding: 6px 6px 8px;
    }

    .timeline-wrap {
        grid-template-columns: 36px minmax(0, 1fr) 36px;
        gap: 5px;
        margin-bottom: 6px;
    }

    .timeline-preview {
        bottom: calc(100% + 10px);
        width: min(160px, 56vw);
        padding: 4px;
    }

    .timeline-preview-time {
        margin-top: 4px;
        font-size: 10px;
    }

    .time-label {
        font-size: 10px;
    }

    .center-play {
        width: 56px;
        height: 56px;
        margin: -28px 0 0 -28px;
    }

    .player-skip-action {
        min-width: 0;
        max-width: calc(100vw - 32px);
        padding: 10px 14px;
        font-size: 0.88rem;
    }

    .player-skip-action-intro {
        left: 10px;
        bottom: 96px;
    }

    .player-skip-action-next {
        right: 10px;
        bottom: 96px;
    }

    .controls-row {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 4px;
        flex-wrap: nowrap;
    }

    .controls-group,
    .controls-group-right {
        justify-content: flex-start;
        gap: 4px;
        flex-wrap: nowrap;
        min-width: 0;
    }

    .controls-group {
        flex: 0 1 auto;
    }

    .episode-toggle {
        min-width: 72px;
        max-width: 22vw;
        padding: 0 7px;
        gap: 5px;
    }

    .episode-toggle-label {
        display: none;
    }

    .volume-wrap {
        width: 44px;
        min-width: 44px;
        padding: 0 2px;
    }

    .player-btn {
        min-width: 32px;
        height: 32px;
        border-radius: 8px;
    }

    .quality-toggle,
    .speed-toggle {
        min-width: 66px;
        padding: 0 7px;
        gap: 5px;
        font-size: 12px;
    }

    .speed-toggle {
        min-width: 56px;
    }

    .screenshot-toggle {
        min-width: 54px;
    }

    .quality-menu,
    .speed-menu {
        min-width: 78px;
        padding: 6px;
    }

    .episode-menu {
        min-width: min(300px, calc(100vw - 24px));
        max-width: min(300px, calc(100vw - 24px));
        right: -42px;
    }

    .custom-player.is-episode-menu-open:not(:fullscreen):not(:-webkit-full-screen) {
        overflow: visible;
        margin-bottom: min(48vh, 320px);
    }

    .custom-player:not(:fullscreen):not(:-webkit-full-screen) .episode-dropdown {
        position: static;
    }

    .custom-player:not(:fullscreen):not(:-webkit-full-screen) .episode-menu {
        left: 0;
        right: 0;
        top: calc(100% + 10px);
        bottom: auto;
        width: 100%;
        min-width: 100%;
        max-width: 100%;
        max-height: min(44vh, 300px);
        border-radius: 14px;
        background: rgba(13, 18, 28, 0.98);
    }

    .custom-player:not(:fullscreen):not(:-webkit-full-screen) .episode-menu-list {
        max-height: min(40vh, 260px);
    }

    .custom-player:fullscreen .episode-dropdown,
    .custom-player:-webkit-full-screen .episode-dropdown {
        position: relative;
    }

    .custom-player:fullscreen .episode-menu,
    .custom-player:-webkit-full-screen .episode-menu {
        left: auto;
        right: -42px;
        top: auto;
        bottom: calc(100% + 10px);
        width: auto;
        min-width: min(300px, calc(100vw - 24px));
        max-width: min(300px, calc(100vw - 24px));
        max-height: none;
    }

    .quality-option,
    .speed-option {
        padding: 8px 10px;
        font-size: 14px;
    }

    .episode-menu-list {
        max-height: 42vh;
        padding-right: 4px;
    }

    .icon,
    .center-play > img,
    .player-btn > img {
        width: 14px !important;
        height: 14px !important;
        max-width: 14px !important;
        max-height: 14px !important;
    }

    .center-play > .icon-center-play {
        width: 26px !important;
        height: 26px !important;
        max-width: 26px !important;
        max-height: 26px !important;
    }

    .quality-arrow {
        font-size: 9px;
    }

    .episode-link {
        padding: 9px 10px;
    }

    .video-catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .episode-card-grid,
    .video-admin-form-row {
        grid-template-columns: 1fr;
    }

    .video-admin-time-row {
        grid-template-columns: 1fr;
    }

    .video-admin-time-inputs {
        flex-wrap: nowrap;
    }

    .video-admin-time-inputs > input {
        width: calc((100% - 24px) / 3);
    }
}

@media (max-width: 420px) {
    .player-controls {
        padding: 5px 5px 7px;
    }

    .timeline-wrap {
        grid-template-columns: 34px minmax(0, 1fr) 34px;
        gap: 4px;
        margin-bottom: 5px;
    }

    .timeline-preview {
        width: min(142px, 62vw);
        border-radius: 9px;
    }

    .time-label {
        font-size: 9px;
    }

    .controls-row,
    .controls-group,
    .controls-group-right {
        gap: 3px;
    }

    .player-btn {
        min-width: 28px;
        height: 28px;
        border-radius: 7px;
    }

    .volume-wrap {
        width: 34px;
        min-width: 34px;
        padding: 0 1px;
    }

    .quality-toggle,
    .speed-toggle {
        min-width: 58px;
        padding: 0 5px;
        gap: 3px;
        font-size: 11px;
    }

    .speed-toggle {
        min-width: 50px;
    }

    .episode-toggle {
        min-width: 56px;
        max-width: 18vw;
    }

    .screenshot-toggle {
        min-width: 46px;
    }

    .icon,
    .center-play > img,
    .player-btn > img {
        width: 13px !important;
        height: 13px !important;
        max-width: 13px !important;
        max-height: 13px !important;
    }
}

.video-catalog-layout {
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.video-catalog-sidebar-shell {
    position: sticky;
    top: 18px;
    display: grid;
    gap: 18px;
}

.video-catalog-sidebar {
    display: grid;
    gap: 18px;
    padding: 20px;
    background: linear-gradient(180deg, #171c25, #10151d);
    border: 1px solid #283244;
    border-radius: 22px;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.28);
}

.video-catalog-sidebar-head,
.video-catalog-hero-head,
.video-catalog-toolbar,
.video-catalog-meta,
.video-selected-filters,
.video-card-facts,
.video-card-filters,
.video-admin-inline-checks {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.video-catalog-sidebar-head,
.video-catalog-hero-head,
.video-catalog-toolbar,
.video-catalog-meta {
    justify-content: space-between;
}

.video-catalog-sidebar-body {
    display: grid;
    gap: 14px;
}

.catalog-filter-group {
    display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 16px;
    border: 1px solid #283244;
    background: linear-gradient(180deg, rgba(10, 16, 25, 0.92), rgba(8, 13, 21, 0.86));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.catalog-filter-group-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    color: #dce8ff;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
}

.catalog-filter-group-meta {
    display: inline-flex;
    gap: 10px;
    align-items: center;
    color: #8fd5ff;
}

.catalog-filter-group-arrow {
    display: inline-flex;
    transition: transform 0.18s ease;
}

.catalog-filter-group.is-open .catalog-filter-group-arrow {
    transform: rotate(180deg);
}

.catalog-filter-group-body {
    display: grid;
    gap: 12px;
}

.catalog-filter-group-body[hidden] {
    display: none !important;
}

.catalog-filter-search input,
.video-catalog-search input,
.video-catalog-sort select {
    width: 100%;
    border-radius: 14px;
    border: 1px solid #314058;
    background: #0f141c;
    color: #f7fbff;
    padding: 12px 14px;
}

.catalog-filter-values {
    display: grid;
    gap: 8px;
    max-height: 260px;
    overflow: auto;
    padding-right: 6px;
}

.catalog-filter-option,
.video-admin-filter-option,
.video-admin-check {
    display: flex;
    gap: 10px;
    align-items: center;
    color: #d3deef;
}

.catalog-filter-option {
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(63, 87, 122, 0.72);
    background: linear-gradient(180deg, rgba(17, 27, 41, 0.96), rgba(10, 18, 29, 0.94));
    cursor: pointer;
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.catalog-filter-option:hover {
    transform: translateY(-1px);
    border-color: rgba(125, 180, 255, 0.82);
    box-shadow: 0 10px 18px rgba(5, 10, 18, 0.24);
}

.catalog-filter-option.is-selected {
    border-color: #79c66d;
    background: linear-gradient(180deg, rgba(27, 55, 38, 0.94), rgba(18, 41, 28, 0.92));
    box-shadow: 0 12px 24px rgba(14, 32, 18, 0.28);
}

.catalog-filter-option input,
.video-admin-filter-option input,
.video-admin-check input {
    margin: 0;
}

.catalog-filter-option input {
    width: 16px;
    height: 16px;
    accent-color: #8fd5ff;
}

.catalog-filter-option-copy {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    width: 100%;
}

.catalog-filter-option-copy strong {
    color: #8fd5ff;
}

.video-catalog-sidebar-actions {
    display: grid;
    gap: 10px;
}

.catalog-app-card {
    display: grid;
    gap: 16px;
    padding: 18px;
    border-radius: 18px;
    border: 1px solid rgba(69, 109, 70, 0.46);
    background:
        radial-gradient(circle at top left, rgba(126, 201, 109, 0.16), transparent 52%),
        linear-gradient(180deg, rgba(11, 18, 28, 0.98), rgba(8, 13, 21, 0.95));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.catalog-app-card-copy {
    display: grid;
    gap: 8px;
}

.catalog-app-card-kicker {
    display: inline-flex;
    width: fit-content;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(118, 196, 99, 0.14);
    border: 1px solid rgba(140, 215, 121, 0.24);
    color: #baf3ac;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.catalog-app-card h2 {
    margin: 0;
    color: #f4fbf2;
    font-size: 20px;
    line-height: 1.25;
}

.catalog-app-card p {
    margin: 0;
    color: #c8d5e8;
    line-height: 1.55;
}

.catalog-app-card-meta,
.catalog-app-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.catalog-app-chip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(92, 124, 164, 0.45);
    background: rgba(12, 19, 29, 0.72);
    color: #dce8ff;
    font-size: 13px;
}

.catalog-app-card-actions .btn {
    flex: 1 1 100%;
    justify-content: center;
}

.catalog-app-card-note {
    font-size: 13px;
    color: #9fb2c8;
}

.catalog-app-card-standalone {
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
}

.video-catalog-main {
    min-width: 0;
    display: grid;
    gap: 18px;
}

.video-catalog-hero {
    display: grid;
    gap: 14px;
    padding: 22px 24px;
}

.video-catalog-toolbar {
    align-items: end;
}

.video-catalog-heading {
    margin: 0;
    color: #fff;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
}

.video-catalog-search,
.video-catalog-sort {
    display: grid;
    gap: 8px;
    min-width: 220px;
    flex: 1 1 280px;
    color: #95a6c6;
    font-size: 13px;
    align-self: end;
}

.video-catalog-toolbar-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(132px, 1fr));
    gap: 10px;
    align-items: end;
    align-self: end;
}

.video-catalog-toolbar-actions .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-width: 132px;
    height: 44px;
    padding: 0 18px;
    box-sizing: border-box;
}

.video-selected-filter-chip,
.video-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid #33516e;
    background: rgba(15, 25, 38, 0.9);
    color: #e6f2ff;
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
}

.video-selected-filter-chip span {
    color: #9ddf7d;
}

.video-catalog-grid-rich {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.video-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid #283244;
    border-radius: 16px;
    background: rgba(12, 18, 28, 0.78);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.video-pagination-summary {
    display: grid;
    gap: 3px;
    min-width: 180px;
    color: #dce8ff;
    line-height: 1.35;
}

.video-pagination-summary strong {
    font-size: 14px;
}

.video-pagination-summary span {
    color: #91a4c0;
    font-size: 12px;
}

.video-pagination-controls,
.video-pagination-pages {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.video-pagination-controls {
    justify-content: flex-end;
}

.video-pagination-btn,
.video-pagination-page {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 13px;
    box-sizing: border-box;
    border: 1px solid #344459;
    border-radius: 12px;
    background: rgba(11, 17, 26, 0.92);
    color: #e7f1ff;
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
    transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.video-pagination-page {
    padding: 0 10px;
}

.video-pagination-btn:hover,
.video-pagination-page:hover {
    border-color: #7fb2e8;
    background: #162338;
    transform: translateY(-1px);
}

.video-pagination-page.is-current {
    border-color: transparent;
    background: #98d875;
    color: #101820;
    box-shadow: 0 10px 22px rgba(75, 148, 88, 0.22);
}

.video-pagination-btn.is-disabled {
    color: #64738a;
    cursor: not-allowed;
    opacity: 0.62;
    pointer-events: none;
}

.video-pagination-gap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 40px;
    color: #8090aa;
}

.video-card-facts,
.video-card-filters {
    margin-top: 12px;
}

.video-title-filter-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    line-height: 1.5;
}

.video-title-filter-links a {
    color: #9fd0ff;
    text-decoration: none;
}

.video-title-filter-links a:hover {
    color: #d9f2ff;
}

.video-title-score-copy {
    color: #f6fbff;
}

.video-admin-filter-picker-grid,
.video-admin-filter-manager {
    display: grid;
    gap: 14px;
}

.video-admin-filter-picker-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.video-admin-filter-block,
.video-admin-filter-card {
    padding: 16px;
    border-radius: 16px;
    border: 1px solid #2d3749;
    background: rgba(15, 20, 29, 0.88);
}

.video-admin-filter-card-toggle {
    cursor: pointer;
}

.video-admin-filter-card-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
}

.video-admin-filter-card-body {
    display: grid;
    gap: 16px;
    margin-top: 16px;
}

.video-admin-filter-card.collapsed .video-admin-filter-card-body {
    display: none;
}

.video-admin-filter-block-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 10px;
}

.video-admin-filter-block-head span {
    color: #90d060;
    font-size: 12px;
    text-transform: uppercase;
}

.video-admin-filter-values,
.video-admin-filter-values-list {
    display: grid;
    gap: 8px;
}

.video-admin-dubbing-grid,
.video-admin-dubbing-album-list {
    display: grid;
    gap: 10px;
}

.video-admin-dubbing-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.video-admin-dubbing-card,
.video-admin-dubbing-album-card,
.video-admin-season-dubbing-sync {
    border: 1px solid rgba(75, 126, 105, 0.5);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(18, 33, 29, 0.82), rgba(11, 16, 24, 0.82));
    padding: 12px;
}

.video-admin-dubbing-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.video-admin-season-dubbing-sync {
    margin-top: 12px;
}

.video-admin-filter-option {
    padding: 8px 10px;
    border-radius: 12px;
    border: 1px solid rgba(61, 74, 95, 0.8);
    background: rgba(11, 16, 24, 0.7);
}

.video-admin-inline-checks {
    margin: 8px 0 4px;
}

.video-admin-check {
    padding: 8px 10px;
    border-radius: 12px;
    border: 1px solid #334155;
    background: rgba(10, 15, 24, 0.68);
}

.video-admin-check-inline {
    align-self: end;
}

.video-admin-form-compact {
    margin-bottom: 16px;
}

.episode-menu-season {
    padding: 10px 12px 6px;
    color: #9fb3c8;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.video-season-browser {
    margin-top: 18px;
}

.video-season-stack {
    display: grid;
    gap: 14px;
}

.video-season-group {
    border: 1px solid rgba(61, 74, 95, 0.75);
    border-radius: 8px;
    padding: 14px;
    background: rgba(10, 15, 23, 0.45);
}

.video-season-group.active {
    border-color: rgba(144, 208, 96, 0.65);
}

.video-season-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 12px;
}

.video-season-head span {
    color: #9fb3c8;
    font-size: 13px;
}

.video-season-episode-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 8px;
}

.video-season-episode-link {
    display: block;
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid rgba(61, 74, 95, 0.75);
    border-radius: 8px;
    color: #e5edf7;
    background: rgba(15, 23, 35, 0.65);
    text-decoration: none;
}

.video-season-episode-link:hover,
.video-season-episode-link.active {
    border-color: rgba(144, 208, 96, 0.7);
    background: rgba(35, 54, 36, 0.72);
}

.video-admin-filter-value-form {
    padding: 12px;
    border-radius: 14px;
    border: 1px solid #2d3749;
    background: rgba(10, 15, 23, 0.64);
}

.site-legal-footer {
    width: min(1440px, calc(100% - 32px));
    margin: 28px auto 34px;
    color: #9fb0cf;
}

.site-legal-footer-inner {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(260px, 2fr) minmax(180px, 1fr);
    gap: 16px;
    align-items: center;
    padding: 18px;
    border: 1px solid rgba(149, 182, 255, 0.16);
    border-radius: 20px;
    background: rgba(10, 16, 27, 0.78);
    box-shadow: 0 18px 42px rgba(2, 8, 19, 0.24);
}

.site-legal-footer-brand,
.site-legal-footer-contact {
    display: grid;
    gap: 4px;
}

.site-legal-footer-brand strong,
.site-legal-footer a {
    color: #eff4ff;
}

.site-legal-footer a {
    text-decoration: none;
}

.site-legal-footer a:hover {
    color: #8ad7ff;
}

.site-legal-footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}

.site-legal-footer-links a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(149, 182, 255, 0.16);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.035);
    font-size: 0.9rem;
    font-weight: 700;
}

.site-legal-footer-contact {
    text-align: right;
}

.cookie-banner {
    position: fixed;
    left: 18px;
    right: 18px;
    bottom: 18px;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: min(920px, calc(100% - 36px));
    margin: 0 auto;
    padding: 16px;
    border: 1px solid rgba(149, 182, 255, 0.22);
    border-radius: 18px;
    background: rgba(9, 15, 26, 0.96);
    color: #eff4ff;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
    backdrop-filter: blur(16px);
}

.cookie-banner[hidden] {
    display: none !important;
}

.cookie-banner-copy {
    display: grid;
    gap: 5px;
}

.cookie-banner-copy strong {
    color: #ffffff;
    font-size: 0.98rem;
}

.cookie-banner-copy p {
    max-width: 580px;
    color: #a8b8d2;
    font-size: 0.9rem;
    line-height: 1.5;
}

.cookie-banner-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 9px;
}

.cookie-banner-actions a,
.cookie-banner-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 13px;
    border: 1px solid rgba(149, 182, 255, 0.2);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    color: #eff4ff;
    text-decoration: none;
    font: inherit;
    font-size: 0.88rem;
    font-weight: 700;
    cursor: pointer;
}

.cookie-banner-actions a:hover,
.cookie-banner-actions button:hover {
    border-color: rgba(138, 215, 255, 0.55);
    background: rgba(255, 255, 255, 0.08);
}

.cookie-banner-actions .cookie-banner-primary {
    border-color: transparent;
    background: linear-gradient(135deg, #8ad7ff, #4fbf88);
    color: #07101d;
}

.auth-legal-note {
    margin-top: 12px;
    color: #9fb0cf;
    font-size: 0.88rem;
    line-height: 1.55;
}

.auth-legal-note a {
    color: #eff4ff;
    font-weight: 700;
    text-decoration: none;
}

.auth-legal-note a:hover {
    color: #8ad7ff;
}

.catalog-sidebar-backdrop,
.video-catalog-mobile-filter-btn,
.video-catalog-sidebar-close {
    display: none;
}

@media (max-width: 1180px) {
    .video-catalog-grid-rich {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .video-catalog-layout {
        grid-template-columns: 1fr;
    }

    .video-catalog-sidebar-shell {
        position: static;
        top: auto;
    }

    .video-catalog-sidebar {
        position: static;
        top: auto;
    }

    .video-catalog-grid-rich {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .site-legal-footer-inner {
        grid-template-columns: 1fr;
        text-align: left;
    }

    .site-legal-footer-links {
        justify-content: flex-start;
    }

    .site-legal-footer-contact {
        text-align: left;
    }

    .cookie-banner {
        align-items: stretch;
        flex-direction: column;
        left: 12px;
        right: 12px;
        bottom: 12px;
        width: auto;
    }

    .cookie-banner-actions {
        justify-content: stretch;
    }

    .cookie-banner-actions a,
    .cookie-banner-actions button {
        flex: 1 1 auto;
    }

    .video-catalog-grid-rich {
        grid-template-columns: 1fr;
    }

    .video-pagination {
        align-items: stretch;
        flex-direction: column;
    }

    .video-pagination-summary,
    .video-pagination-controls {
        width: 100%;
    }

    .video-pagination-controls {
        justify-content: space-between;
    }

    .video-pagination-pages {
        flex: 1 1 auto;
        justify-content: center;
    }

    .video-catalog-toolbar-actions {
        width: 100%;
        grid-template-columns: 1fr;
    }

    .video-catalog-toolbar-actions .btn,
    .video-catalog-toolbar-actions .ghost-link,
    .video-catalog-toolbar-actions .btn-secondary {
        width: 100%;
        justify-content: center;
    }
}
