/**
 * Blog featured imagery: elastic zoom on hover + decorative cursor ring (paired with blog-featured-media.js)
 */

.blog-feature-media {
    position: relative;
    overflow: hidden;
}

.blog-feature-media img {
    transform-origin: center center;
    transition: transform 0.75s cubic-bezier(0.175, 0.885, 0.32, 1.28);
    will-change: transform;
}

.blog-feature-media:hover img,
.blog-feature-media:focus-within img {
    transform: scale(1.11);
}

/* Custom “bouncy” cursor ring (position driven by JS) */
.blog-feature-media-cursor {
    position: absolute;
    left: 0;
    top: 0;
    width: 38px;
    height: 38px;
    margin-left: -19px;
    margin-top: -19px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.92);
    background: radial-gradient(circle, rgba(247, 148, 29, 0.25) 0%, transparent 70%);
    box-shadow:
        0 0 0 1px rgba(247, 148, 29, 0.55),
        0 6px 24px rgba(15, 23, 42, 0.18);
    pointer-events: none;
    z-index: 5;
    opacity: 0;
    will-change: transform;
}

.blog-feature-media.is-media-hover {
    cursor: none;
}

.blog-feature-media.is-media-hover .blog-feature-media-cursor {
    opacity: 1;
    /* Do not animate transform here — JS drives position */
    animation: blog-feature-cursor-pulse 1.35s ease-in-out infinite;
}

@keyframes blog-feature-cursor-pulse {
    0%,
    100% {
        box-shadow:
            0 0 0 1px rgba(247, 148, 29, 0.55),
            0 6px 24px rgba(15, 23, 42, 0.18);
    }
    50% {
        box-shadow:
            0 0 0 10px rgba(247, 148, 29, 0),
            0 8px 28px rgba(15, 23, 42, 0.12);
    }
}

@media (prefers-reduced-motion: reduce) {
    .blog-feature-media img {
        transition: none;
    }

    .blog-feature-media:hover img,
    .blog-feature-media:focus-within img {
        transform: none;
    }

    .blog-feature-media.is-media-hover {
        cursor: default;
    }

    .blog-feature-media-cursor,
    .blog-feature-media.is-media-hover .blog-feature-media-cursor {
        display: none !important;
        animation: none;
    }
}

/* Touch / coarse pointers: zoom only, no cursor ring */
@media (hover: none), (pointer: coarse) {
    .blog-feature-media.is-media-hover {
        cursor: default;
    }

    .blog-feature-media-cursor {
        display: none !important;
    }
}

/* --------------------------------------------------------------------------
   Blog index LISTING thumbnails (must be global: listing view does not load
   the single-post inline <style> in blog/index.php).
   Fixed frame + cover so portrait images never set row height.
   -------------------------------------------------------------------------- */
.blog-featured-list-thumb {
    position: relative;
    background: var(--bs-tertiary-bg, rgba(0, 0, 0, 0.06));
    overflow: hidden;
    padding: 0;
    border-radius: var(--bs-border-radius-xl, 0.75rem) var(--bs-border-radius-xl, 0.75rem) 0 0;
}

@media (min-width: 768px) {
    .blog-featured-list-thumb {
        border-radius: var(--bs-border-radius-xl, 0.75rem) 0 0 var(--bs-border-radius-xl, 0.75rem);
        height: 240px;
        max-height: 240px;
    }
}

@media (max-width: 767.98px) {
    .blog-featured-list-thumb {
        aspect-ratio: 16 / 9;
        min-height: 180px;
        max-height: 280px;
        width: 100%;
    }
}

.blog-featured-list-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

@media (min-width: 768px) {
    .blog-featured-list-thumb img {
        position: absolute;
        inset: 0;
        min-height: 0 !important;
        max-height: none !important;
        width: 100%;
        height: 100%;
    }
}
