/* =========================================================
   SPONZA – hamburger menu + footer
   ========================================================= */

/* tlačítko menu */
.spz-menu-toggle {
    position: fixed !important;
    top: 72px !important;
    right: 58px !important;
    z-index: 1000000 !important;

    width: 54px !important;
    height: 54px !important;
    border: 0 !important;
    border-radius: 999px !important;

    background: #142136 !important;
    box-shadow: 0 12px 30px rgba(20, 33, 54, 0.22) !important;
    cursor: pointer !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 5px !important;
}

.spz-menu-toggle span {
    width: 22px !important;
    height: 3px !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    display: block !important;
}

/* overlay */
.spz-menu-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;

    display: block !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;

    background: rgba(20, 33, 54, 0.42) !important;
    backdrop-filter: blur(8px) !important;

    transition: opacity 0.22s ease, visibility 0.22s ease !important;
}

.spz-menu-overlay.is-open {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

/* panel menu zprava */
.spz-menu-panel {
    position: fixed !important;
    top: 24px !important;
    right: 24px !important;
    left: auto !important;

    width: min(360px, calc(100vw - 48px)) !important;
    max-width: 360px !important;
    max-height: calc(100vh - 48px) !important;
    overflow-y: auto !important;

    padding: 26px 24px !important;
    border-radius: 26px !important;

    background: rgba(255, 250, 246, 0.98) !important;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.25) !important;
    box-sizing: border-box !important;

    transform: translateX(120%) !important;
    transition: transform 0.28s ease !important;
}

.spz-menu-overlay.is-open .spz-menu-panel {
    transform: translateX(0) !important;
}

/* zavírací křížek */
.spz-menu-close {
    position: absolute !important;
    top: 14px !important;
    right: 16px !important;

    border: 0 !important;
    background: transparent !important;
    color: #142136 !important;

    font-size: 32px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}

/* obsah menu */
.spz-menu-title {
    margin: 0 36px 18px 0 !important;
    color: #142136 !important;
    font-size: 22px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    letter-spacing: -0.04em !important;
}

.spz-menu-nav ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.spz-menu-nav li {
    margin: 0 !important;
    padding: 0 !important;
}

.spz-menu-nav li + li {
    margin-top: 8px !important;
}

.spz-menu-nav a {
    display: block !important;
    padding: 10px 0 !important;

    color: #142136 !important;
    font-size: 19px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    letter-spacing: -0.03em !important;
}

.spz-menu-nav a:hover,
.spz-menu-nav .current-menu-item > a {
    color: #d8755f !important;
}

/* při otevřeném menu zamknout stránku */
html.spz-menu-open,
body.spz-menu-open {
    overflow: hidden !important;
}

/* footer */
.spz-site-footer {
    background: #142136 !important;
    color: #ffffff !important;
    padding: 34px 48px !important;
}

.spz-site-footer-inner {
    width: min(1320px, 100%) !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 22px !important;
    flex-wrap: wrap !important;
}

.spz-site-footer strong {
    font-size: 22px !important;
    letter-spacing: -0.04em !important;
}

.spz-site-footer span,
.spz-site-footer small {
    color: rgba(255, 255, 255, 0.72) !important;
}

/* mobil */
@media (max-width: 720px) {
    .spz-menu-toggle {
        top: 22px !important;
        right: 20px !important;
        width: 48px !important;
        height: 48px !important;
    }

    .spz-menu-panel {
        top: 16px !important;
        right: 16px !important;
        width: calc(100vw - 32px) !important;
        max-width: none !important;
        max-height: calc(100vh - 32px) !important;
        padding: 24px 22px !important;
        border-radius: 24px !important;
    }

    .spz-menu-title {
        font-size: 21px !important;
    }

    .spz-menu-nav a {
        font-size: 18px !important;
        padding: 9px 0 !important;
    }

    .spz-site-footer {
        padding: 28px 22px !important;
    }

    .spz-site-footer-inner {
        display: block !important;
    }

    .spz-site-footer span,
    .spz-site-footer small {
        display: block !important;
        margin-top: 10px !important;
    }
}

/* SPONZA – menu vždy nad článkem */
.spz-menu-toggle {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    z-index: 2147483647 !important;
}

.spz-menu-overlay {
    z-index: 2147483646 !important;
}

.spz-menu-overlay.is-open {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

.spz-menu-panel {
    z-index: 2147483647 !important;
}

/* =========================================================
   SPONZA – hamburger bez JS, funkční i na článcích
   ========================================================= */

.spz-menu-check {
    position: fixed !important;
    left: -9999px !important;
    top: -9999px !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.spz-menu-toggle {
    position: fixed !important;
    top: 72px !important;
    right: 58px !important;
    z-index: 2147483647 !important;

    width: 54px !important;
    height: 54px !important;
    border-radius: 999px !important;
    background: #142136 !important;
    box-shadow: 0 12px 30px rgba(20, 33, 54, 0.22) !important;
    cursor: pointer !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 5px !important;
}

.spz-menu-toggle span {
    width: 22px !important;
    height: 3px !important;
    border-radius: 999px !important;
    background: #fff !important;
    display: block !important;
}

.spz-menu-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483646 !important;

    display: block !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;

    background: rgba(20, 33, 54, 0.42) !important;
    backdrop-filter: blur(8px) !important;
    transition: opacity .22s ease, visibility .22s ease !important;
}

.spz-menu-check:checked ~ .spz-menu-overlay {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

.spz-menu-backdrop {
    position: absolute !important;
    inset: 0 !important;
    display: block !important;
    cursor: default !important;
}

.spz-menu-panel {
    position: fixed !important;
    top: 24px !important;
    right: 24px !important;
    left: auto !important;

    width: min(360px, calc(100vw - 48px)) !important;
    max-width: 360px !important;
    max-height: calc(100vh - 48px) !important;
    overflow-y: auto !important;

    padding: 26px 24px !important;
    border-radius: 26px !important;
    background: rgba(255, 250, 246, 0.98) !important;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.25) !important;
    box-sizing: border-box !important;

    transform: translateX(120%) !important;
    transition: transform .28s ease !important;
    z-index: 2147483647 !important;
}

.spz-menu-check:checked ~ .spz-menu-overlay .spz-menu-panel {
    transform: translateX(0) !important;
}

.spz-menu-close {
    position: absolute !important;
    top: 14px !important;
    right: 16px !important;

    border: 0 !important;
    background: transparent !important;
    color: #142136 !important;

    font-size: 32px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}

@media (max-width: 720px) {
    .spz-menu-toggle {
        top: 22px !important;
        right: 20px !important;
        width: 48px !important;
        height: 48px !important;
    }

    .spz-menu-panel {
        top: 16px !important;
        right: 16px !important;
        width: calc(100vw - 32px) !important;
        max-width: none !important;
        max-height: calc(100vh - 32px) !important;
        padding: 24px 22px !important;
        border-radius: 24px !important;
    }
}