/* ===================================
   Template — hidden source block used
   by JS to clone card markup.
   =================================== */
.woa-character-template {
    display: none !important;
}

/* ===================================
   Character Gallery Grid
   =================================== */
.woa-character-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 330px;   /* every row — and every card — is exactly this tall */
    gap: 2.0rem;           /* tight gap — cards nearly edge-to-edge was 0.375rem*/
    max-width: 1264px;
    margin: 0 auto;
    padding: 0;
    align-items: stretch;
}

.woa-character-card {
    cursor: pointer;
    width: 100%;
    height: 100%;            /* fill the fixed row height */
    overflow: hidden;
}

/* Inner card: JS clone wrapper + WP group both fill the card height */
.woa-character-card > div,
.woa-character-card > div > .wp-block-group {
    height: 100% !important;
    min-height: unset !important;
    box-sizing: border-box;
}

/* Card body: Dahlia White background, flex column — stretch so children fill full width */
.woa-character-card > div,
.woa-character-card > div > .wp-block-group {
    width: 100% !important;
}

.woa-character-card > div > .wp-block-group {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;   /* children fill full card width */
    padding: 0 !important;             /* cancel has-global-padding */
    background: var(--wp--preset--color--base) !important;   /* Dahlia White */
}

/* Image figure: lavender background, expands to fill available space.
   max-width: none overrides WP constrained layout's contentSize: 200px rule. */
.woa-character-card .woa-character-image-placeholder {
    flex: 1 1 0 !important;
    align-self: stretch !important;
    overflow: hidden !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: none !important;        /* override WP constrained-layout max-width */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--wp--preset--color--base-2) !important; /* Shocking Lavender */
}

.woa-character-card .woa-character-image-placeholder img {
    /* Override the block's inline width/height (150px) */
    width: calc(100% - 1.5rem) !important;
    height: calc(100% - 1.5rem) !important;
    object-fit: contain !important;    /* show full character — no cropping */
    display: block !important;
    margin: 0.75rem auto !important;   /* breathing room around the artwork */
    box-sizing: border-box !important;
}

/* Name: Dahlia White section at the bottom */
.woa-character-card .woa-character-name-placeholder {
    flex: 0 0 auto !important;
    width: 100% !important;
    background: transparent !important;           /* inherits Dahlia White from group */
    color: var(--wp--preset--color--contrast) !important;
    text-align: center !important;
    padding: 0.5rem 0.25rem !important;
    margin: 0 !important;
    font-size: 1.5rem !important;                   /* override has-large-font-size */
    font-weight: 600 !important;
    line-height: 1.3 !important;
    box-sizing: border-box !important;
}

/* ===================================
   Character Card Hover
   =================================== */
.woa-character-card figure {
    overflow: hidden;
    transition: transform 0.2s ease;
}

.woa-character-card:hover figure,
.woa-character-card:hover img {
    transform: scale(1.05);
    transition: transform 0.2s ease;
}

@media (prefers-reduced-motion: reduce) {
    .woa-character-card figure,
    .woa-character-card:hover figure,
    .woa-character-card:hover img {
        transform: none;
        transition: none;
    }
}

/* ===================================
   Modal Image
   Image tag receives this class via
   get_the_post_thumbnail() in PHP.
   =================================== */
.woa-character-modal-img {
    width: 100%;
    height: auto;
    display: block;
}

/* ===================================
   Responsive — tighter grid on mobile
   =================================== */
@media (max-width: 600px) {
    .woa-character-gallery {
        grid-template-columns: repeat(2, 1fr);
        grid-auto-rows: 280px;
    }
}

/* ── Character Carousel ────────────────────────────────────── */
.woa-character-carousel {
    display: flex;
    gap: var(--woa-gap, 2.5rem);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 0 var(--wp--preset--spacing--30, 1rem);
}
.woa-character-carousel::-webkit-scrollbar { display: none; }

.woa-character-carousel .woa-carousel-slide {
    flex: 0 0 var(--woa-slide-w, calc(25% - 1.875rem));
    scroll-snap-align: start;
    cursor: pointer;
    text-align: center;
    transition: transform 0.2s ease;
}
.woa-character-carousel .woa-carousel-slide:hover {
    transform: scale(1.05);
}

.woa-carousel-figure {
    margin: 0;
    line-height: 0;
}
.woa-character-carousel .woa-carousel-figure img {
    width: 100%;
    max-width: 180px;
    height: auto;
    object-fit: cover;
    margin: 0 auto;
    display: block;
}
/* Circular frame — opt-in via woa-circular class */
.woa-character-card.woa-circular .woa-carousel-figure img {
    border-radius: 50%;
    aspect-ratio: 1;
}

.woa-carousel-label {
    margin: 0.75rem 0 0;
    font-weight: 600;
    font-size: var(--wp--preset--font-size--small, 0.9rem);
    line-height: 1.3;
}

/* ── Autoscroll — shared keyframe for any woa-carousel ────── */
@keyframes woa-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.woa-character-carousel.is-scrolling {
    overflow: hidden;
    justify-content: flex-start;
}
.woa-character-carousel.is-scrolling .woa-scroll-track {
    display: flex;
    gap: var(--woa-gap-scroll, 1.5rem);
    animation: woa-scroll var(--woa-speed, 30s) linear infinite;
    will-change: transform;
}
.woa-character-carousel.is-scrolling .woa-scroll-track:hover {
    animation-play-state: paused;
}
.woa-character-carousel.is-scrolling .woa-carousel-slide {
    flex: none;
    width: var(--woa-slide-w-vw, calc(25vw - 1.875rem));
}

@media (max-width: 768px) {
    .woa-character-carousel .woa-carousel-slide {
        flex: 0 0 calc(50% - 1.25rem);
    }
    .woa-character-carousel.is-scrolling .woa-carousel-slide {
        width: calc((100vw - 5.5rem) / 2) !important;
    }
}
@media (max-width: 480px) {
    .woa-character-carousel {
        gap: 1.5rem;
    }
}
