/* ════════════════════════════════════════════════════════════════
   UCREF — galerie.css
   ════════════════════════════════════════════════════════════════ */

.gal-hero{position:relative;overflow:hidden;padding:72px 24px 56px;text-align:center}
.gal-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 15% 50%,rgba(250,163,7,.08) 0%,transparent 65%),radial-gradient(ellipse 45% 55% at 85% 25%,rgba(16,185,129,.05) 0%,transparent 60%),var(--bg2,#0d2137);border-bottom:1px solid var(--bdr,rgba(255,255,255,.08))}
.gal-hero-inner{position:relative}
.gal-hero-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(250,163,7,.1);border:1px solid rgba(250,163,7,.2);color:var(--gold,#faa307);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:16px}
.gal-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3rem);color:#fff;margin-bottom:10px;line-height:1.15}
.gal-hero p{color:var(--text2,#7a9bbf);font-size:1rem;margin-bottom:16px}
.gal-hero-count{display:inline-block;font-size:.78rem;color:var(--text2,#7a9bbf);background:rgba(255,255,255,.05);border:1px solid var(--bdr,rgba(255,255,255,.08));padding:4px 14px;border-radius:20px}

/* Filtres */
.gal-filters-bar{background:var(--bg2,#0d2137);border-bottom:1px solid var(--bdr,rgba(255,255,255,.08));padding:14px 24px;position:sticky;top:60px;z-index:40}
.gal-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.gal-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;border:1px solid var(--bdr,rgba(255,255,255,.08));background:transparent;color:var(--text2,#7a9bbf);font-size:.78rem;font-weight:600;text-decoration:none;transition:all .18s;white-space:nowrap}
.gal-pill:hover{border-color:var(--gold,#faa307);color:var(--gold,#faa307);text-decoration:none}
.gal-pill.on{background:var(--gold,#faa307);border-color:var(--gold,#faa307);color:#000}
.gal-pill-ct{background:rgba(255,255,255,.12);color:inherit;font-size:.65rem;padding:0 6px;border-radius:10px;font-weight:700}
.gal-pill.on .gal-pill-ct{background:rgba(0,0,0,.15)}

/* Section */
.gal-section{padding:40px 24px 72px}

/* Grille */
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:40px}

/* Item */
.gal-item{background:var(--card,#162f50);border:1px solid var(--bdr,rgba(255,255,255,.08));border-radius:14px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s;animation:gFadeUp .45s ease both;position:relative}
@keyframes gFadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.gal-item:hover{border-color:rgba(250,163,7,.35);transform:translateY(-3px)}
.gal-item--pinned{border-color:rgba(250,163,7,.25)}

/* Image */
.gal-item-img{position:relative;overflow:hidden;background:var(--bg2,#0d2137);aspect-ratio:4/3}
.gal-item-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.gal-item:hover .gal-item-img img{transform:scale(1.04)}

.gal-item-overlay{position:absolute;inset:0;background:rgba(7,23,42,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}
.gal-item:hover .gal-item-overlay{opacity:1}
.gal-item-zoom{width:48px;height:48px;border-radius:50%;background:rgba(250,163,7,.9);color:#000;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;transform:scale(.8);transition:transform .2s}
.gal-item:hover .gal-item-zoom{transform:scale(1)}

.gal-pin-badge{position:absolute;top:10px;right:10px;background:rgba(250,163,7,.9);color:#000;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;z-index:3}

/* Info */
.gal-item-info{padding:13px 15px 15px}
.gal-item-cat{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold,#faa307);margin-bottom:5px}
.gal-item-title{font-weight:600;color:#fff;font-size:.9rem;margin-bottom:4px;line-height:1.35}
.gal-item-caption{font-size:.8rem;color:var(--text2,#7a9bbf);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px}
.gal-item-date{font-size:.72rem;color:var(--text2,#7a9bbf);opacity:.7}

/* Empty */
.gal-empty{text-align:center;padding:80px 24px;color:var(--text2,#7a9bbf)}
.gal-empty-icon{font-size:3rem;opacity:.3;margin-bottom:16px}
.gal-empty h3{font-family:'Playfair Display',serif;color:#fff;font-size:1.3rem;margin-bottom:8px}

/* Pagination */
.gal-pager{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:24px;border-top:1px solid var(--bdr,rgba(255,255,255,.08));font-size:.8rem;color:var(--text2,#7a9bbf)}
.gal-pager-btns{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.gpbtn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border-radius:8px;border:1px solid var(--bdr,rgba(255,255,255,.08));background:var(--bg2,#0d2137);color:var(--text,#dce8f5);font-size:.82rem;text-decoration:none;transition:all .18s}
.gpbtn:hover{border-color:var(--gold,#faa307);color:var(--gold,#faa307);text-decoration:none}
.gpbtn.on{background:var(--gold,#faa307);border-color:var(--gold,#faa307);color:#000;font-weight:700}
.gpbtn-dots{color:var(--text2,#7a9bbf);padding:0 4px}

/* ── Lightbox ── */
.lb-overlay{position:fixed;inset:0;background:rgba(3,10,20,.96);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
.lb-overlay.on{display:flex;animation:lbIn .2s ease}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lb-close{position:absolute;top:18px;right:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:2}
.lb-close:hover{background:rgba(255,255,255,.18)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(250,163,7,.12);border:1px solid rgba(250,163,7,.25);color:var(--gold,#faa307);width:48px;height:72px;border-radius:10px;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:2}
.lb-nav:hover{background:rgba(250,163,7,.25)}
.lb-prev{left:16px}.lb-next{right:16px}
.lb-inner{max-width:900px;width:100%;display:flex;flex-direction:column;align-items:center;gap:16px;position:relative}
.lb-inner img{max-height:72vh;max-width:100%;border-radius:12px;object-fit:contain;display:block;transition:opacity .25s}
.lb-caption{text-align:center;max-width:680px}
.lb-cat{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold,#faa307);margin-bottom:5px}
.lb-title{font-family:'Playfair Display',serif;font-size:1.15rem;color:#fff;margin-bottom:5px}
.lb-text{font-size:.88rem;color:var(--text2,#7a9bbf);line-height:1.6;margin-bottom:5px}
.lb-date{font-size:.75rem;color:var(--text2,#7a9bbf);opacity:.65}
.lb-counter{position:absolute;top:-36px;right:0;font-size:.75rem;color:var(--text2,#7a9bbf);background:rgba(255,255,255,.06);padding:3px 10px;border-radius:10px}

@media(max-width:600px){
  .lb-prev{left:6px}.lb-next{right:6px}
  .lb-nav{width:36px;height:56px;font-size:1.3rem}
  .lb-inner img{max-height:60vh}
  .gal-grid{grid-template-columns:1fr 1fr;gap:10px}
}
@media(max-width:420px){.gal-grid{grid-template-columns:1fr}}
