/* TubeSite custom player — ported from WordPress tubesite */

/* ============================================
   TUBESITE CUSTOM VIDEO PLAYER
   ============================================ */

.ts-player {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: var(--ts-radius, 12px);
    overflow: hidden;
    user-select: none;
    font-family: var(--ts-font, system-ui, -apple-system, sans-serif);
    --ts-primary: #ef4444;
    --ts-primary-hover: #f87171;
    --ts-primary-dark: #dc2626;
    --ts-primary-glow: rgba(239, 68, 68, 0.35);
    --ts-accent: #f97316;
    --ts-radius: 12px;
    --ts-preview-radius: 6px;
    --ts-panel-bg: rgba(20, 20, 20, 0.95);
    --ts-panel-border: rgba(255, 255, 255, 0.1);
    --ts-preview-border: rgba(255, 255, 255, 0.15);
    --ts-subtitle-active: #fbbf24;
}

/* YouTube Player Specific Styles */
.ts-youtube-player .ts-poster {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    z-index: 1;
    transition: opacity 0.3s;
}

.ts-youtube-player .ts-yt-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
}

.ts-youtube-player .ts-yt-container iframe {
    width: 100%;
    height: 100%;
    border: none;
}

.ts-youtube-player .ts-controls {
    z-index: 10;
}

.ts-youtube-player .ts-play-overlay {
    z-index: 5;
}

.ts-youtube-player .ts-loader {
    z-index: 8;
}

.ts-player.ts-fullscreen {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    z-index: 999999 !important;
    border-radius: 0 !important;
    aspect-ratio: unset !important;
}

.ts-video {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: #000;
}

/* IMA Ad Container */
.ts-ad-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100;
    pointer-events: none;
    display: none;
    background: #000;
}

.ts-ad-container * {
    pointer-events: auto;
}

/* Ad playing state - hide player controls */
.ts-player.ts-ad-playing .ts-controls,
.ts-player.ts-ad-playing .ts-play-overlay {
    display: none !important;
}

.ts-player.ts-ad-playing .ts-ad-container {
    display: block;
}

/* Proxy video for YouTube VAST */
.ts-proxy-video {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.plyr-player-wrapper {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
}

.plyr-player-wrapper .plyr-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.plyr-player-wrapper .ts-ad-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100;
}

/* Loading Spinner */
.ts-loader {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: none;
    z-index: 10;
}

.ts-player.ts-loading .ts-loader {
    display: block;
}

.ts-spinner {
    width: 50px;
    height: 50px;
    border: 3px solid rgba(255, 255, 255, 0.2);
    border-top-color: var(--ts-primary);
    border-radius: 50%;
    animation: ts-spin 0.8s linear infinite;
}

@keyframes ts-spin {
    to {
        transform: rotate(360deg);
    }
}

/* Play Overlay */
.ts-play-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.3);
    z-index: 5;
    transition: opacity 0.3s, visibility 0.3s;
    pointer-events: none;
}

.ts-play-overlay .ts-big-play {
    pointer-events: auto;
}

.ts-player.ts-playing .ts-play-overlay,
.ts-player.ts-loading .ts-play-overlay {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.ts-big-play {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--ts-primary) 92%, transparent);
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
    transition: transform 0.2s, background 0.2s, box-shadow 0.2s;
    box-shadow: 0 8px 28px var(--ts-primary-glow);
}

.ts-big-play:hover {
    transform: scale(1.08);
    background: var(--ts-primary-hover);
    box-shadow: 0 10px 36px var(--ts-primary-glow);
}

.ts-big-play i {
    font-size: 28px;
    color: #fff;
    margin: 0;
    padding: 0;
    line-height: 1;
    display: block;
    transform: translateX(2px);
}

/* Controls Container */
.ts-controls {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
    padding: 40px 16px 12px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
    z-index: 20;
}

.ts-player:hover .ts-controls,
.ts-player.ts-paused .ts-controls,
.ts-player:not(.ts-playing) .ts-controls,
.ts-player.ts-controls-visible .ts-controls {
    opacity: 1;
    visibility: visible;
}

/* Progress Bar */
.ts-progress-container {
    position: relative;
    margin-bottom: 12px;
    padding: 8px 0;
    cursor: pointer;
}

.ts-progress-bar {
    position: relative;
    height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    transition: height 0.15s;
}

.ts-progress-container:hover .ts-progress-bar {
    height: 6px;
}

.ts-progress-buffered {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 2px;
    width: 0%;
}

.ts-progress-played {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--ts-primary), var(--ts-accent));
    border-radius: 2px;
    width: 0%;
}

.ts-progress-handle {
    position: absolute;
    top: 50%;
    left: 0%;
    width: 14px;
    height: 14px;
    background: #fff;
    border-radius: 50%;
    transform: translate(-50%, -50%) scale(0);
    transition: transform 0.15s;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}

.ts-progress-container:hover .ts-progress-handle {
    transform: translate(-50%, -50%) scale(1);
    box-shadow: 0 0 0 2px var(--ts-primary), 0 2px 8px var(--ts-primary-glow);
}

/* Preview Tooltip */
.ts-preview-tooltip {
    position: absolute;
    bottom: 24px;
    left: 0;
    transform: translateX(-50%);
    display: none;
    flex-direction: column;
    align-items: center;
    pointer-events: none;
    z-index: 30;
}

.ts-progress-container:hover .ts-preview-tooltip {
    display: flex;
}

.ts-preview-thumb {
    width: 160px;
    height: 90px;
    background: #0a0a0a;
    border-radius: var(--ts-preview-radius);
    border: 2px solid var(--ts-preview-border);
    overflow: hidden;
    margin-bottom: 6px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.6);
    position: relative;
}

/* Preview loading animation */
.ts-preview-thumb::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 24px;
    height: 24px;
    margin: -12px 0 0 -12px;
    border: 2px solid rgba(255, 255, 255, 0.1);
    border-top-color: rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    animation: ts-spin 0.8s linear infinite;
    opacity: 0;
    transition: opacity 0.2s;
}

.ts-preview-thumb:not([style*="background-image"])::before,
.ts-preview-thumb[style*="background-image: url(\"\")"]::before {
    opacity: 1;
}

.ts-preview-time {
    background: rgba(0, 0, 0, 0.9);
    color: #fff;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

/* Bottom Controls */
.ts-controls-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.ts-controls-left,
.ts-controls-right {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Buttons */
.ts-btn {
    background: transparent;
    border: none;
    color: #fff;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border-radius: 8px;
    transition: background 0.2s;
    position: relative;
}

.ts-btn:hover {
    background: rgba(255, 255, 255, 0.1);
}

.ts-btn:focus-visible {
    outline: 2px solid var(--ts-primary);
    outline-offset: -2px;
    background: rgba(255, 255, 255, 0.08);
}

.ts-btn i {
    font-size: 16px;
}

.ts-skip-back,
.ts-skip-forward {
    font-size: 14px;
}

.ts-skip-back span,
.ts-skip-forward span {
    position: absolute;
    font-size: 9px;
    font-weight: 700;
}

/* Volume Control */
.ts-volume-control {
    display: flex;
    align-items: center;
    gap: 4px;
}

.ts-volume-slider {
    width: 0;
    height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    overflow: hidden;
    transition: width 0.2s;
    cursor: pointer;
}

.ts-volume-control:hover .ts-volume-slider {
    width: 70px;
}

.ts-volume-level {
    height: 100%;
    background: #fff;
    width: 100%;
    border-radius: 2px;
}

/* Time Display */
.ts-time {
    color: #fff;
    font-size: 13px;
    font-weight: 500;
    font-variant-numeric: tabular-nums;
    margin-left: 8px;
    white-space: nowrap;
}

.ts-current-time {
    color: #fff;
}

.ts-duration {
    color: rgba(255, 255, 255, 0.6);
}

/* Settings Menu */
.ts-settings-menu {
    position: relative;
}

.ts-settings-panel {
    position: absolute;
    bottom: 50px;
    right: 0;
    background: var(--ts-panel-bg);
    border-radius: 10px;
    padding: 12px;
    min-width: 180px;
    display: none;
    backdrop-filter: blur(10px);
    border: 1px solid var(--ts-panel-border);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
    font-family: var(--ts-font);
}

.ts-settings-menu.ts-open .ts-settings-panel {
    display: block;
}

.ts-settings-group {
    margin-bottom: 12px;
}

.ts-settings-group:last-child {
    margin-bottom: 0;
}

.ts-settings-label {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.5);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.ts-speed-options,
.ts-quality-options {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
}

.ts-speed-options button,
.ts-quality-options button {
    background: rgba(255, 255, 255, 0.1);
    border: none;
    color: #fff;
    padding: 6px 8px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
    min-width: 0;
    text-align: center;
    white-space: nowrap;
}

.ts-speed-options button:hover,
.ts-quality-options button:hover {
    background: rgba(255, 255, 255, 0.2);
}

.ts-speed-options button.ts-active,
.ts-quality-options button.ts-active {
    background: var(--ts-primary);
    color: #fff;
}

/* Mobile Double Tap Seek Indicator */
.ts-seek-indicator {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    color: white;
    font-size: 14px;
    font-weight: 600;
    opacity: 0;
    transition: opacity 0.2s ease;
    pointer-events: none;
    z-index: 25;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.ts-seek-indicator.ts-show {
    opacity: 1;
}

.ts-seek-indicator i {
    font-size: 32px;
    animation: seekPulse 0.4s ease-out;
}

.ts-seek-indicator span {
    font-size: 12px;
}

.ts-seek-left {
    left: 15%;
}

.ts-seek-right {
    right: 15%;
}

@keyframes seekPulse {
    0% {
        transform: scale(0.5);
        opacity: 0;
    }

    50% {
        transform: scale(1.2);
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Fullscreen adjustments */
.ts-player.ts-fullscreen .ts-controls {
    padding: 60px 24px 20px;
}

.ts-player.ts-fullscreen .ts-btn {
    width: 48px;
    height: 48px;
}

.ts-player.ts-fullscreen .ts-btn i {
    font-size: 20px;
}

.ts-player.ts-fullscreen .ts-time {
    font-size: 15px;
}

.ts-player.ts-fullscreen .ts-preview-thumb {
    width: 200px;
    height: 112px;
}

/* iOS Video Fullscreen */
.ts-video::-webkit-media-controls {
    display: none !important;
}

.ts-video::-webkit-media-controls-enclosure {
    display: none !important;
}

/* iOS Fullscreen video element */
video::-webkit-media-controls-panel {
    display: flex !important;
}

/* When iOS native fullscreen is active */
.ts-video:-webkit-full-screen {
    width: 100%;
    height: 100%;
}

/* Subtitle button & overlay */
.ts-subtitle-btn.active {
    color: var(--ts-subtitle-active);
}

.ts-subtitle-overlay {
    position: absolute;
    bottom: 80px;
    left: 0;
    right: 0;
    text-align: center;
    z-index: 25;
    pointer-events: none;
    padding: 0 10%;
    transition: bottom 0.2s ease;
}

.ts-subtitle-overlay:empty {
    display: none;
}

.ts-subtitle-overlay span {
    display: inline;
    background: rgba(0, 0, 0, 0.8);
    color: #fff;
    font-size: 1.5rem;
    line-height: 1.8;
    padding: 3px 10px;
    border-radius: 4px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
}

.ts-player:not(:hover):not(.ts-paused) .ts-subtitle-overlay {
    bottom: 20px;
}

.ts-player.ts-fullscreen .ts-subtitle-overlay {
    bottom: 100px;
    padding: 0 15%;
}

.ts-player.ts-fullscreen .ts-subtitle-overlay span {
    font-size: 1.6rem;
}

.ts-player.ts-fullscreen:not(:hover):not(.ts-paused) .ts-subtitle-overlay {
    bottom: 30px;
}

@media (max-width: 640px) {
    .ts-subtitle-overlay {
        bottom: 52px;
        padding: 0 3%;
    }

    .ts-subtitle-overlay span {
        font-size: 1.25rem;
        padding: 3px 8px;
        line-height: 1.7;
    }

    .ts-player:not(:hover):not(.ts-paused) .ts-subtitle-overlay {
        bottom: 14px;
    }

    /* Büyük play — mobilde küçük ve ortalanmış */
    .ts-big-play {
        width: 52px;
        height: 52px;
    }

    .ts-big-play i {
        font-size: 20px;
        transform: translateX(1px);
    }

    /* Kontroller */
    .ts-controls {
        padding: 24px 8px 8px;
    }

    .ts-btn {
        width: 34px;
        height: 34px;
    }

    .ts-btn i {
        font-size: 14px;
    }

    .ts-time {
        font-size: 11px;
        margin-left: 4px;
    }

    .ts-progress-container {
        margin-bottom: 8px;
        padding: 6px 0;
    }

    /* Ayarlar menüsü */
    .ts-settings-panel {
        bottom: 42px;
        right: 0;
        left: auto;
        min-width: 0;
        width: min(200px, calc(100vw - 32px));
        max-width: 200px;
        max-height: min(45vh, 210px);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        padding: 8px;
        border-radius: 8px;
    }

    .ts-settings-label {
        font-size: 9px;
        margin-bottom: 5px;
        letter-spacing: 0.4px;
    }

    .ts-settings-group {
        margin-bottom: 8px;
    }

    .ts-speed-options,
    .ts-quality-options {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 4px;
    }

    .ts-speed-options button,
    .ts-quality-options button {
        padding: 5px 4px;
        font-size: 10px;
        border-radius: 5px;
    }

    .ts-preview-thumb {
        width: 120px;
        height: 68px;
    }

    .ts-preview-time {
        font-size: 11px;
        padding: 3px 8px;
    }
}

@media (max-width: 480px) {
    .ts-skip-back,
    .ts-skip-forward {
        display: none;
    }

    .ts-big-play {
        width: 46px;
        height: 46px;
    }

    .ts-big-play i {
        font-size: 18px;
    }

    .ts-settings-panel {
        width: min(188px, calc(100vw - 24px));
        max-width: 188px;
    }

    .ts-volume-control:hover .ts-volume-slider {
        width: 48px;
    }
}

@media (max-width: 640px) and (orientation: landscape) {
    .ts-subtitle-overlay {
        bottom: 56px;
    }

    .ts-subtitle-overlay span {
        font-size: 1.1rem;
    }

    .ts-player:not(:hover):not(.ts-paused) .ts-subtitle-overlay {
        bottom: 16px;
    }
}

@media (max-width: 380px) {
    .ts-subtitle-overlay span {
        font-size: 0.95rem;
        padding: 2px 6px;
    }
}

/* =============================================================================
   Theme tokens & chrome — video-theme / xxvideo-theme / pornospace-theme
   ============================================================================= */

/* video-theme: kırmızı/siyah, keskin köşeler */
.ts-player.ts-theme-video {
    --ts-primary: #e53935;
    --ts-primary-hover: #ff5252;
    --ts-primary-dark: #b71c1c;
    --ts-primary-glow: rgba(229, 57, 53, 0.38);
    --ts-accent: #ff7043;
    --ts-radius: 4px;
    --ts-preview-radius: 4px;
    --ts-font: 'Inter', 'Source Sans 3', system-ui, sans-serif;
    --ts-panel-bg: rgba(10, 10, 10, 0.96);
    --ts-panel-border: rgba(229, 57, 53, 0.18);
    --ts-preview-border: rgba(229, 57, 53, 0.5);
}

.ts-player.ts-theme-video .ts-controls {
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.92));
}

.ts-player.ts-theme-video .ts-seek-indicator i {
    color: var(--ts-primary-hover);
}

/* xxvideo-theme: magenta/mor, yuvarlak kartlar */
.ts-player.ts-theme-xxvideo {
    --ts-primary: #ff2d95;
    --ts-primary-hover: #ff5aad;
    --ts-primary-dark: #c9186a;
    --ts-primary-glow: rgba(255, 45, 149, 0.4);
    --ts-accent: #ff6b35;
    --ts-radius: 12px;
    --ts-preview-radius: 10px;
    --ts-font: 'Source Sans 3', system-ui, sans-serif;
    --ts-panel-bg: rgba(18, 14, 36, 0.96);
    --ts-panel-border: rgba(255, 45, 149, 0.22);
    --ts-preview-border: rgba(255, 45, 149, 0.55);
}

.ts-player.ts-theme-xxvideo .ts-controls {
    background: linear-gradient(transparent, rgba(12, 11, 20, 0.9));
}

.ts-player.ts-theme-xxvideo .ts-big-play {
    background: linear-gradient(135deg, var(--ts-primary-dark), var(--ts-primary));
}

.ts-player.ts-theme-xxvideo .ts-big-play:hover {
    background: linear-gradient(135deg, var(--ts-primary), var(--ts-primary-hover));
}

.ts-player.ts-theme-xxvideo .ts-preview-time {
    background: rgba(12, 11, 20, 0.92);
    border: 1px solid rgba(255, 45, 149, 0.25);
}

.ts-player.ts-theme-xxvideo .ts-seek-indicator i {
    color: var(--ts-primary);
}

/* pornospace-theme: cyan/mor, app shell estetiği */
.ts-player.ts-theme-pornospace {
    --ts-primary: #22d3ee;
    --ts-primary-hover: #67e8f9;
    --ts-primary-dark: #0891b2;
    --ts-primary-glow: rgba(34, 211, 238, 0.4);
    --ts-accent: #a78bfa;
    --ts-radius: 10px;
    --ts-preview-radius: 8px;
    --ts-font: 'Outfit', system-ui, sans-serif;
    --ts-panel-bg: rgba(10, 15, 26, 0.96);
    --ts-panel-border: rgba(34, 211, 238, 0.24);
    --ts-preview-border: rgba(34, 211, 238, 0.55);
    --ts-subtitle-active: #22d3ee;
}

.ts-player.ts-theme-pornospace .ts-controls {
    background: linear-gradient(transparent, rgba(4, 6, 13, 0.92));
}

.ts-player.ts-theme-pornospace .ts-big-play {
    background: color-mix(in srgb, var(--ts-primary) 88%, #041016);
}

.ts-player.ts-theme-pornospace .ts-speed-options button.ts-active,
.ts-player.ts-theme-pornospace .ts-quality-options button.ts-active {
    color: #041018;
    font-weight: 700;
}

.ts-player.ts-theme-pornospace .ts-preview-time {
    background: rgba(4, 6, 13, 0.92);
    color: var(--ts-primary);
    border: 1px solid rgba(34, 211, 238, 0.3);
}

.ts-player.ts-theme-pornospace .ts-subtitle-overlay span {
    border: 1px solid rgba(34, 211, 238, 0.15);
}

.ts-player.ts-theme-pornospace .ts-seek-indicator i {
    color: var(--ts-primary);
}

/* Watch page çerçeveleri */
.theme-video .xv-player-block .ts-player {
    border-radius: 0;
    box-shadow: none;
}

.theme-video .xv-player-block .ts-player .ts-controls {
    padding-bottom: 10px;
}

.theme-xxvideo .xxv-watch-stage__frame .ts-player,
.theme-pornospace .ps-watch-stage__frame .ts-player {
    box-shadow:
        0 12px 48px rgba(0, 0, 0, 0.55),
        0 0 48px var(--ts-primary-glow);
}

.theme-xxvideo .xxv-watch-stage__frame .ts-player {
    border: 1px solid rgba(255, 45, 149, 0.35);
}

.theme-pornospace .ps-watch-stage__frame .ts-player {
    border: 1px solid rgba(34, 211, 238, 0.35);
}

@media (min-width: 1024px) {
    .theme-video .xv-player-block .ts-player:not(.ts-fullscreen),
    .theme-xxvideo .xxv-watch-stage__frame .ts-player:not(.ts-fullscreen),
    .theme-pornospace .ps-watch-stage__frame .ts-player:not(.ts-fullscreen) {
        max-height: min(56.25vw, 540px);
    }

    .theme-xxvideo .xxv-watch-stage__frame .ts-player:not(.ts-fullscreen),
    .theme-pornospace .ps-watch-stage__frame .ts-player:not(.ts-fullscreen) {
        max-width: 1200px;
        margin-left: auto;
        margin-right: auto;
    }

    .theme-video .xv-player-block:not(:has(.ts-fullscreen)) {
        max-width: 960px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media (max-width: 640px) {
    .theme-video .xv-player-block .ts-player,
    .theme-xxvideo .xxv-watch-stage__frame .ts-player,
    .theme-pornospace .ps-watch-stage__frame .ts-player {
        border-radius: 0;
        border-left: none;
        border-right: none;
    }
}
