/* ================================
   Scrolling Banner
   ================================ */

.scrolling-banner {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: 5px var(--wp--preset--spacing--page-margin, 1rem);
    touch-action: pan-x;
}

.scrolling-track {
    display: flex;
    width: max-content;
    will-change: transform;
    gap: var(--wp--preset--spacing--gutter, 1.5rem);
    backface-visibility: hidden;
    transform: translateZ(0);
}

/* Animate only on frontend */
body:not(.block-editor-page) .scrolling-track.is-animating {
    animation-name: scroll;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
}

/* Scrolling content wrapper */
.scrolling-content {
    display: flex;
}

.acf-innerblocks-container {
    display: flex;
    align-items: center;
    gap: var(--wp--preset--spacing--gutter, 1.5rem);
}

.acf-innerblocks-container>* {
    flex-shrink: 0;
}

/* Paragraphs inside scrolling banner */
.scrolling-banner .acf-innerblocks-container>p {
    color: var(--wp--preset--color--white);
    font-size: clamp(28px, 5vw, 50px);
    font-style: normal;
    margin: 0;
}

/* Odd paragraph blocks */
.scrolling-banner .acf-innerblocks-container>p:nth-of-type(odd) {
    font-family: var(--wp--preset--font-family--case, sans-serif);
    font-weight: 500;
}

/* Even paragraph blocks */
.scrolling-banner .acf-innerblocks-container>p:nth-of-type(even) {
    font-family: var(--wp--preset--font-family--ivy-presto-display, serif);
    font-weight: 300;
}

/* Images */
.scrolling-banner .wp-block-image {
    margin: 0;
}

.scrolling-banner .wp-block-image img {
    display: block;
    height: auto;
    max-height: 62px;
    width: auto;
}

/* Backend scrollbar for editor only */
body.block-editor-page .scrolling-track-wrapper {
    overflow-x: auto;
    display: block;
    width: 100%;
    padding-bottom: 12px;
}

body.block-editor-page .scrolling-track {
    display: inline-flex;
    width: max-content;
    flex-wrap: nowrap;
}

body.block-editor-page .scrolling-track-wrapper::-webkit-scrollbar {
    height: 12px;
}

body.block-editor-page .scrolling-track-wrapper::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.3);
    border-radius: 6px;
}

body.block-editor-page .scrolling-track-wrapper::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.05);
}

/* Frontend keyframes */
@keyframes scroll {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

/* Hover pause — only when not manually paused via the button */
.scrolling-banner:not(.is-manually-paused):hover .scrolling-track {
    animation-play-state: paused;
}

/* ── Pause / Play button ──────────────────────────────────────────────────── */

.scrolling-banner__pause-btn {
    position: absolute;
    bottom: 8px;
    right: 8px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    background: rgba(0, 0, 0, 0.55);
    border: 2px solid rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    cursor: pointer;
    color: #fff;
    transition: background 0.2s ease;
}

.scrolling-banner__pause-btn:hover {
    background: rgba(0, 0, 0, 0.8);
}

.scrolling-banner__pause-btn:focus-visible {
    outline: 3px solid #fff;
    outline-offset: 3px;
}

.scrolling-banner__pause-btn:focus:not(:focus-visible) {
    outline: none;
}

.scrolling-banner__pause-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.scrolling-banner__pause-icon svg {
    fill: currentColor;
}

/* Show play icon only when paused */
.scrolling-banner__pause-btn .icon-play {
    display: none;
}

.scrolling-banner__pause-btn[aria-pressed="true"] .icon-pause {
    display: none;
}

.scrolling-banner__pause-btn[aria-pressed="true"] .icon-play {
    display: block;
}

@media (prefers-reduced-motion: reduce) {
    .scrolling-banner__pause-btn {
        display: none;
    }
}

@media (forced-colors: active) {
    .scrolling-banner__pause-btn {
        border: 2px solid ButtonText;
        color: ButtonText;
        background: ButtonFace;
        forced-color-adjust: none;
    }

    .scrolling-banner__pause-btn:focus-visible {
        outline: 3px solid Highlight;
        outline-offset: 3px;
    }
}

/* Accessibility: reduced motion */
@media (prefers-reduced-motion: reduce) {
    .scrolling-track {
        animation: none !important;
        transform: none !important;
    }
}

/* Divider styling */
.scrolling-banner .divider {
    width: 3px;
    height: 62px;
    background-color: var(--wp--preset--color--white);
}

@media (max-width: 600px) {
    .scrolling-banner .divider {
        width: 1.6px;
        height: 35px;
    }
}
