/* =====================================================================
   Recherche CdF — Styles
   ===================================================================== */

/* Shortcode [cdf_search] */
.cdf-search {
    --cdf-border: #e0e0e0;
    --cdf-accent: #b22222;
    --cdf-bg:     #fff;
    font-size: 1rem;
}

.cdf-search-form { margin: 0 0 1.25em; }

.cdf-search-bar {
    display: flex;
    gap: .5em;
    margin-bottom: .75em;
}
.cdf-search-q {
    flex: 1;
    padding: .6em .8em;
    border: 1px solid var(--cdf-border);
    border-radius: .25em;
    font-size: 1em;
}
.cdf-search-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35em;
    padding: .6em 1.2em;
    background: var(--cdf-accent);
    color: #fff;
    border: 0;
    border-radius: .25em;
    cursor: pointer;
    font-weight: 600;
    line-height: 1;
}
.cdf-search-submit:hover { filter: brightness(0.9); }
.cdf-search-submit-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    width: 1em;
    height: 1em;
    flex-shrink: 0;
}
svg.cdf-search-submit-icon,
.cdf-search-submit-icon > svg { width: 1em; height: 1em; display: block; fill: currentColor; }

.cdf-facets {
    display: flex;
    flex-wrap: wrap;
    gap: .75em 1.25em;
    padding: .75em 1em;
    border: 1px solid var(--cdf-border);
    border-radius: .25em;
    margin: 0;
}
.cdf-facets legend { font-weight: 600; padding: 0 .4em; }
.cdf-facet { display: flex; flex-direction: column; gap: .25em; }
.cdf-facet label { display: inline-flex; align-items: center; gap: .4em; }
.cdf-facet-label { font-weight: 600; }
.cdf-facet select { padding: .3em .5em; border: 1px solid var(--cdf-border); border-radius: .2em; }

.cdf-facet-type { flex-direction: row; gap: .75em; }
.cdf-facet-type label { font-weight: normal; }

.cdf-search-results.is-loading { opacity: .5; pointer-events: none; }

.cdf-search-summary { margin: 0 0 .75em; color: #666; font-size: .9em; }
.cdf-search-empty   { font-style: italic; color: #666; }

.cdf-search-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: .5em;
}
.cdf-search-item { border: 1px solid var(--cdf-border); border-radius: .3em; }
.cdf-search-link {
    display: flex;
    gap: .8em;
    padding: .7em .8em;
    text-decoration: none;
    color: inherit;
    align-items: flex-start;
}
.cdf-search-link:hover { background: #f8f8f8; }
.cdf-search-thumb {
    width: 64px; height: 64px;
    object-fit: cover;
    border-radius: .2em;
    flex-shrink: 0;
}
.cdf-search-body { display: flex; flex-direction: column; gap: .2em; min-width: 0; }
.cdf-search-type-badge {
    align-self: flex-start;
    background: #eee;
    color: #333;
    font-size: .7em;
    text-transform: uppercase;
    padding: .15em .5em;
    border-radius: .2em;
    letter-spacing: .03em;
}
.cdf-search-item--chant  .cdf-search-type-badge { background: #fef0f0; color: var(--cdf-accent); }
.cdf-search-item--carnet .cdf-search-type-badge { background: #eef6ff; color: #1a5fb4; }
.cdf-search-title   { font-weight: 600; font-size: 1.05em; }
.cdf-search-excerpt { color: #555; font-size: .9em; }

.cdf-search-pagination {
    display: flex;
    justify-content: center;
    gap: 1em;
    align-items: center;
    margin-top: 1em;
}
.cdf-search-pagination a,
.cdf-search-pagination button {
    padding: .4em .8em;
    border: 1px solid var(--cdf-border);
    border-radius: .25em;
    background: #fff;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    font: inherit;
}
.cdf-search-pagination a:hover,
.cdf-search-pagination button:hover { background: #f0f0f0; }
.cdf-search-pageinfo { color: #666; font-size: .9em; }

/* =====================================================================
   Top consultés (.cdf-top-viewed)
   Réutilise .cdf-search-item / .cdf-search-link / .cdf-search-thumb /
   .cdf-search-title pour cohérence visuelle automatique. Seules les
   spécificités du widget sont définies ici.
   ===================================================================== */
.cdf-top-viewed {
    --cdf-rank-bg:    var(--cdf-accent, #b22222);
    --cdf-rank-color: #fff;
}
.cdf-top-viewed-title { margin: 0 0 .75em; }
.cdf-top-viewed-empty { font-style: italic; color: #666; }

/* La liste hérite de .cdf-search-list (display: grid) — on neutralise
   uniquement les styles d'ordonnée pour <ol>. */
.cdf-top-viewed-list { counter-reset: cdf-rank; padding-left: 0; }
ol.cdf-top-viewed-list { list-style: none; }

.cdf-top-viewed-item .cdf-search-link {
    align-items: center; /* badge rang vertical-aligné avec la vignette */
}

.cdf-top-viewed-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2em;
    height: 2em;
    padding: 0 .4em;
    border-radius: 999px;
    background: var(--cdf-rank-bg);
    color: var(--cdf-rank-color);
    font-weight: 700;
    font-size: .9em;
    line-height: 1;
    flex-shrink: 0;
}

.cdf-top-viewed-hits {
    color: #777;
    font-size: .85em;
}

/* =====================================================================
   Header autocomplete (#cdf-header-search)
   ===================================================================== */
.cdf-header-search {
    position: fixed;
    inset: 0 0 auto 0;
    background: rgba(0,0,0,.7);
    z-index: 99999;
    padding: 2em 1em;
}
.cdf-header-search[hidden] { display: none; }
.cdf-header-search-inner {
    max-width: 600px;
    margin: 0 auto;
    background: #fff;
    border-radius: .4em;
    padding: .8em;
    position: relative;
    box-shadow: 0 10px 40px rgba(0,0,0,.25);
}
.cdf-header-search-q {
    width: 100%;
    padding: .7em .9em;
    border: 1px solid var(--cdf-border, #e0e0e0);
    border-radius: .25em;
    font-size: 1.1em;
    box-sizing: border-box;
}
.cdf-header-search-close {
    position: absolute;
    top: .6em; right: .6em;
    border: 0; background: transparent;
    cursor: pointer;
    font-size: 1.3em;
    color: #666;
    padding: .2em .5em;
}
.cdf-header-suggestions {
    list-style: none;
    margin: .5em 0 0;
    padding: 0;
    max-height: 60vh;
    overflow-y: auto;
}
.cdf-header-suggestions li {
    border-top: 1px solid #eee;
}
.cdf-header-suggestions li a {
    display: flex;
    align-items: center;
    gap: .7em;
    padding: .6em .5em;
    text-decoration: none;
    color: inherit;
}
.cdf-header-suggestions li a:hover { background: #f5f5f5; }
.cdf-header-suggestions img {
    width: 40px; height: 40px;
    object-fit: cover; border-radius: .2em;
    flex-shrink: 0;
}
.cdf-suggest-title { flex: 1; font-weight: 500; }
.cdf-suggest-type {
    font-size: .75em;
    text-transform: uppercase;
    color: #999;
    letter-spacing: .05em;
}
.cdf-header-empty {
    padding: 1em .5em;
    font-style: italic;
    color: #666;
    text-align: center;
}
