/**
 * apb-archive.css — Archive publique + ProCard fallback (namespace .apb-*).
 *
 * v2.29.0 — Migré sur design tokens (apb-tokens.css).
 * Sert de FILET DE SÉCURITÉ : `.fxs-annuaire` (apb-annuaire-mockup.css) est
 * le design system canonique de l'archive depuis v2.2.3. Ces règles
 * `.apb-archive` / `.apb-pro-card` (sans préfixe .fxs-) ne sont actives que
 * sur :
 *   - shortcode `[apb_archive_pros]` rendu hors page `/annuaire/` (rare)
 *   - shortcode `[apb_mes_favoris]` (dashboard visiteur — voir aussi
 *     apb-dashboard-visiteur.css)
 *
 * Garder pour la cohérence rétrocompatible mais le navy/amber est désormais
 * appliqué via les tokens, pas hardcodé.
 */

.apb-archive {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 32px;
    padding: 24px 0;
    font-family: var(--apb-sans, 'Inter', system-ui, sans-serif);
    color: var(--apb-ink, #0F172A);
}
@media (max-width: 900px) {
    .apb-archive { grid-template-columns: 1fr; }
}

.apb-filtres {
    background: var(--apb-surface, #FFFFFF);
    border: 1px solid var(--apb-line, #E7E3D9);
    border-radius: var(--apb-radius-md, 16px);
    padding: 20px;
    position: sticky;
    top: 80px;
    box-shadow: var(--apb-shadow-1);
}
.apb-filtres__title {
    margin: 0 0 12px 0;
    font-family: var(--apb-display, var(--apb-sans));
    color: var(--apb-brand, #0B2A4A);
    font-size: 18px;
    font-weight: 700;
}
.apb-filtres .apb-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 12px;
}
.apb-filtres .apb-field span {
    font-size: 13px;
    color: var(--apb-ink-3, #64748B);
    font-weight: 500;
}
.apb-filtres input,
.apb-filtres select {
    padding: 9px 12px;
    border: 1px solid var(--apb-line, #E7E3D9);
    border-radius: var(--apb-radius-sm, 10px);
    font-size: 14px;
    font-family: inherit;
    background: var(--apb-surface, #FFFFFF);
    color: var(--apb-ink, #0F172A);
    transition: border-color var(--apb-dur-fast, 150ms),
                box-shadow var(--apb-dur-fast, 150ms);
}
.apb-filtres input:focus,
.apb-filtres select:focus {
    outline: none;
    border-color: var(--apb-brand, #0B2A4A);
    box-shadow: 0 0 0 3px rgba(11, 42, 74, 0.08);
}

.apb-archive__header { margin-bottom: 16px; }
.apb-archive__count { margin: 0; color: var(--apb-ink-3, #64748B); }
.apb-archive__empty {
    padding: 40px;
    text-align: center;
    background: var(--apb-bg-soft, #F4F2EC);
    border: 1px dashed var(--apb-line, #E7E3D9);
    border-radius: var(--apb-radius-md, 16px);
    color: var(--apb-ink-3, #64748B);
}

.apb-pro-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
@media (max-width: 1100px) {
    .apb-pro-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .apb-pro-grid { grid-template-columns: 1fr; }
}

.apb-pro-card {
    background: var(--apb-surface, #FFFFFF);
    border: 1px solid var(--apb-line, #E7E3D9);
    border-radius: var(--apb-radius-md, 16px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: transform var(--apb-dur, 220ms) var(--apb-ease-out, ease),
                box-shadow var(--apb-dur, 220ms) var(--apb-ease-out, ease),
                border-color var(--apb-dur-fast, 150ms);
    box-shadow: var(--apb-shadow-1);
}
.apb-pro-card:hover {
    transform: translateY(-3px);
    border-color: var(--apb-brand, #0B2A4A);
    box-shadow: var(--apb-shadow-2);
}
.apb-pro-card__cover {
    display: block;
    aspect-ratio: 16/11;
    overflow: hidden;
    background: var(--apb-bg-soft, #F4F2EC);
}
.apb-pro-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.apb-pro-card__img--placeholder {
    background: linear-gradient(135deg, #F1ECE0 0%, #E7DFD3 100%);
}
.apb-pro-card__body {
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.apb-pro-card__title {
    margin: 0;
    font-family: var(--apb-display, var(--apb-sans));
    font-size: 18px;
    font-weight: 700;
    color: var(--apb-ink, #0F172A);
    letter-spacing: var(--apb-tracking-tight, -0.025em);
}
.apb-pro-card__title a {
    color: inherit;
    text-decoration: none;
}
.apb-pro-card__title a:hover {
    color: var(--apb-brand, #0B2A4A);
}
.apb-pro-card__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.apb-pro-card__meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    color: var(--apb-ink-3, #64748B);
    font-size: 14px;
}
.apb-pro-card__rating {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
}
.apb-rating-stars {
    color: var(--apb-accent, #F59E0B);
    letter-spacing: 2px;
}
.apb-rating-value {
    font-weight: 700;
    color: var(--apb-ink, #0F172A);
}
.apb-rating-count {
    color: var(--apb-ink-3, #64748B);
}
.apb-pro-card__cta {
    margin-top: auto;
}
.apb-pro-card__cta .apb-btn {
    width: 100%;
    text-align: center;
}

.apb-chip {
    display: inline-block;
    padding: 3px 9px;
    border-radius: var(--apb-radius-xs, 6px);
    font-size: 12px;
    background: var(--apb-bg-soft, #F4F2EC);
    color: var(--apb-ink-2, #334155);
    border: 1px solid var(--apb-line, #E7E3D9);
}
.apb-chip--cat {
    background: var(--apb-brand-soft, #EEF2F8);
    color: var(--apb-brand, #0B2A4A);
    border-color: var(--apb-brand-soft-2, #DDE6F1);
}
.apb-chip--vies,
.apb-chip--complet {
    background: var(--apb-ok-soft, #ECFDF5);
    color: var(--apb-ok-2, #065F46);
    border-color: var(--apb-ok-border, #A7F3D0);
}
.apb-chip--super {
    background: var(--apb-brand-soft, #EEF2F8);
    color: var(--apb-brand, #0B2A4A);
    border-color: var(--apb-brand-soft-2, #DDE6F1);
}
.apb-chip--nouveau,
.apb-chip--multi {
    background: var(--apb-bg-soft, #F4F2EC);
    color: var(--apb-ink-2, #334155);
    border-color: var(--apb-line, #E7E3D9);
}

.apb-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 4px 0;
}

.apb-favori-btn {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--apb-ink-3, #64748B);
    font-size: 24px;
    padding: 4px 8px;
    transition: color var(--apb-dur-fast, 150ms),
                transform var(--apb-dur-fast, 150ms);
}
.apb-favori-btn.is-active {
    color: var(--apb-danger, #DC2626);
}
.apb-favori-btn:hover {
    transform: scale(1.1);
}
.apb-favori-btn--floating {
    position: absolute;
    top: 12px;
    right: 12px;
    background: rgba(255, 255, 255, 0.92);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
    box-shadow: 0 2px 8px rgba(11, 42, 74, 0.08);
}

.apb-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 18px;
    border-radius: var(--apb-radius-sm, 10px);
    border: none;
    cursor: pointer;
    font-family: inherit;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    transition: background var(--apb-dur-fast, 150ms),
                transform var(--apb-dur-fast, 150ms),
                box-shadow var(--apb-dur, 220ms);
}
.apb-btn--primary {
    background: var(--apb-brand, #0B2A4A);
    color: var(--apb-ink-on-brand, #FFFFFF);
}
.apb-btn--primary:hover {
    background: var(--apb-brand-2, #143D69);
    color: var(--apb-ink-on-brand, #FFFFFF);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(11, 42, 74, 0.18);
}
.apb-btn--ghost {
    background: transparent;
    color: var(--apb-brand, #0B2A4A);
    border: 1px solid var(--apb-line, #E7E3D9);
}
.apb-btn--ghost:hover {
    background: var(--apb-bg-soft, #F4F2EC);
    border-color: var(--apb-brand, #0B2A4A);
}

.apb-pagination {
    display: flex;
    gap: 6px;
    justify-content: center;
    margin-top: 32px;
    flex-wrap: wrap;
}
.apb-pagination__link {
    padding: 8px 14px;
    border-radius: var(--apb-radius-sm, 10px);
    background: var(--apb-surface, #FFFFFF);
    color: var(--apb-ink-2, #334155);
    border: 1px solid var(--apb-line, #E7E3D9);
    text-decoration: none;
    font-size: 14px;
    transition: border-color var(--apb-dur-fast, 150ms),
                color var(--apb-dur-fast, 150ms);
}
.apb-pagination__link:hover {
    border-color: var(--apb-brand, #0B2A4A);
    color: var(--apb-brand, #0B2A4A);
}
.apb-pagination__link.is-active {
    background: var(--apb-brand, #0B2A4A);
    color: var(--apb-ink-on-brand, #FFFFFF);
    border-color: var(--apb-brand, #0B2A4A);
}
