/* =========================================================
   Transaction Grid — dc26-dimension
   ========================================================= */

/* =========================================================
   Filters & Facets
   ========================================================= */

.dc26-transaction-grid__filters {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--wp--preset--spacing--40);
    margin-block-end: var(--wp--preset--spacing--60);
}

/* Pills — facet slug: tags_pills (domaines) */
.dc26-transaction-grid .facetwp-facet-tags_pills {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 0;
}

.dc26-transaction-grid .facetwp-facet-tags_pills .facetwp-radio {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 1.1rem;
    border-radius: var(--facet-radius-pill);
    border: 1px solid var(--wp--preset--color--gray-light);
    color: var(--facet-color-primary);
    background: var(--wp--preset--color--white);
    font-size: var(--facet-font-size);
    font-weight: 600;
    cursor: pointer;
    margin-bottom: 0;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.dc26-transaction-grid .facetwp-facet-tags_pills .facetwp-radio:hover {
    border-color: var(--facet-color-primary);
}

.dc26-transaction-grid .facetwp-facet-tags_pills .facetwp-radio.checked {
    background: var(--facet-color-primary);
    color: var(--facet-color-bg);
    border-color: var(--facet-color-primary);
}

/* Grid */
.dc26-transaction-grid__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--wp--preset--spacing--50);
}

@media (max-width: 1024px) {
    .dc26-transaction-grid__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .dc26-transaction-grid__grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   Card — overlay design
   ========================================================= */

.dc26-transaction-card {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--wp--preset--color--primary);

    /* Animation — activée uniquement quand JS ajoute data-anim sur le grid */
}

/* Scroll-reveal — JS pose data-anim sur le grid, puis is-visible sur chaque carte */
.dc26-transaction-grid__grid[data-anim] .dc26-transaction-card {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.45s ease, transform 0.45s ease;
}

.dc26-transaction-grid__grid[data-anim] .dc26-transaction-card.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Image — full bleed background */
.dc26-transaction-card__image {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.dc26-transaction-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.65s cubic-bezier(0.4, 0, 0.2, 1);
}

.dc26-transaction-card:hover .dc26-transaction-card__image img {
    transform: scale(1.07);
}

/* Gradient overlay — renforcer sur hover */
.dc26-transaction-card::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        to bottom,
        rgba(24, 46, 78, 0.1) 0%,
        rgba(24, 46, 78, 0.35) 45%,
        rgba(24, 46, 78, 0.88) 100%
    );
    transition: opacity 0.4s ease;
}

.dc26-transaction-card:hover::before {
    opacity: 1.0;
    background: linear-gradient(
        to bottom,
        rgba(24, 46, 78, 0.2) 0%,
        rgba(24, 46, 78, 0.55) 35%,
        rgba(24, 46, 78, 0.96) 100%
    );
}

/* Header — compétence top-left */
.dc26-transaction-card__header {
    position: absolute;
    top: 1rem;
    left: 1rem;
    z-index: 2;
}

/* Body — collé en bas */
.dc26-transaction-card__body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
    padding: 1.25rem;
}

/* Tags */
.dc26-transaction-card__tags {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

.dc26-transaction-card__tags li {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    line-height: 1.5;
    padding: 0.18rem 0.6rem;
    border-radius: var(--facet-radius-pill, 9999px);
}

.dc26-transaction-card__tags--competence li {
    background: var(--wp--preset--color--secondary);
    color: var(--wp--preset--color--white);
}

.dc26-transaction-card__tags--domaine {
    margin-top: 0.45rem;
}

.dc26-transaction-card__tags--domaine li {
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.35);
}

/* Excerpt — masqué, reveal sur hover */
.dc26-transaction-card__excerpt {
    font-size: 0.8rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.82);
    margin: 0 0 0.65rem;

    max-height: 0;
    overflow: hidden;
    opacity: 0;

    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;

    transition:
        max-height 0.42s cubic-bezier(0.4, 0, 0.2, 1),
        opacity    0.32s ease 0.08s,
        margin-bottom 0.32s ease;
}

.dc26-transaction-card:hover .dc26-transaction-card__excerpt {
    max-height: 6rem;
    opacity: 1;
}

/* Title */
.dc26-transaction-card__title {
    font-size: var(--wp--preset--font-size--medium);
    font-weight: 700;
    line-height: 1.25;
    color: var(--wp--preset--color--white);
    margin: 0;
}

.dc26-transaction-card__title a {
    color: inherit;
    text-decoration: none;
}

/* Overlay — couvre toute la carte (image incluse), direct enfant de l'article */
.dc26-transaction-card__overlay {
    position: absolute;
    inset: 0;
    z-index: 3;
}

/* Arrow — au-dessus de l'overlay, pointer-events none (décoratif) */
.dc26-transaction-card__arrow {
    position: absolute;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 4;
    color: var(--wp--preset--color--secondary);
    font-size: 1.1rem;
    line-height: 1;
    pointer-events: none;

    opacity: 0;
    transform: translate(-4px, 4px);
    transition:
        opacity 0.3s ease 0.1s,
        transform 0.3s ease 0.1s;
}

.dc26-transaction-card:hover .dc26-transaction-card__arrow {
    opacity: 1;
    transform: translate(0, 0);
}

/* Empty state */
.dc26-transaction-grid__empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem;
    color: var(--wp--preset--color--gray);
    font-size: var(--wp--preset--font-size--medium);
}

/* =========================================================
   Load More
   ========================================================= */

.dc26-transaction-grid__load-more {
    margin-block-start: var(--wp--preset--spacing--60);
    text-align: center;
}

/* Load more — facet slug: more (pager type) */
.dc26-transaction-grid__load-more .facetwp-facet-more {
    display: flex;
    justify-content: center;
}

.dc26-transaction-grid__load-more .fwp-load-more {
    display: inline-block;
    padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--60);
    background: var(--wp--preset--color--primary);
    color: var(--wp--preset--color--white);
    border: 2px solid var(--wp--preset--color--primary);
    border-radius: 0;
    font-size: var(--wp--preset--font-size--small);
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
}

.dc26-transaction-grid__load-more .fwp-load-more:hover {
    background: transparent;
    color: var(--wp--preset--color--primary);
}

.dc26-transaction-grid__load-more .fwp-load-more[style*="display: none"],
.dc26-transaction-grid__load-more .facetwp-facet-more:empty {
    display: none;
}

/* Spinner pendant le chargement FacetWP */
.dc26-transaction-grid[data-facetwp-loading] .dc26-transaction-grid__grid {
    opacity: 0.5;
    pointer-events: none;
    transition: opacity 0.2s ease;
}
