/* =========================================================
   Sport Balloon Banner — Frontend Balloon
   ========================================================= */

#sport-balloon-wrap {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 99999;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
    pointer-events: none;
}

#sport-balloon-wrap.sbb-visible {
    pointer-events: auto;
}

/* Close button */
#sport-balloon-close {
    display: none;
    align-self: flex-end;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(0,0,0,.65);
    color: #fff;
    border: none;
    cursor: pointer;
    font-size: 13px;
    line-height: 1;
    align-items: center;
    justify-content: center;
    pointer-events: auto;
    transition: background .2s, transform .15s;
    box-shadow: 0 2px 8px rgba(0,0,0,.4);
    padding: 0;
}

#sport-balloon-close:hover {
    background: rgba(220, 50, 50, .85);
    transform: scale(1.15);
}

/* The balloon itself */
#sport-balloon {
    display: block;
    overflow: hidden;
    background: transparent;
    cursor: default;
    position: relative;
    pointer-events: auto;

    /* subtle drop-shadow */
    filter: drop-shadow(0 4px 12px rgba(0,0,0,.35));

    /* entrance animation */
    animation: sbb-enter .5s cubic-bezier(.34,1.56,.64,1) both;
}

/* When link is present */
#sport-balloon.sbb-clickable {
    cursor: pointer;
}

#sport-balloon.sbb-clickable:hover {
    filter: drop-shadow(0 6px 18px rgba(0,0,0,.45)) brightness(1.05);
    transition: filter .2s ease;
}

/* Image — show as-is, no cropping, no forced shape */
#sport-balloon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* Custom HTML — fill container */
#sport-balloon .sbb-html-inner {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

/* ── Bounce Animation ───────────────────────────── */
@keyframes sbb-bounce {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-10px); }
}

#sport-balloon.sbb-animated {
    animation: sbb-enter .5s cubic-bezier(.34,1.56,.64,1) both,
               sbb-bounce 3s ease-in-out 0.6s infinite;
}

/* ── Entrance ───────────────────────────────────── */
@keyframes sbb-enter {
    from {
        opacity: 0;
        transform: scale(0) translateY(40px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* ── Exit / Hidden ──────────────────────────────── */
#sport-balloon-wrap.sbb-hidden {
    animation: sbb-exit .3s ease forwards;
    pointer-events: none;
}

@keyframes sbb-exit {
    to {
        opacity: 0;
        transform: scale(0) translateY(40px);
    }
}

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 480px) {
    #sport-balloon-wrap {
        bottom: 14px;
        right: 12px;
    }
}
