.gallery-hero{
    padding:28px 0 10px;
}

.gallery-hero-inner{
    max-width:860px;
}

.kicker{
    display:inline-block;
    font-weight:900;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--brand-gold);
    margin-bottom:14px;
    font-size:12px;
}

.lead{
    font-size:18px;
    max-width:62ch;
    color:rgba(244,246,251,.88);
}

.gallery-wrap .container{
    padding-top:10px;
    padding-bottom:24px;
}

/* Controls */
.gallery-controls{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:10px 0 18px;
}

.chip{
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.02);
    color:rgba(244,246,251,.85);
    padding:10px 12px;
    border-radius:999px;
    font-weight:800;
    cursor:pointer;
}

.chip:hover{
    color:var(--brand-gold);
    border-color:rgba(197,139,42,.35);
}

.chip.active{
    color:#0b0c0f;
    background:linear-gradient(135deg, #e2c27a, var(--brand-gold), var(--brand-gold-dark));
    border-color:transparent;
}

/* Grid */
.gallery-grid{
    display:grid;
    gap:14px;
    grid-template-columns:repeat(3, 1fr);
}

@media (max-width: 980px){
    .gallery-grid{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 560px){
    .gallery-grid{ grid-template-columns:1fr; }
}

/* Category badge */
.gallery-badge{
    position:absolute;
    top:10px;
    left:10px;
    padding:6px 10px;
    font-size:11px;
    font-weight:900;
    letter-spacing:.12em;
    text-transform:uppercase;
    border-radius:999px;
    background:rgba(11,12,15,.85);
    color:var(--brand-gold);
    border:1px solid rgba(197,139,42,.45);
    backdrop-filter:blur(4px);
}

.gallery-card{
    text-align:left;
    border:1px solid rgba(255,255,255,.06);
    background:rgba(255,255,255,.02);
    border-radius:16px;
    overflow:hidden;
    cursor:pointer;
    padding:0;
}

.gallery-card:hover{
    border-color:rgba(197,139,42,.25);
}

.gallery-thumb{
    position: relative;
    aspect-ratio: 4 / 3;
    overflow:hidden;
    background:#0b0c0f;
}

.gallery-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    transform:scale(1.02);
    transition:transform .18s ease;
    filter:saturate(.9) contrast(1.05) brightness(.75);
}

.gallery-card:hover .gallery-thumb img{
    transform:scale(1.06);
}

.gallery-info{
    padding:12px 12px 14px;
}

.gallery-title{
    font-weight:900;
    margin-bottom:4px;
}

.gallery-meta{
    font-size:12px;
    letter-spacing:.10em;
    text-transform:uppercase;
    color:rgba(244,246,251,.60);
}

/* Empty */
.gallery-empty{
    padding:18px;
    border:1px dashed rgba(255,255,255,.14);
    border-radius:16px;
    background:rgba(255,255,255,.02);
}
.gallery-empty code{
    color:rgba(244,246,251,.9);
}

/* Lightbox */
.lightbox{
    display:none;
}
body.lightbox-open{
    overflow:hidden;
}
body.lightbox-open .lightbox{
    display:block;
    position:fixed;
    inset:0;
    z-index:80;
}

.lightbox-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.65);
}

.lightbox-panel{
    position:absolute;
    inset: 5%;
    max-width:1100px;
    margin:0 auto;
    background:rgba(11,12,15,.98);
    border:1px solid rgba(255,255,255,.10);
    border-radius:18px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
}

@media (max-width: 700px){
    .lightbox-panel{ inset: 4%; }
}

.lightbox-close{
    position:absolute;
    top:10px;
    right:10px;
    width:44px;
    height:44px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.04);
    color:rgba(244,246,251,.9);
    font-size:26px;
    cursor:pointer;
}

.lightbox-media{
    flex:1;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#0b0c0f;
}

.lightbox-media img{
    max-width:100%;
    max-height:100%;
    object-fit:contain;
}

.lightbox-caption{
    padding:14px 16px;
    border-top:1px solid rgba(255,255,255,.08);
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    gap:12px;
    flex-wrap:wrap;
}

.lightbox-title{
    font-weight:900;
}

.lightbox-meta{
    font-size:12px;
    letter-spacing:.10em;
    text-transform:uppercase;
    color:rgba(244,246,251,.60);
}

.lightbox-actions{
    position:absolute;
    inset:0;
    pointer-events:none;
}

.lightbox-nav{
    pointer-events:auto;
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:48px;
    height:48px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.04);
    color:rgba(244,246,251,.9);
    font-size:30px;
    cursor:pointer;
}

#prevBtn{ left:12px; }
#nextBtn{ right:12px; }


