/* *
 * XElementor Interactive App Demo
 * Interactive App Demo for Elementor.
 * Exclusively on https://xelementor.com
 * *
 * @copyright       (C) 2019 - 2023 XElementor ( https://xelementor.com ). All rights reserved.
 * @license         Envato License
 * @contributors    Nenad Mihajlovic
 * @support         https://xelementor.com
 * */

.xel-interactive-app-demo {
    --xel-iad-aspect-ratio: 16 / 9;
    --xel-iad-radius: 8px;
    --xel-iad-shadow: 0 18px 48px rgba(16, 24, 40, 0.18);
    --xel-iad-top-bar-height: 34px;
    --xel-iad-click-color: #2563eb;
    position: relative;
    width: 100%;
}

.xel-iad-window {
    overflow: hidden;
    background: #101828;
    border: 1px solid rgba(16, 24, 40, 0.12);
    border-radius: var(--xel-iad-radius);
    box-shadow: var(--xel-iad-shadow);
}

.xel-iad-stage {
    position: relative;
    width: 100%;
    aspect-ratio: var(--xel-iad-aspect-ratio);
    min-height: 220px;
    overflow: hidden;
    background: #101828;
    isolation: isolate;
}

.xel-iad-top-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    height: var(--xel-iad-top-bar-height);
    padding: 0 13px;
    background: linear-gradient(180deg, #f8fafc 0%, #e5e7eb 100%);
    border-bottom: 1px solid rgba(16, 24, 40, 0.13);
}

.xel-iad-top-bar-dark .xel-iad-top-bar {
    background: linear-gradient(180deg, #2f3540 0%, #1f242d 100%);
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

.xel-iad-window-dot {
    display: block;
    width: 12px;
    height: 12px;
    border-radius: 999px;
    box-shadow: inset 0 0 0 1px rgba(16, 24, 40, 0.12);
}

.xel-iad-window-dot-red {
    background: #ff5f57;
}

.xel-iad-window-dot-yellow {
    background: #ffbd2e;
}

.xel-iad-window-dot-green {
    background: #28c840;
}

.xel-iad-screen {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: top center;
    transform-origin: 50% 0;
    transition: filter 380ms ease, opacity 380ms ease;
    will-change: transform, filter, opacity;
}

.xel-iad-transition-fade {
    animation: xel-iad-fade 420ms ease both;
}

.xel-iad-transition-slide-left {
    animation: xel-iad-slide-left 480ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.xel-iad-transition-slide-up {
    animation: xel-iad-slide-up 480ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.xel-iad-transition-zoom {
    animation: xel-iad-zoom 500ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.xel-iad-transition-blur {
    animation: xel-iad-blur 520ms ease both;
}

.xel-iad-cursor {
    position: absolute;
    z-index: 8;
    top: 0;
    left: 0;
    width: clamp(34px, 4.2vw, 58px);
    height: auto;
    pointer-events: none;
    transform: translate3d(0, 0, 0) translate(-40%, -10%);
    transform-origin: 40% 10%;
    will-change: transform;
}

.xel-iad-cursor img {
    display: block;
    width: 100%;
    height: auto;
    filter: drop-shadow(0 4px 6px rgba(16, 24, 40, 0.24));
    transition: transform 160ms ease;
    user-select: none;
}

.xel-iad-cursor-clicking img {
    transform: scale(0.86);
}

.xel-iad-click {
    position: absolute;
    z-index: 4;
    top: 0;
    left: 0;
    width: clamp(28px, 4vw, 54px);
    height: clamp(28px, 4vw, 54px);
    pointer-events: none;
    border: 4px solid var(--xel-iad-click-color);
    border-radius: 999px;
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--xel-iad-click-color) 18%, transparent), 0 0 26px color-mix(in srgb, var(--xel-iad-click-color) 34%, transparent);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.36);
}

.xel-iad-click-active {
    animation: xel-iad-click 520ms ease-out both;
}

.xel-iad-typed {
    position: absolute;
    z-index: 3;
    right: 6%;
    bottom: 7%;
    left: 6%;
    min-height: 42px;
    padding: 11px 14px;
    overflow: hidden;
    color: #111827;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(16, 24, 40, 0.12);
    border-radius: 8px;
    box-shadow: 0 12px 32px rgba(16, 24, 40, 0.16);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: clamp(12px, 1.35vw, 15px);
    line-height: 1.45;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 180ms ease, transform 180ms ease;
    white-space: pre-wrap;
}

.xel-iad-typed::after {
    display: inline-block;
    width: 1px;
    height: 1em;
    margin-left: 2px;
    background: #2563eb;
    content: "";
    vertical-align: -0.15em;
    animation: xel-iad-caret 850ms steps(2, start) infinite;
}

.xel-iad-typed-visible {
    opacity: 1;
    transform: translateY(0);
}

.xel-iad-hotspots {
    position: absolute;
    z-index: 5;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 180ms ease;
}

.xel-iad-hotspots-visible {
    pointer-events: auto;
    opacity: 1;
}

.xel-iad-hotspot {
    position: absolute;
    min-width: 18px;
    min-height: 18px;
    padding: 0;
    border: 2px solid var(--xel-iad-hotspot-color, #2563eb);
    border-radius: 6px;
    background: color-mix(in srgb, var(--xel-iad-hotspot-color, #2563eb) 14%, transparent);
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--xel-iad-hotspot-color, #2563eb) 16%, transparent);
    cursor: pointer;
    transform: translate(-50%, -50%);
}

.xel-iad-hotspot::after {
    position: absolute;
    inset: -8px;
    border: 1px solid color-mix(in srgb, var(--xel-iad-hotspot-color, #2563eb) 28%, transparent);
    border-radius: 9px;
    content: "";
    animation: xel-iad-hotspot-pulse 1400ms ease-in-out infinite;
}

.xel-iad-hotspot:hover,
.xel-iad-hotspot:focus-visible {
    background: color-mix(in srgb, var(--xel-iad-hotspot-color, #2563eb) 22%, transparent);
    outline: none;
}

@keyframes xel-iad-fade {
    from {
        opacity: 0.2;
    }
    to {
        opacity: 1;
    }
}

@keyframes xel-iad-slide-left {
    from {
        opacity: 0.4;
        transform: translate3d(3.5%, 0, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes xel-iad-slide-up {
    from {
        opacity: 0.4;
        transform: translate3d(0, 3.5%, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes xel-iad-zoom {
    from {
        opacity: 0.45;
        transform: scale(1.035);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes xel-iad-blur {
    from {
        opacity: 0.45;
        filter: blur(8px);
    }
    to {
        opacity: 1;
        filter: blur(0);
    }
}

@keyframes xel-iad-hotspot-pulse {
    0%,
    100% {
        opacity: 0.3;
        transform: scale(0.96);
    }
    50% {
        opacity: 0.85;
        transform: scale(1.03);
    }
}

@keyframes xel-iad-click {
    0% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(0.28);
    }
    48% {
        opacity: 0.72;
    }
    100% {
        opacity: 0;
        transform: translate(-50%, -50%) scale(1.65);
    }
}

@keyframes xel-iad-caret {
    0%,
    45% {
        opacity: 1;
    }
    46%,
    100% {
        opacity: 0;
    }
}

@media (max-width: 767px) {
    .xel-iad-stage {
        min-height: 180px;
    }

    .xel-iad-typed {
        right: 4%;
        bottom: 5%;
        left: 4%;
        min-height: 36px;
        padding: 9px 11px;
    }
}
