/* =========================================================
 * Széchenyi Terv Plusz Infoblokk – Frontend styles
 * A 64px magasság az Arculati Kézikönyv Plusz 5.10 szerint kötelező.
 * ========================================================= */

#sztp-infoblokk {
    position: fixed;
    height: 64px;
    background: #ffffff;
    border-radius: 6px;
    overflow: visible;
    line-height: 0;
    box-shadow:
        0 4px 16px rgba(0, 0, 0, 0.08),
        0 1px 3px rgba(0, 0, 0, 0.06);
    transition:
        opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1),
        transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: opacity, transform;
}

#sztp-infoblokk.sztp-position-bottom-right { bottom: 24px; right: 24px; }
#sztp-infoblokk.sztp-position-bottom-left  { bottom: 24px; left: 24px; }
#sztp-infoblokk.sztp-position-top-right    { top: 24px; right: 24px; }
#sztp-infoblokk.sztp-position-top-left     { top: 24px; left: 24px; }

#sztp-infoblokk .sztp-link,
#sztp-infoblokk > img {
    display: block;
    height: 64px;
    width: auto;
}

#sztp-infoblokk img {
    height: 64px;
    width: auto;
    display: block;
    border: 0;
    max-width: none;
    border-radius: 6px;
}

/* ---------- Modern, designerly close button ---------- */
#sztp-infoblokk .sztp-close {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 24px;
    height: 24px;
    border: none;
    background: #ffffff;
    border-radius: 50%;
    cursor: pointer;
    padding: 0;
    font-size: 0;
    color: #6b7280;
    box-shadow:
        0 1px 3px rgba(0, 0, 0, 0.12),
        0 0 0 1px rgba(0, 0, 0, 0.06);
    transition:
        background 0.2s cubic-bezier(0.4, 0, 0.2, 1),
        color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
        transform 0.2s cubic-bezier(0.4, 0, 0.2, 1),
        box-shadow 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 2;
}

#sztp-infoblokk .sztp-close::before,
#sztp-infoblokk .sztp-close::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 1.5px;
    background: currentColor;
    border-radius: 1px;
}

#sztp-infoblokk .sztp-close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

#sztp-infoblokk .sztp-close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

#sztp-infoblokk .sztp-close:hover,
#sztp-infoblokk .sztp-close:focus-visible {
    background: #f9fafb;
    color: #111827;
    transform: scale(1.08);
    box-shadow:
        0 2px 8px rgba(0, 0, 0, 0.15),
        0 0 0 1px rgba(0, 0, 0, 0.08);
    outline: none;
}

#sztp-infoblokk .sztp-close:active {
    transform: scale(0.94);
}

/* ---------- Elegáns fade-out (X gomb és görgetés is ezt használja) ---------- */
#sztp-infoblokk.sztp-hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px) scale(0.96);
}

/* Felső pozíció esetén természetesebb felfelé "elszállni" */
#sztp-infoblokk.sztp-position-top-right.sztp-hidden,
#sztp-infoblokk.sztp-position-top-left.sztp-hidden {
    transform: translateY(-8px) scale(0.96);
}

/* ---------- Mobil viselkedés ---------- */
@media (max-width: 768px) {
    #sztp-infoblokk.sztp-mobile-smaller,
    #sztp-infoblokk.sztp-mobile-smaller .sztp-link,
    #sztp-infoblokk.sztp-mobile-smaller img {
        height: 48px;
    }
    #sztp-infoblokk.sztp-mobile-smaller {
        bottom: 12px;
        right: 12px;
        left: auto;
        top: auto;
    }
    #sztp-infoblokk.sztp-mobile-smaller.sztp-position-bottom-left { left: 12px; right: auto; }
    #sztp-infoblokk.sztp-mobile-smaller.sztp-position-top-right   { top: 12px; right: 12px; bottom: auto; }
    #sztp-infoblokk.sztp-mobile-smaller.sztp-position-top-left    { top: 12px; left: 12px; right: auto; bottom: auto; }

    #sztp-infoblokk.sztp-mobile-hidden {
        display: none !important;
    }
}

