html,
body {
    overflow-x: hidden;
}

.landing-shell *,
.landing-shell *::before,
.landing-shell *::after {
    box-sizing: border-box;
}

.landing-section,
.hero-premium,
.section-cta-premium {
    max-width: 100%;
}

.sapotku-section-with-mascot,
.hero-visual-wrap,
.section-obs-alerts .container,
.cta-premium-card.has-cta-mascot {
    position: relative;
}

.sapotku-mascot {
    position: absolute;
    width: 96px;
    height: auto;
    display: block;
    opacity: 1;
    pointer-events: none;
    user-select: none;
    z-index: 1;
    will-change: transform;
    backface-visibility: hidden;
}

.sapotku-mascot img,
.sapotku-mascot-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    max-width: 100%;
    user-select: none;
}

.sapotku-section-with-mascot > :not(.sapotku-mascot),
.cta-premium-card.has-cta-mascot > :not(.sapotku-mascot) {
    position: relative;
    z-index: 2;
}

.sapotku-mascot--hero {
    width: 96px !important;
    left: auto;
    right: 14px;
    bottom: 14px;
    z-index: 2;
}

.sapotku-mascot--section {
    width: 92px !important;
}

.sapotku-mascot--section-top-right {
    top: -6px;
    right: 0;
}

.sapotku-mascot--obs-top-right {
    top: 8px;
    right: 18px;
}

.sapotku-mascot--cta-right {
    width: 108px !important;
    right: 24px;
    bottom: 20px;
    z-index: 1;
}

.section-heading.has-mascot,
.section-heading-center.has-mascot,
.section-membership .section-heading.has-mascot {
    padding-right: 110px;
    padding-left: 0;
}

.sapotku-mascot--float,
.sapotku-mascot--slow-float,
.sapotku-mascot--hover,
.sapotku-mascot--rocket {
    animation: mascotFloat 4.8s ease-in-out infinite;
}

.sapotku-mascot--pulse {
    animation: mascotFloat 3.4s ease-in-out infinite;
}

.sapotku-mascot--none {
    animation: none;
}

@keyframes mascotFloat {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-6px);
    }
}

@media (max-width: 767.98px) {
    .sapotku-mascot {
        width: 78px !important;
    }

    .sapotku-mascot--hero {
        width: 82px !important;
        max-width: 90px !important;
        left: auto;
        right: 10px;
        bottom: 12px;
        z-index: 2;
    }

    .sapotku-mascot--section,
    .sapotku-mascot--section-top-right,
    .sapotku-mascot--obs-top-right {
        width: 78px !important;
        max-width: 84px !important;
        top: -8px;
        right: 2px;
        opacity: 0.96;
    }

    .sapotku-mascot--cta-right {
        width: 80px !important;
        max-width: 95px !important;
        right: 18px;
        bottom: 18px;
        opacity: 0.95;
    }

    .section-heading.has-mascot,
    .section-heading-center.has-mascot,
    .section-membership .section-heading.has-mascot {
        padding-right: 56px;
        padding-left: 0;
    }

    .section-obs-alerts .row {
        position: relative;
        z-index: 2;
    }

    @keyframes mascotFloat {
        0%, 100% {
            transform: translateY(0);
        }
        50% {
            transform: translateY(-4px);
        }
    }
}

@media (max-width: 480px) {
    .sapotku-mascot--hero {
        width: 78px !important;
    }

    .sapotku-mascot--section,
    .sapotku-mascot--section-top-right,
    .sapotku-mascot--obs-top-right {
        width: 74px !important;
        max-width: 78px !important;
        right: 0;
        top: -10px;
    }

    .sapotku-mascot--cta-right {
        width: 72px !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .sapotku-mascot {
        animation: none !important;
        transform: none !important;
    }
}
