/* =========================================================
   Video 50/50 component
   - sb-* = runtime
   - pb-* = builder/canvas (optional alias)
   Token-driven presets so dark mode stays consistent.
   ========================================================= */

.sb-video-5050,
.pb-video-5050 {
    position: relative;
    box-sizing: border-box;
}

.sb-video-5050-row,
.pb-video-5050-row {
    border-radius: 16px;
}

.sb-video-5050-text,
.sb-video-5050-video,
.pb-video-5050-text,
.pb-video-5050-video {
    padding-top: 12px;
    padding-bottom: 12px;
}

.sb-video-5050-content > *:last-child,
.sb-video-5050-video-caption > *:last-child,
.sb-video-5050-video-heading > *:last-child,
.pb-video-5050-content > *:last-child,
.pb-video-5050-video-caption > *:last-child,
.pb-video-5050-video-heading > *:last-child {
    margin-bottom: 0;
}

/* ---------------------------------------------------------
   Background presets
   --------------------------------------------------------- */

.sb-video-5050.bg-light,
.pb-video-5050.bg-light {
    background: var(--sb-surface-2);
    color: var(--sb-text);
}

.sb-video-5050.bg-dark,
.pb-video-5050.bg-dark {
    background: #212529;
    color: #fff;
}

/* ---------------------------------------------------------
   Media wrapper
   --------------------------------------------------------- */

.sb-video-5050-media,
.pb-video-5050-media {
    width: 100%;
    border-radius: 14px;
    overflow: hidden;
    background: transparent;
}

.sb-video-5050-media-inner,
.pb-video-5050-media-inner {
    width: 100%;
    border-radius: 14px;
    overflow: hidden;
    background: var(--sb-surface-2);
    border: 1px solid var(--sb-border);
}

/* Optional shadow toggle (JS adds/removes this class) */
.sb-video-5050-media--shadow,
.pb-video-5050-media--shadow {
    box-shadow: var(--sb-shadow);
}

/* Media background presets must come after media-inner */
.sb-video-5050-media-inner.sb-video-5050-media-bg-light,
.pb-video-5050-media-inner.pb-video-5050-media-bg-light {
    background: var(--sb-surface-2);
    color: var(--sb-text);
}

.sb-video-5050-media-inner.sb-video-5050-media-bg-dark,
.pb-video-5050-media-inner.pb-video-5050-media-bg-dark {
    background: #212529;
    color: #fff;
}

/* ---------------------------------------------------------
   Aspect ratio helpers
   --------------------------------------------------------- */

.sb-ar,
.pb-ar {
    position: relative;
    width: 100%;
}

.sb-ar::before,
.pb-ar::before {
    content: "";
    display: block;
}

.sb-ar-16x9::before,
.pb-ar-16x9::before {
    padding-top: 56.25%;
}

.sb-ar-4x3::before,
.pb-ar-4x3::before {
    padding-top: 75%;
}

.sb-ar-1x1::before,
.pb-ar-1x1::before {
    padding-top: 100%;
}

.sb-ar-21x9::before,
.pb-ar-21x9::before {
    padding-top: 42.857%;
}

.sb-ar > iframe,
.sb-ar > video,
.sb-ar > .sb-ar-inner,
.pb-ar > iframe,
.pb-ar > video,
.pb-ar > .pb-ar-inner,
.pb-ar > .sb-ar-inner {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

/* ---------------------------------------------------------
   Placeholder state
   --------------------------------------------------------- */

.sb-video-5050-placeholder,
.pb-video-5050-placeholder {
    display: grid;
    place-items: center;
    min-height: 220px;
    padding: 24px;
    text-align: center;

    font-size: 0.95rem;
    color: var(--sb-text-muted);
    opacity: 1;

    background: color-mix(in srgb, var(--sb-surface-2) 70%, transparent);
    border: 1px dashed var(--sb-border);
    border-radius: 14px;
}
