/* WP Directory Pro — Front CSS v3 */
:root{--jann-color:#1d4ed8;--jann-light:#1d4ed818;}
.jann *{box-sizing:border-box;margin:0;padding:0;}
.jann{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#1e293b;width:100%;}

/* ── Barre recherche ───────────────────────────────────── */
.jann-bar{margin-bottom:20px;display:flex;flex-direction:column;gap:12px;}
.jann-search-row{display:flex;gap:8px;flex-wrap:wrap;}
.jann-input{flex:1;min-width:160px;height:40px;padding:0 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.88rem;background:#fff;outline:none;transition:border-color .2s;}
.jann-input:focus{border-color:var(--jann-color);box-shadow:0 0 0 3px var(--jann-light);}
.jann-btn-primary{height:40px;padding:0 18px;background:var(--jann-color);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.85rem;cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.jann-btn-primary:hover{opacity:.88;}
.jann-btn-ghost{height:40px;padding:0 14px;background:transparent;color:#64748b;border:1.5px solid #e2e8f0;border-radius:10px;text-decoration:none;font-size:.82rem;display:inline-flex;align-items:center;white-space:nowrap;}
.jann-btn-ghost:hover{border-color:#94a3b8;color:#334155;}

/* ── Filtres ───────────────────────────────────────────── */
.jann-filters-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.jann-tabs{display:flex;gap:4px;flex-wrap:wrap;}
.jann-tab{display:inline-flex;align-items:center;gap:5px;height:32px;padding:0 12px;border-radius:8px;text-decoration:none;font-size:.8rem;font-weight:500;color:#64748b;background:#f8fafc;border:1.5px solid #e2e8f0;transition:all .15s;}
.jann-tab:hover{background:#f1f5f9;color:#1e293b;}
.jann-tab.active{background:var(--jann-color);color:#fff;border-color:var(--jann-color);}
.jann-tab span{font-size:.72rem;background:rgba(255,255,255,.25);padding:1px 6px;border-radius:10px;}
.jann-tab:not(.active) span{background:#e2e8f0;color:#94a3b8;}
.jann-switcher{display:flex;gap:2px;background:#f1f5f9;border-radius:8px;padding:3px;}
.jann-sw{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:6px;text-decoration:none;color:#94a3b8;transition:all .15s;}
.jann-sw.active{background:#fff;color:var(--jann-color);box-shadow:0 1px 4px rgba(0,0,0,.1);}
.jann-count{font-size:.78rem;color:#94a3b8;margin-bottom:14px;}

/* ── Badge catégorie ───────────────────────────────────── */
.jann-badge{
    display:inline-block;
    background:var(--jann-color);
    color:#fff;
    font-size:.68rem;
    font-weight:700;
    padding:3px 10px;
    border-radius:20px;
    letter-spacing:.02em;
    white-space:nowrap;
}

/* ── GRILLE ────────────────────────────────────────────── */
.jann-grille{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.jann-grille .jann-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s;}
.jann-grille .jann-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);transform:translateY(-3px);}

/* Image */
.jann-grille .jann-card-img{display:block;height:180px;overflow:hidden;background:#f8fafc;flex-shrink:0;}
.jann-grille .jann-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s;display:block;}
.jann-grille .jann-card:hover .jann-card-img img{transform:scale(1.04);}
.jann-grille .jann-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--jann-light),#e0e7ff);}
.jann-grille .jann-img-placeholder span{font-size:2.8rem;font-weight:800;color:var(--jann-color);opacity:.5;}

/* Corps */
.jann-grille .jann-card-body{padding:16px;display:flex;flex-direction:column;flex:1;gap:10px;}

/* Badge — inline, pas pleine largeur */
.jann-grille .jann-badge{align-self:flex-start;display:inline-block;}

.jann-grille .jann-card-title{font-size:1rem;font-weight:700;line-height:1.35;}
.jann-grille .jann-card-title a{color:#1e293b;text-decoration:none;}
.jann-grille .jann-card-title a:hover{color:var(--jann-color);}
.jann-grille .jann-card-desc{font-size:.82rem;color:#64748b;line-height:1.6;}

.jann-grille .jann-card-meta{list-style:none;display:flex;flex-direction:column;gap:6px;flex:1;}
.jann-grille .jann-card-meta li{display:flex;align-items:flex-start;gap:7px;font-size:.81rem;color:#475569;}
.jann-grille .jann-card-meta li span{width:18px;text-align:center;flex-shrink:0;font-size:.88rem;margin-top:1px;}
.jann-grille .jann-card-meta li a{color:var(--jann-color);text-decoration:none;}
.jann-grille .jann-card-meta li a:hover{text-decoration:underline;}

.jann-grille .jann-card-tags{display:flex;gap:5px;flex-wrap:wrap;}
.jann-grille .jann-card-tags span{font-size:.72rem;background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;padding:2px 8px;border-radius:8px;}

/* Actions collées en bas */
.jann-grille .jann-card-actions{
    display:flex;align-items:center;justify-content:flex-end;
    padding:12px 16px;
    border-top:1px solid #f1f5f9;
    gap:6px;
    margin-top:auto;
    background:#fafbfd;
}
.jann-grille .jann-social{display:flex;gap:4px;margin-right:auto;}
.jann-grille .jann-social a{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:7px;text-decoration:none;font-size:.82rem;color:#64748b;transition:all .15s;}
.jann-grille .jann-social a:hover{background:var(--jann-light);color:var(--jann-color);}

.jann-btns{display:flex;gap:6px;align-items:center;}
.jann-btn-voir{display:inline-flex;align-items:center;height:32px;padding:0 14px;background:var(--jann-color);color:#fff;border-radius:8px;text-decoration:none;font-size:.8rem;font-weight:600;transition:opacity .15s;white-space:nowrap;}
.jann-btn-voir:hover{opacity:.85;}
.jann-btn-contact{display:inline-flex;align-items:center;height:32px;padding:0 14px;background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;border-radius:8px;text-decoration:none;font-size:.8rem;font-weight:600;transition:all .15s;white-space:nowrap;}
.jann-btn-contact:hover{background:#dcfce7;}

/* ── LISTE ──────────────────────────────────────────────── */
.jann-liste{display:flex;flex-direction:column;gap:12px;}

.jann-liste .jann-card{
    background:#fff;
    border:1.5px solid #e2e8f0;
    border-radius:14px;
    overflow:hidden;
    display:grid;
    grid-template-columns:180px 1fr auto;
    grid-template-rows:1fr;
    min-height:140px;
    transition:box-shadow .2s,border-color .2s;
}
.jann-liste .jann-card:hover{
    box-shadow:0 6px 24px rgba(0,0,0,.09);
    border-color:#bfdbfe;
}

/* Colonne 1 : photo pleine hauteur */
.jann-liste .jann-card-img{
    grid-column:1;
    grid-row:1;
    display:block;
    overflow:hidden;
    background:#f1f5f9;
    position:relative;
}
.jann-liste .jann-card-img img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    display:block;
}
.jann-liste .jann-img-placeholder{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,var(--jann-light),#e0e7ff);
}
.jann-liste .jann-img-placeholder span{
    font-size:2.4rem;font-weight:800;
    color:var(--jann-color);opacity:.35;
    text-transform:uppercase;
}

/* Colonne 2 : infos */
.jann-liste .jann-card-body{
    grid-column:2;
    grid-row:1;
    padding:18px 22px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:7px;
    min-width:0;
    border-left:1px solid #f1f5f9;
}
.jann-liste .jann-badge{
    align-self:flex-start;
    font-size:.67rem;
    padding:3px 10px;
}
.jann-liste .jann-card-title{
    font-size:1.05rem;
    font-weight:700;
    line-height:1.3;
}
.jann-liste .jann-card-title a{color:#0f172a;text-decoration:none;}
.jann-liste .jann-card-title a:hover{color:var(--jann-color);}
.jann-liste .jann-card-desc{display:none;}
.jann-liste .jann-card-tags{display:none;}
.jann-liste .jann-card-meta{
    list-style:none;
    display:flex;
    flex-direction:row;
    flex-wrap:wrap;
    gap:5px 20px;
}
.jann-liste .jann-card-meta li{
    display:flex;align-items:center;gap:5px;
    font-size:.82rem;color:#475569;
    padding:0;
}
.jann-liste .jann-card-meta li span{width:auto;font-size:.88rem;}
.jann-liste .jann-card-meta li a{color:var(--jann-color);text-decoration:none;}
.jann-liste .jann-card-meta li a:hover{text-decoration:underline;}

/* Colonne 3 : boutons */
.jann-liste .jann-card-actions{
    grid-column:3;
    grid-row:1;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:center;
    gap:8px;
    padding:18px 20px;
    border-left:1px solid #f1f5f9;
    background:#f8fafc;
    flex-shrink:0;
    min-width:130px;
    border-top:none;
}
.jann-liste .jann-social{display:none;}
.jann-liste .jann-btns{
    display:flex;flex-direction:column;gap:7px;
    align-items:stretch;width:100%;
}
.jann-liste .jann-btn-voir{
    height:36px;font-size:.82rem;
    padding:0 14px;justify-content:center;
    width:100%;
}
.jann-liste .jann-btn-contact{
    height:36px;font-size:.82rem;
    padding:0 14px;justify-content:center;
    width:100%;
}

/* ── Vide ──────────────────────────────────────────────── */
.jann-empty{text-align:center;padding:48px 20px;}
.jann-empty-icon{font-size:2.5rem;margin-bottom:10px;}
.jann-empty p{color:#94a3b8;font-size:.9rem;margin-bottom:14px;}

/* ── Pagination ────────────────────────────────────────── */
.jann-pagination{display:flex;gap:4px;justify-content:center;margin-top:24px;flex-wrap:wrap;}
.jann-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid #e2e8f0;border-radius:9px;text-decoration:none;color:#475569;font-size:.85rem;transition:all .15s;}
.jann-pagination .page-numbers.current{background:var(--jann-color);color:#fff;border-color:var(--jann-color);}
.jann-pagination .page-numbers.dots{border:none;width:auto;}

/* ── Responsive ────────────────────────────────────────── */
@media(max-width:700px){
    .jann-grille{grid-template-columns:repeat(2,1fr);}
    .jann-liste .jann-card{grid-template-columns:100px 1fr;min-height:110px;}
    .jann-liste .jann-card-actions{display:none;}
    .jann-liste .jann-card-body{padding:12px 14px;gap:5px;}
    .jann-liste .jann-card-title{font-size:.9rem;}
    .jann-liste .jann-card-meta li{font-size:.76rem;}
}
@media(max-width:400px){
    .jann-grille{grid-template-columns:1fr;}
}
