/* AFEBAS Galeries V12 — front.css */
:root {
    --afg-blue:    #003153;
    --afg-blue2:   #0b2a5b;
    --afg-yellow:  #F5C518;
    --afg-text:    #1a1a2e;
    --afg-muted:   #667085;
    --afg-border:  #e6e8eb;
    --afg-radius:  12px;
    --afg-shadow:  0 4px 16px rgba(9,30,66,.09);
    --afg-card-h:  220px;
}

/* ============================================================
   BASE
   ============================================================ */
.afg-browser,.afg-single-wrap { margin:1.5rem 0; font-family:inherit; }
.afg-empty     { padding:20px; border:1px dashed #c8cdd5; border-radius:var(--afg-radius); color:var(--afg-muted); text-align:center; margin:12px 0; }
.afg-gallery-title { font-size:1.6rem; font-weight:900; color:var(--afg-blue); border-bottom:3px solid var(--afg-yellow); padding-bottom:.4rem; display:inline-block; margin-bottom:1rem; }
.afg-section-title { font-size:1rem; font-weight:700; color:var(--afg-blue); border-left:4px solid var(--afg-yellow); padding-left:10px; margin:24px 0 12px; }
.afg-ok        { color:#166534; font-weight:600; }

/* ============================================================
   NAVIGATION / BREADCRUMB (hérité + amélioré)
   ============================================================ */
.afg60-folder-nav { display:flex; flex-wrap:wrap; align-items:center; gap:8px; padding:10px 0; margin-bottom:10px; font-size:.9rem; }
.afg60-folder-nav-btn { display:inline-flex; align-items:center; padding:.45rem 1rem; background:var(--afg-blue2); color:#fff !important; border-radius:999px; text-decoration:none !important; font-weight:600; font-size:.85rem; transition:background .15s; }
.afg60-folder-nav-btn:hover { background:var(--afg-blue); }
.afg60-folder-breadcrumb { display:flex; flex-wrap:wrap; align-items:center; gap:3px; font-size:.88rem; }
.afg60-folder-separator { color:#bbb; margin:0 2px; }
.afg60-folder-crumb     { color:var(--afg-blue); text-decoration:none; }
.afg60-folder-crumb:hover { text-decoration:underline; }
.afg60-folder-current   { font-weight:700; color:var(--afg-text); }

/* ============================================================
   NAVIGATION PHOTO PREV / NEXT
   ============================================================ */
.afg-photo-nav { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:16px; }
.afg-photo-nav-bottom { margin-top:16px; margin-bottom:0; }
.afg-nav-btn {
    display:inline-flex; align-items:center; gap:6px;
    padding:.5rem 1.2rem; border-radius:999px;
    background:var(--afg-blue2); color:#fff !important;
    text-decoration:none !important; font-weight:700; font-size:.9rem;
    transition:background .15s,transform .1s;
    box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.afg-nav-btn:hover { background:var(--afg-yellow); color:var(--afg-blue) !important; transform:translateY(-1px); }
.afg-nav-back      { background:#475467; }
.afg-nav-back:hover{ background:#344054; color:#fff !important; }

/* ============================================================
   GRILLE DOSSIERS
   ============================================================ */
.afg-folder-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:20px; margin-bottom:24px; }
.afg-folder-card { border-radius:var(--afg-radius); overflow:hidden; background:#fff; box-shadow:var(--afg-shadow); transition:transform .2s,box-shadow .2s; }
.afg-folder-card:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(9,30,66,.14); }
.afg-folder-cover-link { display:block; position:relative; overflow:hidden; aspect-ratio:4/3; background:#eef3f8; text-decoration:none !important; }
.afg-folder-cover-img { width:100%; height:100%; object-fit:cover; transition:transform .35s; display:block; }
.afg-folder-card:hover .afg-folder-cover-img { transform:scale(1.06); }
.afg-folder-cover-empty { display:flex; align-items:center; justify-content:center; width:100%; height:100%; min-height:160px; background:linear-gradient(135deg,#dfe9f6,#e8f0fa); color:var(--afg-blue); font-weight:900; letter-spacing:1px; }

/* Badge compteur photos */
.afg-folder-badge {
    position:absolute; bottom:10px; right:10px;
    background:var(--afg-yellow); color:var(--afg-blue);
    font-size:.78rem; font-weight:900;
    padding:5px 11px; border-radius:999px;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
    letter-spacing:.01em;
}
.afg-folder-body   { padding:12px 14px; }
.afg-folder-body h3{ margin:0 0 4px; font-size:.95rem; }
.afg-folder-body a { color:var(--afg-text); text-decoration:none; }
.afg-folder-body a:hover { color:var(--afg-blue); }
.afg-folder-dep    { font-size:.82rem; color:var(--afg-muted); }

/* Hero dossier */
.afg-folder-hero { display:grid; grid-template-columns:260px 1fr; gap:24px; align-items:center; margin-bottom:24px; background:#fff; border-radius:var(--afg-radius); padding:20px; box-shadow:var(--afg-shadow); }
.afg-folder-hero-img { border-radius:10px; overflow:hidden; aspect-ratio:4/3; }
.afg-folder-hero-img img { width:100%; height:100%; object-fit:cover; display:block; }
.afg-folder-hero-meta h2 { margin:0 0 6px; color:var(--afg-blue); font-size:1.5rem; }
.afg-folder-path  { font-size:.85rem; color:var(--afg-muted); margin:0 0 4px; }
.afg-folder-dep   { font-size:.85rem; color:var(--afg-muted); margin:0 0 8px; }
.afg-folder-count { font-size:1.15rem; font-weight:800; color:var(--afg-blue); margin:0; }

/* ============================================================
   FILTRES PUBLICS (année / lieu / tri)
   ============================================================ */
.afg-filters-bar { display:flex; flex-wrap:wrap; gap:10px; padding:12px 14px; background:#f3f5f8; border-radius:10px; margin-bottom:18px; align-items:center; }
.afg-filter-group { display:flex; flex-wrap:wrap; align-items:center; gap:5px; }
.afg-sort-group   { margin-left:auto; }
.afg-filter-label { font-size:.83rem; font-weight:700; color:var(--afg-blue); margin-right:2px; }
.afg-filter-btn   { display:inline-block; padding:.3rem .75rem; border-radius:999px; border:1px solid var(--afg-border); background:#fff; color:var(--afg-text); text-decoration:none; font-size:.83rem; transition:all .15s; white-space:nowrap; }
.afg-filter-btn:hover { border-color:var(--afg-blue); color:var(--afg-blue); }
.afg-filter-btn.active { background:var(--afg-blue); color:#fff; border-color:var(--afg-blue); }

/* ============================================================
   GRILLE PHOTOS
   ============================================================ */
.afg-photo-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px; margin-bottom:22px; }
.afg-photo-card { border-radius:var(--afg-radius); overflow:hidden; background:#fff; box-shadow:var(--afg-shadow); transition:transform .2s,box-shadow .2s; }
.afg-photo-card:hover { transform:translateY(-3px); box-shadow:0 10px 28px rgba(9,30,66,.13); }
.afg-photo-link { display:block; position:relative; overflow:hidden; aspect-ratio:4/3; background:#f0f2f5; text-decoration:none !important; }
.afg-photo-link img { width:100%; height:100%; object-fit:cover; transition:transform .3s; display:block; }
.afg-photo-card:hover .afg-photo-link img { transform:scale(1.05); }
.afg-photo-empty { display:flex; align-items:center; justify-content:center; width:100%; height:100%; min-height:140px; color:#aaa; font-style:italic; }

/* Overlay métadonnées au survol */
.afg-photo-overlay {
    position:absolute; left:0; right:0; bottom:0;
    background:linear-gradient(to top, rgba(7,27,58,.92) 0%, rgba(7,27,58,.4) 60%, transparent 100%);
    padding:14px 12px 10px;
    display:flex; flex-direction:column; justify-content:flex-end; gap:3px;
    opacity:0; transform:translateY(6px);
    transition:opacity .2s ease,transform .2s ease;
}
.afg-photo-link:hover .afg-photo-overlay { opacity:1; transform:translateY(0); }
.afg-overlay-title { color:#fff; font-weight:700; font-size:.88rem; line-height:1.3; text-shadow:0 1px 3px rgba(0,0,0,.5); }
.afg-overlay-meta  { color:rgba(255,255,255,.85); font-size:.78rem; text-shadow:0 1px 2px rgba(0,0,0,.4); }

/* Métas sous la vignette */
.afg-photo-card-body  { padding:10px 12px; }
.afg-photo-card-title { font-size:.88rem; font-weight:600; display:block; margin-bottom:4px; color:var(--afg-text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.afg-photo-card-meta  { display:flex; flex-wrap:wrap; gap:6px; font-size:.78rem; color:var(--afg-muted); }

/* ============================================================
   PAGE PHOTO UNIQUE
   ============================================================ */
.afg-single-wrap  { max-width:900px; }
.afg-photo-title  { font-size:1.5rem; font-weight:900; color:var(--afg-blue); margin:0 0 .7rem; }

/* Chips de métas */
.afg-photo-chips  { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1rem; }
.afg-chip         { display:inline-block; padding:.3rem .75rem; border-radius:999px; background:#eef3f8; font-size:.86rem; color:var(--afg-text); }

/* Personnes identifiées (au-dessus de la photo) */
.afg60-front-tags-top   { background:#fff; border:1px solid var(--afg-border); border-radius:var(--afg-radius); padding:14px 16px; margin-bottom:14px; box-shadow:var(--afg-shadow); }
.afg60-front-tags-title { font-weight:700; color:var(--afg-blue); margin-bottom:10px; font-size:.95rem; }
.afg60-front-tags-list  { display:flex; flex-wrap:wrap; gap:.5rem; }
.afg60-front-tag-pill   {
    display:inline-flex; align-items:center;
    padding:.45rem 1rem;
    background:var(--afg-blue2); color:#fff !important;
    border-radius:999px; font-size:.87rem; font-weight:600;
    text-decoration:none !important;
    transition:background .15s;
    box-shadow:0 2px 6px rgba(0,0,0,.15);
}
.afg60-front-tag-pill:hover { background:var(--afg-yellow); color:var(--afg-blue) !important; }

/* Photo + watermark */
.afg-single-stage { position:relative; display:inline-block; max-width:100%; border-radius:var(--afg-radius); overflow:hidden; background:#f0f2f5; user-select:none; -webkit-user-select:none; }
.afg-single-stage img { max-width:100%; height:auto; display:block; pointer-events:none; -webkit-user-drag:none; }
.afg-watermark    { position:absolute; bottom:10px; right:12px; z-index:3; color:rgba(255,255,255,.9); font-size:11px; font-weight:700; text-shadow:0 1px 4px rgba(0,0,0,.8); text-transform:uppercase; letter-spacing:.06em; pointer-events:none; user-select:none; }

/* Légende */
.afg-photo-caption { margin:14px 0; padding:12px 16px; background:#f6f7f8; border-left:4px solid var(--afg-yellow); border-radius:0 8px 8px 0; font-size:.95rem; line-height:1.6; }

/* Partage */
.afg-share-wrap   { margin-top:16px; }
.afg102-share     { display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.afg102-share-label{ font-size:.88rem; font-weight:600; color:var(--afg-muted); }
.afg102-share-btn { display:inline-block; padding:.4rem .9rem; border-radius:8px; background:var(--afg-blue2); color:#fff !important; text-decoration:none !important; font-size:.84rem; font-weight:600; transition:opacity .15s; }
.afg102-share-btn:hover { opacity:.85; }
.afg102-share-copy{ padding:.4rem .9rem; border-radius:8px; background:#f3f4f6; border:1px solid var(--afg-border); color:var(--afg-text); font-size:.84rem; cursor:pointer; font-weight:600; }
.afg102-share-copy:hover { background:#e5e7eb; }
.afg-protected    { user-select:none; -webkit-user-select:none; }

/* ============================================================
   PAGINATION
   ============================================================ */
.afg60-pagination { display:flex; flex-wrap:wrap; gap:5px; justify-content:center; margin:20px 0; }
.afg60-pagination a { display:inline-flex; align-items:center; justify-content:center; min-width:36px; height:36px; padding:0 8px; border-radius:8px; border:1px solid var(--afg-border); background:#fff; color:var(--afg-text); text-decoration:none; font-size:.9rem; transition:all .15s; }
.afg60-pagination a:hover,.afg60-pagination a.current { background:var(--afg-blue); color:#fff; border-color:var(--afg-blue); }

/* ============================================================
   GRILLE GÉNÉRIQUE (shortcodes vitrine / recent / etc.)
   ============================================================ */
.afg60-netflix-grid,.afg-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:14px; }
.afg60-netflix-card,.afg-grid-card { position:relative; border-radius:var(--afg-radius); overflow:hidden; box-shadow:var(--afg-shadow); background:#fff; transition:transform .2s,box-shadow .2s; }
.afg60-netflix-card:hover,.afg-grid-card:hover { transform:translateY(-3px); box-shadow:0 10px 26px rgba(9,30,66,.13); }
.afg60-netflix-card a,.afg-grid-card a { display:block; position:relative; aspect-ratio:4/3; overflow:hidden; text-decoration:none; }
.afg60-netflix-card img,.afg-grid-card img { width:100%; height:100%; object-fit:cover; transition:transform .3s; display:block; }
.afg60-netflix-card:hover img,.afg-grid-card:hover img { transform:scale(1.05); }
.afg60-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(7,27,58,.9) 0%,transparent 55%); display:flex; flex-direction:column; justify-content:flex-end; padding:12px 10px; opacity:0; transition:opacity .2s; }
.afg60-netflix-card:hover .afg60-card-overlay,.afg-grid-card:hover .afg60-card-overlay { opacity:1; }
.afg60-card-title  { color:#fff; font-weight:700; font-size:.88rem; line-height:1.3; }
.afg80-card-meta   { color:rgba(255,255,255,.82); font-size:.76rem; margin-top:2px; }

/* ============================================================
   GALERIE JOUEUR (player shortcode)
   ============================================================ */
.afg-player-gallery       { margin:1.5rem 0; }
.afg-player-gallery-title { color:var(--afg-blue); margin-bottom:12px; font-size:1.2rem; font-weight:700; }

/* ============================================================
   RECHERCHE
   ============================================================ */
.afg-search-wrap  { margin:1rem 0; }
.afg-search-form  { display:flex; gap:8px; margin-bottom:16px; }
.afg-search-form input { flex:1; max-width:480px; padding:10px 14px; border:1px solid var(--afg-border); border-radius:8px; font-size:.95rem; }
.afg-search-form button { padding:10px 20px; background:var(--afg-blue); color:#fff; border:0; border-radius:8px; cursor:pointer; font-weight:700; transition:background .15s; }
.afg-search-form button:hover { background:var(--afg-blue2); }
.afg-search-title { margin-bottom:12px; font-size:.95rem; color:var(--afg-muted); }

/* ============================================================
   VITRINE / COMPTEUR
   ============================================================ */
.afg-vitrine      { margin:2rem 0; }
.afg-vitrine-head { display:flex; align-items:center; gap:16px; margin-bottom:16px; flex-wrap:wrap; }
.afg-vitrine-head h2 { margin:0; color:var(--afg-blue); font-size:1.4rem; }
.afg-counter      { font-size:.95rem; color:var(--afg-muted); }
.afg90-public-stats { font-size:.95rem; color:var(--afg-muted); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px) {
    .afg-folder-grid,.afg-photo-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media(max-width:900px) {
    .afg-folder-hero { grid-template-columns:1fr; }
    .afg-folder-hero-img { max-height:220px; aspect-ratio:16/9; }
    .afg-photo-overlay { opacity:1; transform:none; }
}
@media(max-width:680px) {
    .afg-photo-nav    { flex-direction:column; align-items:stretch; }
    .afg-nav-btn      { text-align:center; justify-content:center; }
    .afg-folder-grid,.afg-photo-grid { grid-template-columns:1fr 1fr; gap:12px; }
    .afg60-netflix-grid,.afg-grid    { grid-template-columns:1fr 1fr; }
    .afg-sort-group   { margin-left:0; width:100%; }
}
@media(max-width:480px) {
    .afg-folder-grid,.afg-photo-grid,
    .afg60-netflix-grid,.afg-grid    { grid-template-columns:1fr; }
}


/* ============================================================
   AFEBAS Galeries V12.2 — Fiche photo publique centrée + infos latérales
   ============================================================ */

.afg-browser.afg-single-wrap,
.afg-single-wrap{
    width: min(1480px, calc(100vw - 48px));
    max-width: 1480px !important;
    margin: 2rem auto 3rem !important;
    padding: 0 !important;
}

.afg-single-wrap > .afg60-folder-nav,
.afg-single-wrap > .afg-photo-nav{
    max-width: 1480px;
    margin-left: auto;
    margin-right: auto;
}

.afg-single-layout{
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 28px;
    align-items: start;
    margin-top: 20px;
}

.afg-single-main{
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.afg-single-aside{
    min-width: 0;
    position: sticky;
    top: 115px;
    align-self: start;
}

.afg-single-info-card,
.afg60-front-tags-top,
.afg-share-wrap{
    background: rgba(255,255,255,.94) !important;
    border: 1px solid rgba(11,42,91,.10) !important;
    border-radius: 18px !important;
    box-shadow: 0 14px 34px rgba(11,42,91,.10) !important;
    padding: 18px !important;
    margin: 0 0 16px !important;
}

.afg-photo-title{
    margin: 0 0 14px !important;
    color: var(--afg-blue) !important;
    font-size: clamp(1.25rem, 1.6vw, 1.9rem) !important;
    line-height: 1.08 !important;
}

.afg-photo-chips{
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin: 0 !important;
}

.afg-chip{
    background: #eef3f8 !important;
    color: #071b3a !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
}

.afg60-front-tags-title{
    font-size: .95rem !important;
    font-weight: 900 !important;
    color: var(--afg-blue) !important;
    text-transform: uppercase;
    letter-spacing: .02em;
}

.afg60-front-tags-list{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
}

.afg60-front-tag-pill{
    justify-content: center !important;
    text-align: center !important;
    line-height: 1.25 !important;
    white-space: normal !important;
}

.afg-single-stage{
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #0b2a5b !important;
    box-shadow: 0 18px 44px rgba(11,42,91,.22) !important;
}

.afg-single-stage img{
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    max-height: calc(100vh - 250px) !important;
    height: auto !important;
    object-fit: contain !important;
    margin: 0 auto !important;
}

.afg-photo-caption{
    width: 100%;
    max-width: 980px;
    margin: 18px auto 0 !important;
}

.afg-photo-nav{
    justify-content: center !important;
}

.afg-photo-nav-bottom{
    width: 100%;
    justify-content: center !important;
    margin-top: 18px !important;
}

.afg-share-wrap .afg102-share{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
}

.afg-share-wrap .afg102-share-label{
    color: var(--afg-blue) !important;
    font-weight: 900 !important;
    text-transform: uppercase;
}

.afg-share-wrap .afg102-share-btn,
.afg-share-wrap .afg102-share-copy{
    width: 100%;
    text-align: center;
    justify-content: center;
    border-radius: 999px !important;
}

@media (max-width: 1180px){
    .afg-single-layout{
        grid-template-columns: minmax(0, 1fr) 330px;
        gap: 22px;
    }
}

@media (max-width: 920px){
    .afg-browser.afg-single-wrap,
    .afg-single-wrap{
        width: min(100% - 24px, 760px);
        margin-top: 1rem !important;
    }

    .afg-single-layout{
        grid-template-columns: 1fr;
    }

    .afg-single-aside{
        position: static;
        order: -1;
    }

    .afg60-front-tags-list{
        flex-direction: row !important;
    }

    .afg-single-stage img{
        max-height: none !important;
        width: 100% !important;
    }
}

@media (max-width: 520px){
    .afg-single-info-card,
    .afg60-front-tags-top,
    .afg-share-wrap{
        padding: 14px !important;
        border-radius: 14px !important;
    }

    .afg-photo-nav{
        flex-direction: column;
        align-items: stretch !important;
    }

    .afg-nav-btn{
        justify-content: center;
    }
}


/* ============================================================
   AFEBAS Galeries V13.2 — Vignettes publiques non coupées
   Objectif : éviter les têtes coupées sur les cartes dossiers/photos.
   ============================================================ */

/* Cartes dossiers : l'image doit rester lisible, pas remplie au prix d'une tête coupée. */
.afg-folder-card img,
.afg60-folder-card img,
.afg-card-folder img,
.afg-gallery-folder img,
.afg-dossier-card img,
.afg-browser .afg-folder img,
.afg-browser .afg60-folder img,
.afg-browser [class*="folder"] img,
.afg-browser [class*="dossier"] img {
    object-fit: contain !important;
    object-position: center center !important;
    width: 100% !important;
    height: 260px !important;
    background: linear-gradient(135deg, #071b3a 0%, #0b2a5b 100%) !important;
}

/* Vignettes photos : priorité au visage, donc cadrage haut/centre si cover reste utilisé ailleurs. */
.afg-photo-card img,
.afg60-photo-card img,
.afg-gallery-photo img,
.afg-browser [class*="photo"] img {
    object-fit: contain !important;
    object-position: center center !important;
    width: 100% !important;
    height: 260px !important;
    background: linear-gradient(135deg, #071b3a 0%, #0b2a5b 100%) !important;
}

/* Les images de grandes cartes peuvent être légèrement plus hautes sur desktop. */
@media (min-width: 1024px) {
    .afg-folder-card img,
    .afg60-folder-card img,
    .afg-card-folder img,
    .afg-gallery-folder img,
    .afg-dossier-card img,
    .afg-photo-card img,
    .afg60-photo-card img,
    .afg-gallery-photo img {
        height: 300px !important;
    }
}

/* Sur mobile, on réduit la hauteur tout en gardant l'image entière. */
@media (max-width: 700px) {
    .afg-folder-card img,
    .afg60-folder-card img,
    .afg-card-folder img,
    .afg-gallery-folder img,
    .afg-dossier-card img,
    .afg-photo-card img,
    .afg60-photo-card img,
    .afg-gallery-photo img,
    .afg-browser [class*="folder"] img,
    .afg-browser [class*="dossier"] img,
    .afg-browser [class*="photo"] img {
        height: 220px !important;
        object-fit: contain !important;
        object-position: center center !important;
    }
}

/* Si une carte a un conteneur image dédié, on lui impose un fond propre AFEBAS. */
.afg-folder-card .afg-thumb,
.afg60-folder-card .afg-thumb,
.afg-photo-card .afg-thumb,
.afg60-photo-card .afg-thumb,
.afg-card-media,
.afg-card-thumb {
    background: linear-gradient(135deg, #071b3a 0%, #0b2a5b 100%) !important;
    overflow: hidden !important;
}

/* Badge nombre de photos : conservé visible, sans masquer les visages. */
.afg-folder-count,
.afg60-folder-count,
.afg-photo-count,
.afg60-photo-count {
    z-index: 5 !important;
}


/* ============================================================
   AFEBAS Galeries V13.3.1 — Vignettes non coupées SANS vide inutile
   ============================================================ */

.afg-folder-card img,
.afg60-folder-card img,
.afg-card-folder img,
.afg-gallery-folder img,
.afg-dossier-card img,
.afg-photo-card img,
.afg60-photo-card img,
.afg-gallery-photo img,
.afg-browser [class*="folder"] img,
.afg-browser [class*="dossier"] img,
.afg-browser [class*="photo"] img {
    height: auto !important;
    min-height: 0 !important;
    max-height: 320px !important;
    width: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
    background: #071b3a !important;
}

.afg-folder-card .afg-thumb,
.afg60-folder-card .afg-thumb,
.afg-photo-card .afg-thumb,
.afg60-photo-card .afg-thumb,
.afg-card-media,
.afg-card-thumb,
.afg-browser [class*="folder"] .afg-thumb,
.afg-browser [class*="photo"] .afg-thumb {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: hidden !important;
    background: #071b3a !important;
}

.afg-folder-card,
.afg60-folder-card,
.afg-card-folder,
.afg-gallery-folder,
.afg-dossier-card,
.afg-photo-card,
.afg60-photo-card,
.afg-gallery-photo {
    display: flex !important;
    flex-direction: column !important;
}

.afg-folder-card a,
.afg60-folder-card a,
.afg-photo-card a,
.afg60-photo-card a {
    display: flex !important;
    flex-direction: column !important;
}

.afg-folder-card figure,
.afg60-folder-card figure,
.afg-photo-card figure,
.afg60-photo-card figure,
.afg-card-media,
.afg-card-thumb {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

.afg-browser .afg-folder-card img,
.afg-browser .afg60-folder-card img,
.afg-browser .afg-photo-card img,
.afg-browser .afg60-photo-card img {
    max-height: 280px !important;
}

@media (max-width: 700px) {
    .afg-folder-card img,
    .afg60-folder-card img,
    .afg-card-folder img,
    .afg-gallery-folder img,
    .afg-dossier-card img,
    .afg-photo-card img,
    .afg60-photo-card img,
    .afg-gallery-photo img,
    .afg-browser [class*="folder"] img,
    .afg-browser [class*="dossier"] img,
    .afg-browser [class*="photo"] img {
        height: auto !important;
        max-height: 260px !important;
        object-fit: contain !important;
    }
}


/* ============================================================
   AFEBAS Galeries V13.4.0 — Correctif complet vignettes publiques
   ------------------------------------------------------------
   Correction réelle du vide :
   - les anciennes versions forçaient aspect-ratio:4/3 sur les liens images
   - object-fit:contain gardait l'image entière mais le conteneur restait trop haut
   - V13.4 supprime le ratio fixe et laisse la carte suivre la hauteur réelle de l'image
   ============================================================ */

/* 1) Grilles : cartes propres, sans hauteur imposée */
.afg-folder-grid,
.afg-photo-grid {
    align-items: start !important;
}

.afg-folder-card,
.afg-photo-card {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    background: #fff !important;
}

/* 2) Élément critique : les liens images ne doivent plus imposer un ratio 4/3 */
.afg-folder-cover-link,
.afg-photo-link {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    background: #071b3a !important;
    line-height: 0 !important;
}

/* 3) Images : jamais coupées, jamais de bloc vide forcé */
.afg-folder-cover-img,
.afg-photo-link img,
.afg-folder-cover-link img,
.afg-folder-card img,
.afg-photo-card img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: 340px !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin: 0 auto !important;
    padding: 0 !important;
    background: #071b3a !important;
}

/* 4) Les photos verticales ne doivent pas casser la page */
.afg-photo-link img,
.afg-folder-cover-img {
    object-fit: contain !important;
}

/* 5) Suppression des effets de zoom qui peuvent recouper les têtes au survol */
.afg-folder-card:hover .afg-folder-cover-img,
.afg-photo-card:hover .afg-photo-link img {
    transform: none !important;
}

/* 6) Corps de carte : collé proprement sous l'image */
.afg-folder-body,
.afg-photo-card-body {
    padding: 12px 14px !important;
    margin: 0 !important;
    flex: 0 0 auto !important;
    background: #fff !important;
    line-height: 1.35 !important;
}

.afg-folder-body h3,
.afg-photo-card-title {
    margin-top: 0 !important;
}

/* 7) Badge compteur : reste sur l'image, sans imposer de hauteur */
.afg-folder-badge {
    z-index: 5 !important;
    line-height: 1.2 !important;
}

/* 8) Cas image absente */
.afg-folder-cover-empty,
.afg-photo-empty {
    min-height: 180px !important;
    line-height: 1.3 !important;
}

/* 9) Compatibilité anciennes classes ajoutées par versions précédentes */
.afg60-folder-card,
.afg60-photo-card,
.afg-card-folder,
.afg-gallery-folder,
.afg-gallery-photo,
.afg-dossier-card,
.afg-browser [class*="folder"],
.afg-browser [class*="dossier"],
.afg-browser [class*="photo"] {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
}

.afg60-folder-card a,
.afg60-photo-card a,
.afg-card-folder a,
.afg-gallery-folder a,
.afg-gallery-photo a,
.afg-dossier-card a,
.afg-browser [class*="folder"] a,
.afg-browser [class*="dossier"] a,
.afg-browser [class*="photo"] a {
    aspect-ratio: auto !important;
    height: auto !important;
    min-height: 0 !important;
    line-height: 0 !important;
}

/* 10) Mobile */
@media (max-width: 768px) {
    .afg-folder-grid,
    .afg-photo-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .afg-folder-cover-img,
    .afg-photo-link img,
    .afg-folder-cover-link img,
    .afg-folder-card img,
    .afg-photo-card img {
        max-height: 280px !important;
    }
}

/* 11) Tablette */
@media (min-width: 769px) and (max-width: 1100px) {
    .afg-folder-grid,
    .afg-photo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* 12) Desktop : on garde trois colonnes sans forcer la hauteur uniforme */
@media (min-width: 1101px) {
    .afg-folder-grid,
    .afg-photo-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}


/* ============================================================
   AFEBAS Galeries V13.5.0 — Correctifs mobile, identification, partage
   ============================================================ */

/* Titres dossiers/photos : plus de chevauchement ni débordement mobile */
.afg-folder-body,
.afg-photo-card-body {
    min-height: 0 !important;
    height: auto !important;
    padding: 12px 16px !important;
    overflow: visible !important;
    background: #fff !important;
}

.afg-folder-body h3,
.afg-folder-title,
.afg-photo-card-title,
.afg-card-title,
.afg-gallery-title,
.afg-dossier-title {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: clamp(16px, 4.4vw, 21px) !important;
    line-height: 1.18 !important;
    letter-spacing: 0 !important;
    text-align: left !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    hyphens: auto !important;
    color: #061329 !important;
    text-shadow: none !important;
}

.afg-folder-card h3 a,
.afg-photo-card h3 a,
.afg-folder-title a,
.afg-photo-card-title a {
    color: #061329 !important;
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
    line-height: 1.18 !important;
}

@media (max-width: 768px) {
    .afg-folder-card,
    .afg-photo-card {
        border-radius: 18px !important;
        overflow: hidden !important;
    }
    .afg-folder-body h3,
    .afg-folder-title,
    .afg-photo-card-title,
    .afg-card-title,
    .afg-gallery-title,
    .afg-dossier-title {
        font-size: 18px !important;
        line-height: 1.2 !important;
    }
    .afg-folder-badge {
        right: 12px !important;
        bottom: 12px !important;
        font-size: 13px !important;
        padding: 8px 12px !important;
    }
}

/* Page photo publique : image plus grande, centrée et cliquable */
.afg-photo-single,
.afg-single-photo,
.afg-photo-detail,
.afg-public-photo,
.afg-photo-view,
.afg-photo-main,
.afg-single-main {
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.afg-photo-single img,
.afg-single-photo img,
.afg-photo-detail img,
.afg-public-photo img,
.afg-photo-view img,
.afg-photo-main img,
.afg-single-main img {
    display: block !important;
    width: auto !important;
    max-width: min(100%, 1180px) !important;
    max-height: none !important;
    height: auto !important;
    margin: 18px auto !important;
    border-radius: 18px !important;
    cursor: zoom-in !important;
    box-shadow: 0 18px 44px rgba(7, 27, 58, .18) !important;
}

@media (max-width: 768px) {
    .afg-photo-single img,
    .afg-single-photo img,
    .afg-photo-detail img,
    .afg-public-photo img,
    .afg-photo-view img,
    .afg-photo-main img,
    .afg-single-main img {
        width: 100% !important;
        max-width: 100% !important;
        margin: 14px auto !important;
        border-radius: 16px !important;
    }
}

/* Identification publique : affichage compact, licence/droit image masqués */
.afg-people-list,
.afg-identified-people,
.afg-persons,
.afg-tags-public {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    align-items: flex-start !important;
}

.afg-people-list a,
.afg-people-list span,
.afg-identified-people a,
.afg-identified-people span,
.afg-persons a,
.afg-persons span,
.afg-tags-public a,
.afg-tags-public span {
    font-size: 15px !important;
    line-height: 1.2 !important;
    padding: 9px 14px !important;
    border-radius: 999px !important;
    text-align: center !important;
}

.afg-person-license,
.afg-person-right,
.afg-droit-image,
.afg-license,
.afg-player-license,
.afg-public-license,
.afg-public-right {
    display: none !important;
}

/* Partage : icônes compactes en bas */
.afg-share,
.afg-share-block,
.afg-social-share,
.afg-share-buttons {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin: 22px auto !important;
    padding: 0 !important;
    max-width: 100% !important;
}

.afg-share h3,
.afg-share-block h3,
.afg-social-share h3,
.afg-share-title {
    flex-basis: 100% !important;
    text-align: center !important;
    margin: 0 0 8px !important;
    font-size: 15px !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    color: #062b4a !important;
}

.afg-share a,
.afg-share button,
.afg-share-block a,
.afg-share-block button,
.afg-social-share a,
.afg-social-share button,
.afg-share-buttons a,
.afg-share-buttons button {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0 !important;
    line-height: 1 !important;
    background: #082f63 !important;
    color: #fff !important;
    border: 1px solid rgba(255, 210, 0, .55) !important;
    box-shadow: 0 8px 18px rgba(7, 27, 58, .16) !important;
    text-decoration: none !important;
}

.afg-share a[href*="facebook"]::before,
.afg-share-block a[href*="facebook"]::before,
.afg-social-share a[href*="facebook"]::before { content: "f"; font-size: 20px; font-weight: 900; }

.afg-share a[href*="whatsapp"]::before,
.afg-share-block a[href*="whatsapp"]::before,
.afg-social-share a[href*="whatsapp"]::before { content: "☎"; font-size: 20px; font-weight: 900; }

.afg-share a[href^="mailto"]::before,
.afg-share-block a[href^="mailto"]::before,
.afg-social-share a[href^="mailto"]::before { content: "✉"; font-size: 19px; font-weight: 900; }

.afg-share button::before,
.afg-share-block button::before,
.afg-social-share button::before,
.afg-share-copy::before,
.afg-copy-link::before { content: "🔗"; font-size: 18px; }

/* Lightbox */
.afg135-lightbox {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 22px;
    background: rgba(2, 10, 25, .92);
}
.afg135-lightbox.is-open { display: flex; }
.afg135-lightbox img {
    max-width: 96vw;
    max-height: 92vh;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 10px;
    box-shadow: 0 24px 80px rgba(0,0,0,.45);
}
.afg135-lightbox-close {
    position: fixed;
    top: 14px;
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.35);
    background: #082f63;
    color: #fff;
    font-size: 30px;
    line-height: 1;
    cursor: pointer;
}

/* ============================================================
V13.5.1 HOTFIX MOBILE
============================================================ */

.afg-folder-card,
.afg-photo-card{
 display:flex !important;
 flex-direction:column !important;
}

.afg-folder-body,
.afg-photo-card-body,
.afg-photo-body{
 position:relative !important;
 z-index:5 !important;
 background:#fff !important;
 min-height:auto !important;
 height:auto !important;
 padding:14px 16px 18px !important;
 overflow:visible !important;
}

.afg-folder-card h3,
.afg-folder-title,
.afg-photo-card h3,
.afg-photo-title{
 display:block !important;
 position:relative !important;
 width:100% !important;
 margin:0 !important;
 padding:0 !important;
 transform:none !important;
 white-space:normal !important;
 overflow:visible !important;
 text-overflow:unset !important;
 word-break:break-word !important;
 overflow-wrap:anywhere !important;
 line-height:1.15 !important;
 font-size:clamp(18px,5vw,28px) !important;
}

.afg-photo-overlay,
.afg-photo-caption-overlay,
.afg-overlay,
.caption-on-image,
.photo-meta-overlay{
 display:none !important;
}

.afg-single-photo img,
.afg-photo-single img,
.afg-photo-main img{
 width:100% !important;
 max-width:100% !important;
 height:auto !important;
 object-fit:contain !important;
}

.afg-person-license,
.afg-license,
.afg-droit-image,
.afg-player-license{
 display:none !important;
}

.afg-share a,
.afg-share button,
.afg-share-block a,
.afg-share-block button{
 width:52px !important;
 height:52px !important;
 border-radius:50% !important;
 font-size:0 !important;
 display:inline-flex !important;
 align-items:center !important;
 justify-content:center !important;
}

.afg-share a[href*="facebook"]::before{content:"📘";font-size:24px;}
.afg-share a[href*="whatsapp"]::before{content:"💬";font-size:24px;}
.afg-share a[href^="mailto"]::before{content:"✉";font-size:24px;}
.afg-share button::before,
.afg-copy-link::before{content:"🔗";font-size:24px;}


/* ============================================================
   AFEBAS Galeries V13.5.2 — Correctif réel public mobile
   ============================================================ */

/* Les anciens sélecteurs trop larges mettaient line-height:0 sur les liens des titres. */
.afg-browser .afg-folder-body,
.afg-browser .afg-photo-card-body {
    display: block !important;
    position: relative !important;
    z-index: 10 !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 12px 14px !important;
    margin: 0 !important;
    background: #fff !important;
    overflow: visible !important;
    line-height: 1.2 !important;
}

.afg-browser .afg-folder-body h3,
.afg-browser .afg-folder-body h3 a,
.afg-browser .afg-photo-card-title,
.afg-browser .afg-photo-card-body span,
.afg-browser .afg-photo-card-body a {
    display: block !important;
    position: static !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.16 !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    text-align: left !important;
    color: #061329 !important;
    background: transparent !important;
    transform: none !important;
}

/* Cartes dossiers : titre sous l'image, jamais en overlay. */
.afg-browser .afg-folder-cover-link {
    line-height: 0 !important;
}

.afg-browser .afg-folder-body h3 a {
    font-size: 17px !important;
    font-weight: 900 !important;
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
}

/* Cartes photos : on supprime définitivement les overlays texte sur image. */
.afg-browser .afg-photo-overlay,
.afg-browser .afg-overlay-title,
.afg-browser .afg-overlay-meta {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
}

/* Image principale publique : pleine largeur utile, cliquable. */
.afg-browser .afg-single-stage {
    width: 100% !important;
    max-width: 1180px !important;
    margin: 0 auto 18px !important;
    text-align: center !important;
}

.afg-browser .afg-single-stage img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: none !important;
    object-fit: contain !important;
    cursor: zoom-in !important;
}

/* Identifications : PHP sort maintenant nom/prénom uniquement, CSS compacte. */
.afg-browser .afg60-front-tag-pill {
    font-size: 15px !important;
    line-height: 1.15 !important;
    padding: 10px 14px !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
}

/* Partage : vraies icônes, plus de gros boutons texte. */
.afg-browser .afg135-share-icons,
.afg-browser .afg102-share {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

.afg-browser .afg102-share-label {
    flex-basis: 100% !important;
    text-align: center !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    color: #062b4a !important;
    text-transform: uppercase !important;
}

.afg-browser .afg135-share-icons .afg102-share-btn,
.afg-browser .afg135-share-icons .afg102-share-copy {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    max-width: 46px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #082f63 !important;
    color: #fff !important;
    border: 1px solid rgba(255, 210, 0, .55) !important;
    text-decoration: none !important;
    box-shadow: 0 8px 18px rgba(7, 27, 58, .16) !important;
}

.afg-browser .afg135-share-icons .afg102-share-btn span,
.afg-browser .afg135-share-icons .afg102-share-copy span {
    font-size: 21px !important;
    line-height: 1 !important;
    color: #fff !important;
}

/* Lightbox */
.afg135-lightbox {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(2, 10, 25, .92);
}

.afg135-lightbox.is-open {
    display: flex;
}

.afg135-lightbox img {
    max-width: 96vw;
    max-height: 92vh;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 10px;
    box-shadow: 0 24px 80px rgba(0,0,0,.45);
}

.afg135-lightbox-close {
    position: fixed;
    top: 14px;
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.35);
    background: #082f63;
    color: #fff;
    font-size: 30px;
    line-height: 1;
    cursor: pointer;
}

@media (max-width: 768px) {
    .afg-browser .afg-folder-body h3 a,
    .afg-browser .afg-photo-card-title {
        font-size: 17px !important;
        line-height: 1.16 !important;
    }

    .afg-browser .afg-single-layout {
        display: flex !important;
        flex-direction: column !important;
    }

    .afg-browser .afg-single-main {
        order: 1 !important;
    }

    .afg-browser .afg-single-aside {
        order: 2 !important;
    }

    .afg-browser .afg-share-wrap {
        order: 99 !important;
    }
}


/* AFEBAS Galeries V13.6.0 — Photos joueur réseau multisite */
.afg136-network-player-photos{max-width:1200px;margin:32px auto}
.afg136-network-player-photos h2{color:#062b4a;font-size:clamp(22px,3vw,34px);margin:0 0 18px}
.afg136-network-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.afg136-network-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 14px 34px rgba(7,27,58,.12)}
.afg136-network-card a{display:block;color:#061329;text-decoration:none}
.afg136-network-card img{display:block;width:100%;height:auto;max-height:240px;object-fit:contain;background:#071b3a}
.afg136-network-card strong{display:block;padding:12px 14px 4px;line-height:1.18;color:#061329}
.afg136-network-card span{display:block;padding:0 14px 14px;color:#5d6678;font-size:14px}
@media(max-width:900px){.afg136-network-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.afg136-network-grid{grid-template-columns:1fr}}


/* ============================================================
   AFEBAS Galeries V13.6.1 — réseau joueur responsive dense
   Desktop : jusqu'à 10 photos par ligne
   Mobile : 3 photos par ligne si largeur suffisante, puis 2/1 si trop étroit
   ============================================================ */

.afg136-network-player-photos {
    max-width: 100% !important;
    margin: 24px auto !important;
}

.afg136-network-player-photos h2 {
    margin: 0 0 14px !important;
}

.afg136-network-grid {
    display: grid !important;
    grid-template-columns: repeat(10, minmax(0, 1fr)) !important;
    gap: 10px !important;
    align-items: start !important;
}

.afg136-network-card {
    border-radius: 10px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(7,27,58,.10) !important;
}

.afg136-network-card a {
    display: block !important;
    text-decoration: none !important;
}

.afg136-network-card img {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center top !important;
    background: #071b3a !important;
}

.afg136-network-card strong {
    display: block !important;
    padding: 6px 7px 2px !important;
    font-size: 11px !important;
    line-height: 1.12 !important;
    color: #061329 !important;
    overflow-wrap: anywhere !important;
}

.afg136-network-card span {
    display: block !important;
    padding: 0 7px 7px !important;
    font-size: 10px !important;
    line-height: 1.12 !important;
    color: #5d6678 !important;
}

@media (max-width: 1400px) {
    .afg136-network-grid { grid-template-columns: repeat(8, minmax(0, 1fr)) !important; }
}

@media (max-width: 1100px) {
    .afg136-network-grid { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
}

@media (max-width: 760px) {
    .afg136-network-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }
    .afg136-network-card strong { font-size: 10px !important; padding: 5px 5px 1px !important; }
    .afg136-network-card span { font-size: 9px !important; padding: 0 5px 5px !important; }
}

@media (max-width: 360px) {
    .afg136-network-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

/* Zoom réseau */
.afg1361-zoom {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(2,10,25,.92);
}

.afg1361-zoom.is-open {
    display: flex;
}

.afg1361-zoom img {
    max-width: 96vw;
    max-height: 92vh;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 10px;
}

.afg1361-zoom button {
    position: fixed;
    top: 14px;
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.35);
    background: #082f63;
    color: #fff;
    font-size: 30px;
    line-height: 1;
    cursor: pointer;
}


/* AFEBAS Galeries V13.6.2 — correction liens multisite + grille réseau */
.afg136-network-grid {
    grid-template-columns: repeat(10, minmax(0, 1fr)) !important;
}

@media (max-width: 760px) {
    .afg136-network-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 360px) {
    .afg136-network-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}


/* ============================================================
   AFEBAS Galeries V13.6.3
   [afebas_player_photos_network] : grille adaptative + zoom
   ============================================================ */

/* Conteneur réseau */
.afg136-network-player-photos {
    width: 100% !important;
    max-width: 100% !important;
    margin: 26px auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.afg136-network-player-photos h2 {
    margin: 0 0 14px !important;
    color: #062b4a !important;
    font-size: clamp(20px, 2.2vw, 30px) !important;
    line-height: 1.15 !important;
}

/* Desktop large : 10 photos par ligne */
.afg136-network-grid {
    display: grid !important;
    grid-template-columns: repeat(10, minmax(0, 1fr)) !important;
    gap: 10px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Cartes compactes */
.afg136-network-card {
    min-width: 0 !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 8px 18px rgba(7, 27, 58, .12) !important;
}

.afg136-network-card a {
    display: block !important;
    color: #061329 !important;
    text-decoration: none !important;
}

/* Vignette carrée pour obtenir une grille stable */
.afg136-network-card img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    object-position: center top !important;
    background: #071b3a !important;
    cursor: zoom-in !important;
    transition: transform .18s ease, filter .18s ease !important;
}

.afg136-network-card:hover img {
    transform: scale(1.025) !important;
    filter: brightness(1.03) !important;
}

/* Texte très compact, sinon 10 colonnes deviennent illisibles */
.afg136-network-card strong {
    display: block !important;
    padding: 7px 7px 2px !important;
    color: #061329 !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    overflow-wrap: anywhere !important;
}

.afg136-network-card span {
    display: block !important;
    padding: 0 7px 8px !important;
    color: #5d6678 !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
}

/* Adaptation progressive */
@media (max-width: 1500px) {
    .afg136-network-grid { grid-template-columns: repeat(9, minmax(0, 1fr)) !important; }
}

@media (max-width: 1320px) {
    .afg136-network-grid { grid-template-columns: repeat(8, minmax(0, 1fr)) !important; }
}

@media (max-width: 1160px) {
    .afg136-network-grid { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
}

@media (max-width: 900px) {
    .afg136-network-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}

@media (max-width: 760px) {
    .afg136-network-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }

    .afg136-network-card {
        border-radius: 10px !important;
    }

    .afg136-network-card strong {
        font-size: 10px !important;
        line-height: 1.12 !important;
        padding: 5px 5px 1px !important;
    }

    .afg136-network-card span {
        font-size: 9px !important;
        line-height: 1.1 !important;
        padding: 0 5px 6px !important;
    }
}

@media (max-width: 360px) {
    .afg136-network-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Zoom image réseau */
.afg1363-network-zoom {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px !important;
    background: rgba(2, 10, 25, .92) !important;
}

.afg1363-network-zoom.is-open {
    display: flex !important;
}

.afg1363-network-zoom img {
    display: block !important;
    max-width: 96vw !important;
    max-height: 92vh !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: 12px !important;
    box-shadow: 0 24px 80px rgba(0, 0, 0, .45) !important;
    background: #071b3a !important;
}

.afg1363-network-zoom-close {
    position: fixed !important;
    top: 14px !important;
    right: 16px !important;
    width: 46px !important;
    height: 46px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.35) !important;
    background: #082f63 !important;
    color: #fff !important;
    font-size: 32px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}


/* ============================================================
   AFEBAS Galeries V13.6.4 — SHORTCODE RÉSEAU FORCÉ
   Classes neuves .afg1364-* pour éviter les conflits hérités.
   ============================================================ */

.afg1364-player-network {
    width: 100% !important;
    max-width: 100% !important;
    margin: 26px auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.afg1364-player-network-title {
    color: #062b4a !important;
    font-size: clamp(20px, 2vw, 30px) !important;
    line-height: 1.15 !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
}

/* 10 photos par ligne desktop */
.afg1364-grid {
    display: grid !important;
    grid-template-columns: repeat(10, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    align-items: start !important;
    box-sizing: border-box !important;
}

.afg1364-card {
    display: block !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(7, 27, 58, .12) !important;
}

.afg1364-photo-button {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: #071b3a !important;
    cursor: zoom-in !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    line-height: 0 !important;
}

.afg1364-photo-button img {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
    object-fit: cover !important;
    object-position: center top !important;
    background: #071b3a !important;
    transition: transform .18s ease, filter .18s ease !important;
}

.afg1364-photo-button:hover img {
    transform: scale(1.025) !important;
    filter: brightness(1.03) !important;
}

.afg1364-photo-title {
    display: block !important;
    padding: 7px 7px 2px !important;
    color: #061329 !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    overflow-wrap: anywhere !important;
}

.afg1364-photo-title:hover {
    text-decoration: underline !important;
}

.afg1364-meta {
    display: flex !important;
    flex-direction: column !important;
    gap: 1px !important;
    padding: 0 7px 8px !important;
    color: #5d6678 !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
}

.afg1364-meta span {
    display: block !important;
    color: #5d6678 !important;
}

/* Adaptation automatique écran */
@media (max-width: 1500px) {
    .afg1364-grid { grid-template-columns: repeat(9, minmax(0, 1fr)) !important; }
}

@media (max-width: 1320px) {
    .afg1364-grid { grid-template-columns: repeat(8, minmax(0, 1fr)) !important; }
}

@media (max-width: 1160px) {
    .afg1364-grid { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
}

@media (max-width: 900px) {
    .afg1364-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}

/* Mobile demandé : 3 photos par ligne */
@media (max-width: 760px) {
    .afg1364-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }

    .afg1364-card {
        border-radius: 10px !important;
    }

    .afg1364-photo-title {
        font-size: 10px !important;
        line-height: 1.12 !important;
        padding: 5px 5px 1px !important;
    }

    .afg1364-meta {
        font-size: 9px !important;
        line-height: 1.1 !important;
        padding: 0 5px 6px !important;
    }
}

/* Très petit mobile : on descend à 2 pour préserver la lisibilité */
@media (max-width: 360px) {
    .afg1364-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Zoom */
.afg1364-zoom {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px !important;
    background: rgba(2, 10, 25, .92) !important;
}

.afg1364-zoom.is-open {
    display: flex !important;
}

.afg1364-zoom img {
    display: block !important;
    max-width: 96vw !important;
    max-height: 92vh !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: 12px !important;
    background: #071b3a !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.45) !important;
}

.afg1364-zoom-close {
    position: fixed !important;
    top: 14px !important;
    right: 16px !important;
    width: 46px !important;
    height: 46px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.35) !important;
    background: #082f63 !important;
    color: #fff !important;
    font-size: 32px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}


/* ============================================================
   AFEBAS Galeries V13.6.5 — ALIGNEMENT RÉEL SHORTCODE RÉSEAU
   Objectif : cartes toujours alignées, sans flux vertical brut.
   ============================================================ */

/* Le bloc doit occuper la largeur réelle de la zone de contenu */
.afg1365-player-network,
.afg1364-player-network {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 28px 0 !important;
    padding: 0 28px !important;
    box-sizing: border-box !important;
    clear: both !important;
}

.afg1365-player-network-title,
.afg1364-player-network-title {
    display: block !important;
    margin: 0 0 16px !important;
    padding: 0 !important;
    color: #062b4a !important;
    font-size: clamp(20px, 2vw, 30px) !important;
    line-height: 1.15 !important;
    text-align: left !important;
}

/* Grille : minmax(0,1fr) + enfants directs. */
.afg1365-grid,
.afg1364-grid {
    display: grid !important;
    grid-template-columns: repeat(10, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    align-items: stretch !important;
    justify-items: stretch !important;
}

/* Neutralise les effets des thèmes sur article/a/button/img */
.afg1365-card,
.afg1364-card {
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    clear: none !important;
    border: 0 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(7, 27, 58, .12) !important;
    box-sizing: border-box !important;
}

.afg1365-photo-button,
.afg1364-photo-button {
    display: block !important;
    flex: 0 0 auto !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: #071b3a !important;
    cursor: zoom-in !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    line-height: 0 !important;
    text-align: center !important;
    box-sizing: border-box !important;
}

.afg1365-photo-button img,
.afg1364-photo-button img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
    object-fit: cover !important;
    object-position: center top !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #071b3a !important;
}

.afg1365-card-body {
    display: block !important;
    flex: 1 1 auto !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    min-height: 0 !important;
}

.afg1365-photo-title,
.afg1364-photo-title {
    display: block !important;
    width: 100% !important;
    padding: 7px 7px 2px !important;
    margin: 0 !important;
    color: #061329 !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    overflow-wrap: anywhere !important;
    box-sizing: border-box !important;
}

.afg1365-photo-title:hover,
.afg1364-photo-title:hover {
    text-decoration: underline !important;
}

.afg1365-meta,
.afg1364-meta {
    display: flex !important;
    flex-direction: column !important;
    gap: 1px !important;
    width: 100% !important;
    padding: 0 7px 8px !important;
    margin: 0 !important;
    color: #5d6678 !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
    box-sizing: border-box !important;
}

.afg1365-meta span,
.afg1364-meta span {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #5d6678 !important;
}

/* Responsive progressif */
@media (max-width: 1500px) {
    .afg1365-grid,
    .afg1364-grid { grid-template-columns: repeat(9, minmax(0, 1fr)) !important; }
}

@media (max-width: 1320px) {
    .afg1365-grid,
    .afg1364-grid { grid-template-columns: repeat(8, minmax(0, 1fr)) !important; }
}

@media (max-width: 1160px) {
    .afg1365-grid,
    .afg1364-grid { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
}

@media (max-width: 900px) {
    .afg1365-grid,
    .afg1364-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}

/* Mobile demandé : 3 colonnes */
@media (max-width: 760px) {
    .afg1365-player-network,
    .afg1364-player-network {
        padding: 0 14px !important;
    }

    .afg1365-grid,
    .afg1364-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }

    .afg1365-card,
    .afg1364-card {
        border-radius: 10px !important;
    }

    .afg1365-photo-title,
    .afg1364-photo-title {
        font-size: 10px !important;
        line-height: 1.12 !important;
        padding: 5px 5px 1px !important;
    }

    .afg1365-meta,
    .afg1364-meta {
        font-size: 9px !important;
        line-height: 1.1 !important;
        padding: 0 5px 6px !important;
    }
}

/* Très petit écran */
@media (max-width: 360px) {
    .afg1365-grid,
    .afg1364-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Zoom V13.6.5 */
.afg1365-zoom {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px !important;
    background: rgba(2, 10, 25, .92) !important;
}

.afg1365-zoom.is-open {
    display: flex !important;
}

.afg1365-zoom img {
    display: block !important;
    max-width: 96vw !important;
    max-height: 92vh !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: 12px !important;
    background: #071b3a !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.45) !important;
}

.afg1365-zoom-close {
    position: fixed !important;
    top: 14px !important;
    right: 16px !important;
    width: 46px !important;
    height: 46px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.35) !important;
    background: #082f63 !important;
    color: #fff !important;
    font-size: 32px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}
