/* Slot Demoplay — age gate + responsive frame for [demo_slot_iframe].
   Tokens only: assets/css/design-tokens-base.css + site-overrides/design-tokens.css */

.demoplay {
    width: 100%;
    margin-block: var(--spacing-4);
}

/* --- Gate + declined screens --- */
.demoplay__gate,
.demoplay__declined {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-4);
    padding: var(--spacing-8) var(--spacing-5);
    background-color: var(--color-base-ghost-white);
    border: var(--border-width-thin) solid var(--color-base-light-gray);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-card);
}

.demoplay__title {
    margin: 0;
    font-family: var(--font-family-header);
    font-size: var(--font-size-h4);
    font-weight: var(--font-weight-bold);
    color: var(--color-base-dark);
}

.demoplay__text {
    margin: 0;
    max-width: 42ch;
    font-family: var(--font-family-paragraph);
    font-size: var(--font-size-p2-base);
    font-weight: var(--font-weight-regular);
    color: var(--color-default-text);
    line-height: var(--line-height-p2-base);
}

.demoplay__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-3);
    margin-top: var(--spacing-2);
}

.demoplay__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 160px;
    padding: var(--spacing-button-padding-y) var(--spacing-button-padding-x);
    font-family: var(--font-family-header);
    font-size: var(--font-size-button);
    font-weight: var(--font-weight-semibold);
    line-height: 1;
    border: var(--border-width-thin) solid transparent;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.demoplay__btn--yes {
    background-color: var(--color-primary);
    color: var(--color-base-white);
    box-shadow: var(--shadow-button);
}
.demoplay__btn--yes:hover,
.demoplay__btn--yes:focus-visible {
    background-color: var(--color-primary-dark);
}

.demoplay__btn--no {
    background-color: transparent;
    color: var(--color-default-text);
    border-color: var(--color-base-mid-gray);
}
.demoplay__btn--no:hover,
.demoplay__btn--no:focus-visible {
    background-color: var(--color-base-light-gray);
    color: var(--color-base-dark);
}

.demoplay__btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* --- Responsive frame (mobile-first: portrait) --- */
.demoplay__frame {
    position: relative;
    width: 100%;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.demoplay__frame iframe {
    display: block;
    width: 100% !important;
    height: 100% !important;
    border: 0;
}

@media (min-width: 768px) {
    .demoplay__frame {
        aspect-ratio: 16 / 9;
    }
}

/* --- Fullscreen toggle button --- */
.demoplay__fs {
    position: absolute;
    top: var(--spacing-2);
    left: var(--spacing-2);
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    color: var(--color-base-white);
    background-color: rgba(0, 0, 0, 0.55);
    border: 0;
    border-radius: var(--radius-full);
    cursor: pointer;
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
    transition: background-color 0.2s ease;
}

.demoplay__fs:hover,
.demoplay__fs:focus-visible {
    background-color: rgba(0, 0, 0, 0.8);
}

.demoplay__fs:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.demoplay__fs-icon {
    width: 22px;
    height: 22px;
    display: block;
    fill: currentColor;
    pointer-events: none;
}

.demoplay__fs-icon--exit {
    display: none;
}

.demoplay__fs[aria-pressed="true"] .demoplay__fs-icon--enter {
    display: none;
}

.demoplay__fs[aria-pressed="true"] .demoplay__fs-icon--exit {
    display: block;
}

/* --- Fullscreen states --- */
/* CSS "fill the viewport" fallback for iOS / when native fullscreen is blocked.
   100dvh tracks the dynamic viewport so mobile browser chrome doesn't clip it. */
.demoplay__frame--fs {
    position: fixed;
    inset: 0;
    z-index: 9999;
    width: 100vw;
    width: 100dvw;
    height: 100vh;
    height: 100dvh;
    aspect-ratio: auto;
    border-radius: 0;
    background-color: #000;
}

/* Native fullscreen: fill the screen and drop the framed styling.
   Vendor-prefixed selectors are split so an unknown pseudo doesn't void the rule. */
.demoplay__frame:fullscreen {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    border-radius: 0;
    background-color: #000;
}

.demoplay__frame:-webkit-full-screen {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    border-radius: 0;
    background-color: #000;
}

.demoplay__frame:fullscreen iframe {
    width: 100% !important;
    height: 100% !important;
}

.demoplay__frame:-webkit-full-screen iframe {
    width: 100% !important;
    height: 100% !important;
}

/* Lock page scroll behind the CSS-fallback fullscreen */
.demoplay-fs-lock {
    overflow: hidden;
}

/* Guarantee the hidden attribute wins over any inherited display rule */
.demoplay [hidden] {
    display: none !important;
}

@media (prefers-reduced-motion: reduce) {
    .demoplay__btn,
    .demoplay__fs {
        transition: none;
    }
}
