.dltube-player {

    position: relative;
    width: 100%;
    max-width: 960px;
    margin: 40px auto;

    border-radius: 24px;
    overflow: hidden;

    background: #000;

    box-shadow:
        0 20px 60px rgba(0,0,0,.35);

    transform: translateZ(0);
}

/* =========================
   THUMBNAIL
========================= */

.dltube-thumbnail-wrapper {

    position: relative;
    cursor: pointer;
    z-index: 2;
}

.dltube-thumbnail-wrapper img {

    width: 100%;
    display: block;

    transition: transform .5s ease;

    transform: translateZ(0);
}

.dltube-thumbnail-wrapper:hover img {

    transform: scale(1.02);
}

/* =========================
   OVERLAY
========================= */

.dltube-overlay {

    position: absolute;
    inset: 0;

    background:
        linear-gradient(
            to top,
            rgba(0,0,0,.25),
            rgba(0,0,0,.05)
        );

    z-index: 2;
}

/* =========================
   PLAY BUTTON
========================= */

.dltube-play {

    position: absolute;

    top: 50%;
    left: 50%;

    transform: translate(-50%, -50%);

    width: 52px;
    height: 52px;

    border-radius: 10px;

    border: 1px solid rgba(255,255,255,.12);

    background: rgba(0,0,0,.45);

    color: #fff;

    font-size: 16px;

    cursor: pointer;

    z-index: 5;

    transition: .2s ease;
}

/* =========================
   IFRAME PLAYER
========================= */

.dltube-iframe {

    position: relative;
    width: 100%;
    padding-top: 56.25%;

    background: #000;

    z-index: 1;

    transform: translateZ(0);

    overflow: hidden;

    border-radius: 24px;
}

/* =========================
   NORMAL + VSL
========================= */

.dltube-iframe iframe {

    position: absolute;
    inset: 0;

    width: 100%;
    height: 100%;

    border: 0;

    display: block;

    transform: translateZ(0);

    will-change: transform;
}

/* =========================
   VSL EXTREME
========================= */

.dltube-player[data-mode="vsl_extreme"] .dltube-iframe iframe {

    top: -58px;
    left: 0;

    width: 100%;
    height: calc(100% + 116px);
}

/* =========================
   CTA BUTTON - PREMIUM VERDE
========================= */

.dltube-cta {

    position: absolute;
    left: 50%;
    bottom: 22px;

    transform: translateX(-50%) translateY(10px) scale(.98);

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    min-width: 300px;
    max-width: calc(100% - 48px);

    background:
        linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 38%),
        linear-gradient(135deg, var(--dltube-cta-primary, #22c55e) 0%, var(--dltube-cta-secondary, #16a34a) 48%, var(--dltube-cta-shadow, #0b6b34) 100%);
    color: var(--dltube-cta-text, #fff) !important;

    padding: 16px 34px;

    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.24);
    outline: 1px solid color-mix(in srgb, var(--dltube-cta-primary, #22c55e) 50%, transparent);
    outline-offset: -4px;

    text-decoration: none !important;

    font-weight: 900;

    font-size: 18px;
    letter-spacing: .3px;
    text-align: center;
    text-transform: uppercase;

    line-height: 1.15;

    white-space: nowrap;

    opacity: 0;
    visibility: hidden;
    pointer-events: none;

    transition:
        opacity .35s ease,
        visibility .35s ease,
        transform .35s ease,
        box-shadow .25s ease,
        filter .25s ease,
        background .25s ease;

    z-index: 2147483647;

    box-shadow:
        0 0 0 1px rgba(255,255,255,.10) inset,
        0 4px 0 color-mix(in srgb, var(--dltube-cta-shadow, #0b6b34) 80%, transparent),
        0 16px 34px color-mix(in srgb, var(--dltube-cta-primary, #22c55e) 38%, transparent),
        0 9px 22px rgba(0,0,0,.42);

    -webkit-tap-highlight-color: transparent;
}

.dltube-cta::before {
    content: '';
    position: absolute;
    inset: 2px;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255,255,255,.20), rgba(255,255,255,0) 45%);
    pointer-events: none;
}

.dltube-cta::after {
    content: '➜';
    font-size: 18px;
    line-height: 1;
    position: relative;
}

.dltube-cta.active {

    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0) scale(1);
}

.dltube-cta:hover {
    filter: brightness(1.08) saturate(1.08);
    transform: translateX(-50%) translateY(-2px) scale(1.01);
    box-shadow:
        0 0 0 1px rgba(255,255,255,.14) inset,
        0 5px 0 color-mix(in srgb, var(--dltube-cta-shadow, #0b6b34) 84%, transparent),
        0 20px 44px color-mix(in srgb, var(--dltube-cta-primary, #22c55e) 48%, transparent),
        0 12px 26px rgba(0,0,0,.48);
}

.dltube-cta:active {
    transform: translateX(-50%) translateY(2px) scale(.995);
    box-shadow:
        0 0 0 1px rgba(255,255,255,.10) inset,
        0 2px 0 color-mix(in srgb, var(--dltube-cta-shadow, #0b6b34) 80%, transparent),
        0 12px 26px color-mix(in srgb, var(--dltube-cta-primary, #22c55e) 34%, transparent),
        0 7px 18px rgba(0,0,0,.40);
}

@media (max-width: 480px) {
    .dltube-cta {
        bottom: 16px;
        min-width: calc(100% - 40px);
        max-width: calc(100% - 40px);
        padding: 15px 20px;
        font-size: 16px;
        white-space: normal;
        border-radius: 14px;
    }

    .dltube-cta::before {
        border-radius: 12px;
    }
}

/* =========================
   VSL MODE
========================= */

.dltube-player[data-mode="vsl"] .dltube-play {

    width: 68px;
    height: 68px;

    background: rgba(0,0,0,.22);

    border: 1px solid rgba(255,255,255,.12);
}

.dltube-player[data-mode="vsl"] .dltube-overlay {

    background:
        radial-gradient(
            circle,
            rgba(0,0,0,.15),
            rgba(0,0,0,.55)
        );
}

/* =========================
   VSL EXTREME STYLE
========================= */

.dltube-player[data-mode="vsl_extreme"] .dltube-play {

    width: 68px;
    height: 68px;

    background: rgba(0,0,0,.18);

    border: 1px solid rgba(255,255,255,.08);

    backdrop-filter: blur(4px);
}

.dltube-player[data-mode="vsl_extreme"] .dltube-overlay {

    background:
        radial-gradient(
            circle,
            rgba(0,0,0,.10),
            rgba(0,0,0,.70)
        );
}

/* =========================
   ESCONDER PLAY
========================= */

.dltube-player.hide-play .dltube-play {

    display: none;
}

/* =====================================================
   DeleonTubePlayer - Modo VSL Overlay Ativar Som
   ===================================================== */

.dltube-player.vsl-overlay-enabled {
    position: relative;
    overflow: hidden;
    background: #000;
    border-radius: 14px;
}

.dltube-player.vsl-overlay-enabled .dltube-iframe {
    position: relative;
    display: block;
}

.dltube-vsl-sound-overlay {
    position: absolute;
    inset: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(1px);
    transition: opacity .3s ease, visibility .3s ease;
}

.dltube-vsl-sound-overlay.hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.dltube-vsl-sound-card {
    width: min(92%, 620px);
    padding: 34px 28px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(16, 16, 16, 0.72), rgba(0, 0, 0, 0.62));
    box-shadow: 0 20px 60px rgba(0,0,0,.45);
    color: #fff;
}

.dltube-vsl-sound-card h2 {
    margin: 0 0 18px;
    font-size: clamp(28px, 5vw, 52px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: #fff;
    text-shadow: 0 3px 14px rgba(0,0,0,.35);
}

.dltube-vsl-sound-icon {
    font-size: clamp(48px, 8vw, 86px);
    line-height: 1;
    margin: 10px 0 18px;
    color: var(--dltube-overlay-primary, #ffd400);
    filter: drop-shadow(0 8px 18px rgba(255, 212, 0, .25));
}

.dltube-vsl-sound-card p {
    margin: 0 0 22px;
    font-size: clamp(16px, 2.5vw, 24px);
    color: rgba(255,255,255,.94);
}

.dltube-vsl-sound-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 18px 44px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(180deg, var(--dltube-overlay-primary, #ffd900), var(--dltube-overlay-secondary, #ffb800));
    color: var(--dltube-overlay-text, #111);
    font-size: clamp(18px, 3vw, 30px);
    font-weight: 900;
    letter-spacing: .02em;
    cursor: pointer;
    box-shadow: 0 10px 30px color-mix(in srgb, var(--dltube-overlay-primary, #ffd900) 35%, transparent);
    transform: translateY(0);
    transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.dltube-vsl-sound-btn:hover {
    transform: translateY(-2px);
    filter: brightness(1.04);
    box-shadow: 0 16px 38px color-mix(in srgb, var(--dltube-overlay-primary, #ffd900) 46%, transparent);
}

.dltube-vsl-sound-card small {
    display: block;
    margin-top: 18px;
    color: rgba(255,255,255,.72);
    font-size: 14px;
}

@media (max-width: 600px) {
    .dltube-vsl-sound-card {
        width: 94%;
        padding: 24px 18px;
        border-radius: 18px;
    }

    .dltube-vsl-sound-btn {
        width: 100%;
        padding: 16px 18px;
    }
}

/* =====================================================
   DeleonTubePlayer 2.1.1 - Ajuste Responsivo Automático
   O player e o overlay agora respeitam o tamanho do bloco/coluna.
   ===================================================== */

.dltube-player,
.dltube-player * {
    box-sizing: border-box;
}

.dltube-player {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.dltube-iframe {
    width: 100%;
    max-width: 100%;
    aspect-ratio: 16 / 9;
    padding-top: 0 !important;
    height: auto;
    min-height: 0;
}

.dltube-ratio {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.dltube-ratio iframe,
.dltube-iframe iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
    border: 0;
    display: block;
}

.dltube-player.vsl-overlay-enabled .dltube-iframe {
    aspect-ratio: 16 / 9;
    max-width: 100%;
    overflow: hidden;
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-overlay {
    max-width: 100%;
    max-height: 100%;
    padding: clamp(8px, 2vw, 18px);
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card {
    width: min(92%, 520px);
    max-height: 92%;
    overflow: hidden;
    padding: clamp(14px, 3vw, 30px);
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card h2 {
    font-size: clamp(18px, 4vw, 42px);
    margin-bottom: clamp(8px, 2vw, 16px);
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-icon {
    font-size: clamp(34px, 7vw, 70px);
    margin: clamp(6px, 1.5vw, 14px) 0;
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card p {
    font-size: clamp(13px, 2vw, 20px);
    margin-bottom: clamp(10px, 2vw, 18px);
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-btn {
    max-width: 100%;
    padding: clamp(10px, 2vw, 16px) clamp(16px, 4vw, 36px);
    font-size: clamp(14px, 2.8vw, 24px);
    white-space: nowrap;
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card small {
    font-size: clamp(10px, 1.6vw, 13px);
    margin-top: clamp(8px, 1.5vw, 14px);
}

/* Ajuste especial para locais pequenos, como galeria do WooCommerce ou colunas estreitas */
@media (max-width: 520px) {
    .dltube-player {
        margin-top: 16px;
        margin-bottom: 16px;
        border-radius: 14px;
    }

    .dltube-iframe,
    .dltube-player.vsl-overlay-enabled .dltube-iframe {
        border-radius: 14px;
    }

    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card {
        width: 94%;
        padding: 14px 12px;
        border-radius: 14px;
    }

    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card h2 {
        font-size: 18px;
        line-height: 1.1;
    }

    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-icon {
        font-size: 34px;
        margin: 6px 0;
    }

    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card p {
        font-size: 13px;
        margin-bottom: 10px;
    }

    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-btn {
        width: auto;
        padding: 10px 16px;
        font-size: 14px;
        border-radius: 10px;
    }

    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card small {
        display: none;
    }
}

/* Container queries: quando o player estiver em bloco pequeno, o overlay diminui mesmo em tela grande */
@supports (container-type: inline-size) {
    .dltube-player {
        container-type: inline-size;
    }

    @container (max-width: 520px) {
        .dltube-vsl-sound-card {
            width: 94%;
            padding: 14px 12px;
            border-radius: 14px;
        }

        .dltube-vsl-sound-card h2 {
            font-size: 18px;
            line-height: 1.1;
            margin-bottom: 8px;
        }

        .dltube-vsl-sound-icon {
            font-size: 34px;
            margin: 6px 0;
        }

        .dltube-vsl-sound-card p {
            font-size: 13px;
            margin-bottom: 10px;
        }

        .dltube-vsl-sound-btn {
            width: auto;
            padding: 10px 16px;
            font-size: 14px;
            border-radius: 10px;
        }

        .dltube-vsl-sound-card small {
            display: none;
        }
    }
}

/* =====================================================
   DeleonTubePlayer 2.1.4 - Estabilidade do ícone Overlay
   Troca o ícone emoji por SVG estável para evitar "pulo"
   no carregamento do overlay.
   ===================================================== */

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-icon {
    width: clamp(42px, 7vw, 76px) !important;
    height: clamp(42px, 7vw, 76px) !important;
    min-width: clamp(42px, 7vw, 76px) !important;
    min-height: clamp(42px, 7vw, 76px) !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    margin: clamp(6px, 1.5vw, 14px) auto !important;

    font-size: 0 !important;
    line-height: 0 !important;

    color: var(--dltube-overlay-primary, #ffd400);
    filter: drop-shadow(0 8px 18px rgba(255, 212, 0, .25));

    transform: none !important;
    transition: none !important;
    will-change: auto !important;
    backface-visibility: hidden;
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-icon svg {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    fill: currentColor !important;
    stroke: currentColor !important;
    stroke-width: 5;
    stroke-linecap: round;
    stroke-linejoin: round;
    overflow: visible;
}

.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-card {
    transform: none !important;
}

.dltube-vsl-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1em;
    height: 1em;
    font-size: .8em;
    line-height: 1;
}

@media (max-width: 520px) {
    .dltube-player.vsl-overlay-enabled .dltube-vsl-sound-icon {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        margin: 6px auto !important;
    }
}



/* =====================================================
   DeleonTubePlayer LAB - Barra VSL Premium
   Barra visual fiel ao tempo real do vídeo.
   ===================================================== */

.dltube-vsl-progress {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 12px;
    z-index: 28;
    height: 10px;
    border-radius: 999px;
    pointer-events: none;
    overflow: hidden;
    background: rgba(255,255,255,.14);
    box-shadow:
        0 0 0 1px rgba(255,255,255,.10) inset,
        0 8px 20px rgba(0,0,0,.35);
}

.dltube-vsl-progress-track {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    overflow: hidden;
}

.dltube-vsl-progress-fill {
    position: absolute;
    left: 0;
    top: 0;
    width: 0%;
    height: 100%;
    border-radius: inherit;
    background:
        linear-gradient(90deg, #facc15 0%, #f59e0b 45%, #22c55e 100%);
    box-shadow:
        0 0 12px rgba(250,204,21,.45),
        0 0 22px rgba(34,197,94,.28);
    transition: width .45s ease;
}

/* Mantém a barra discreta quando o CTA aparece */
.dltube-player .dltube-cta.active ~ .dltube-vsl-progress {
    opacity: .75;
}

@media (max-width: 520px) {
    .dltube-vsl-progress {
        left: 12px;
        right: 12px;
        bottom: 8px;
        height: 8px;
    }
}


/* Barra VSL Agressiva - brilho reforçado */
.dltube-player[data-vsl-bar-aggressive="1"] .dltube-vsl-progress-fill {
    background: linear-gradient(90deg, #fde047 0%, #f97316 45%, #22c55e 100%);
    box-shadow:
        0 0 14px rgba(250,204,21,.55),
        0 0 28px rgba(249,115,22,.35),
        0 0 24px rgba(34,197,94,.25);
}



/* =========================
   BORDA PREMIUM PERSONALIZADA
========================= */

.dltube-player.dltube-border-enabled {
    border: var(--dltube-border-width, 1px) solid var(--dltube-border-color, #facc15);
    box-shadow:
        0 0 0 1px rgba(255,255,255,.06) inset,
        0 0 12px color-mix(in srgb, var(--dltube-border-color, #facc15) 28%, transparent),
        0 20px 60px rgba(0,0,0,.35);
}

@supports not (color: color-mix(in srgb, #fff 50%, transparent)) {
    .dltube-player.dltube-border-enabled {
        box-shadow:
            0 0 0 1px rgba(255,255,255,.06) inset,
            0 0 10px rgba(250,204,21,.25),
            0 20px 60px rgba(0,0,0,.35);
    }
}



/* =========================
   AJUSTE FINO: OVERLAY + BORDA PREMIUM
   Mantém o overlay com o mesmo arredondamento do player.
========================= */

.dltube-player {
    --dltube-player-radius: 24px;
}

.dltube-player.vsl-overlay-enabled {
    border-radius: var(--dltube-player-radius) !important;
    overflow: hidden !important;
}

.dltube-player.vsl-overlay-enabled .dltube-iframe,
.dltube-player.vsl-overlay-enabled .dltube-ratio,
.dltube-player.vsl-overlay-enabled .dltube-overlay,
.dltube-player.vsl-overlay-enabled .dltube-vsl-sound-overlay {
    border-radius: inherit !important;
    overflow: hidden !important;
}

.dltube-player.vsl-overlay-enabled .dltube-ratio iframe,
.dltube-player.vsl-overlay-enabled .dltube-iframe iframe {
    border-radius: inherit !important;
}

.dltube-player.dltube-border-enabled.vsl-overlay-enabled {
    background-clip: padding-box;
}

@media (max-width: 520px) {
    .dltube-player {
        --dltube-player-radius: 14px;
    }
}


/* Fallback para navegadores sem color-mix no Overlay */
@supports not (color: color-mix(in srgb, #fff 50%, transparent)) {
    .dltube-vsl-sound-btn {
        box-shadow: 0 10px 30px color-mix(in srgb, var(--dltube-overlay-primary, #ffd900) 35%, transparent);
    }

    .dltube-vsl-sound-btn:hover {
        box-shadow: 0 16px 38px color-mix(in srgb, var(--dltube-overlay-primary, #ffd900) 46%, transparent);
    }
}


/* =========================
   BANNER OFERTA TEMPORIZADO
========================= */

.dltube-offer-banner {
    width: 100%;
    max-width: 960px;
    margin: 18px auto 28px;
    text-decoration: none !important;
    opacity: 0;
    transform: translateY(12px);
    transition:
        opacity .35s ease,
        transform .35s ease,
        filter .25s ease;
}

.dltube-offer-banner.active {
    display: block !important;
    opacity: 1;
    transform: translateY(0);
}

.dltube-offer-banner img {
    width: 100%;
    display: block;
    border-radius: 18px;
    box-shadow:
        0 14px 36px rgba(0,0,0,.28),
        0 0 0 1px rgba(255,255,255,.08) inset;
}

.dltube-offer-banner:hover {
    filter: brightness(1.04);
}

@media (max-width: 520px) {
    .dltube-offer-banner {
        margin: 14px auto 22px;
    }

    .dltube-offer-banner img {
        border-radius: 14px;
    }
}


/* =========================
   CTA CORES - FALLBACK
========================= */

@supports not (color: color-mix(in srgb, #fff 50%, transparent)) {
    .dltube-cta {
        outline: 1px solid rgba(255,255,255,.18);
    }

    .dltube-player.cta-color-red .dltube-cta {
        box-shadow: 0 0 0 1px rgba(255,255,255,.10) inset, 0 4px 0 rgba(127,29,29,.80), 0 16px 34px rgba(239,68,68,.38), 0 9px 22px rgba(0,0,0,.42);
    }

    .dltube-player.cta-color-blue .dltube-cta {
        box-shadow: 0 0 0 1px rgba(255,255,255,.10) inset, 0 4px 0 rgba(30,58,138,.80), 0 16px 34px rgba(59,130,246,.38), 0 9px 22px rgba(0,0,0,.42);
    }

    .dltube-player.cta-color-purple .dltube-cta {
        box-shadow: 0 0 0 1px rgba(255,255,255,.10) inset, 0 4px 0 rgba(76,29,149,.80), 0 16px 34px rgba(168,85,247,.38), 0 9px 22px rgba(0,0,0,.42);
    }

    .dltube-player.cta-color-orange .dltube-cta {
        box-shadow: 0 0 0 1px rgba(255,255,255,.10) inset, 0 4px 0 rgba(124,45,18,.80), 0 16px 34px rgba(249,115,22,.38), 0 9px 22px rgba(0,0,0,.42);
    }

    .dltube-player.cta-color-yellow .dltube-cta {
        box-shadow: 0 0 0 1px rgba(255,255,255,.10) inset, 0 4px 0 rgba(120,53,15,.80), 0 16px 34px rgba(250,204,21,.38), 0 9px 22px rgba(0,0,0,.42);
    }
}


/* =========================
   DeleonTubePlayer v2.2.1
   Correção: mantém cor do botão Overlay no hover/focus/click
   Evita que tema/Elementor force texto branco ou fundo branco.
========================= */
.dltube-vsl-sound-btn,
.dltube-vsl-sound-btn:hover,
.dltube-vsl-sound-btn:focus,
.dltube-vsl-sound-btn:active,
.dltube-vsl-sound-btn:visited {
    background: linear-gradient(180deg, var(--dltube-overlay-primary, #ffd900), var(--dltube-overlay-secondary, #ffb800)) !important;
    color: var(--dltube-overlay-text, #111) !important;
    border: 0 !important;
    text-decoration: none !important;
}

.dltube-vsl-sound-btn:hover,
.dltube-vsl-sound-btn:focus {
    transform: translateY(-2px);
    filter: brightness(1.04);
}

.dltube-vsl-sound-btn * {
    color: inherit !important;
}
