.fbgs-wrap{
  width:100%;
  box-sizing:border-box;
  position:relative;
}

.fbgs-controls{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin:10px 0 16px;
}
.fbgs-controls input[type="search"]{
  flex:1;
  min-width:220px;
  padding:10px 12px;
  border:1px solid #ddd;
  border-radius:12px;
}
.fbgs-controls select{
  padding:10px 12px;
  border:1px solid #ddd;
  border-radius:12px;
}

.fbgs-year{
  margin:26px 0 10px;
  font-size:15px;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  opacity:.75;
}

.fbgs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(170px, 1fr));
  gap:14px;
  align-items:stretch;
}

.fbgs-card{
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 8px 22px rgba(0,0,0,.06);
  transition:transform .18s ease, box-shadow .18s ease;
}
.fbgs-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(0,0,0,.10);
}

.fbgs-card-thumb{
  aspect-ratio:1 / 1;
  overflow:hidden;
}
.fbgs-card-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
}

.fbgs-card-meta{
  padding:12px 12px 14px;
}
.fbgs-card-meta .fbgs-title{
  font-weight:900;
  line-height:1.2;
  font-size:16px;
  margin:0;
}
.fbgs-card-meta .fbgs-date{
  margin-top:6px;
  font-size:14px;
  font-weight:700;
  opacity:.82;
}

.fbgs-photo{
  display:block;
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 8px 22px rgba(0,0,0,.06);
  transition:transform .18s ease, box-shadow .18s ease;
  aspect-ratio:1 / 1;
}
.fbgs-photo:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(0,0,0,.10);
}
.fbgs-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.fbgs-pagination{
  margin-top:18px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
}
.fbgs-pagination a{
  display:inline-flex;
  min-width:36px;
  height:36px;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  padding:0 12px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  text-decoration:none;
  color:inherit;
  font-weight:800;
  font-size:14px;
}
.fbgs-pagination .is-active{
  background:rgba(0,0,0,.08);
}

/* loading */
.fbgs-loading{
  position: sticky;   /* albo absolute */
  top: 0;
  height: 90px;
  inset: auto 0 auto 0;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.85);
  z-index: 5;
  border-radius: 14px;
}

.fbgs-spinner{
  width:44px;
  height:44px;
  border-radius:999px;
  border:4px solid rgba(0,0,0,.15);
  border-top-color: rgba(0,0,0,.55);
  animation: fbgsSpin .9s linear infinite;
}
@keyframes fbgsSpin { to { transform: rotate(360deg); } }
.fbgs-loading.is-done{ opacity:0; transition:opacity .3s; }

/* --- Lightbox --- */
.fbgs-no-scroll{ overflow:hidden; }

.fbgs-lightbox{
  position:fixed;
  inset:0;
  z-index:999999;
  display:none;
}
.fbgs-lightbox.is-open{ display:block; }

.fbgs-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.78);
}

.fbgs-lightbox-shell{
  position:absolute;
  inset:14px;
  display:grid;
  grid-template-rows:auto 1fr;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(15,15,15,.35);
  backdrop-filter: blur(10px);
}

/* top bar is always above hit-areas */
.fbgs-lightbox-top{
  position:relative;
  z-index:20; /* ✅ above everything */
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.12);
}

.fbgs-lightbox-meta{ color:#fff; min-width:0; }
.fbgs-lightbox-album{
  font-weight:1000;
  font-size:18px;
  letter-spacing:.01em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.fbgs-lightbox-sub{
  margin-top:4px;
  font-size:13px;
  opacity:.88;
  font-weight:800;
}

.fbgs-lightbox-close{
  position:relative;
  z-index:30; /* ✅ highest */
  width:46px;
  height:46px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.28);
  color:#fff;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:transform .15s ease, background .15s ease;
}
.fbgs-lightbox-close span{
  font-size:30px;
  line-height:1;
  transform: translateY(-1px);
}
.fbgs-lightbox-close:hover{
  background:rgba(0,0,0,.45);
  transform: translateY(-1px);
}

.fbgs-lightbox-figure{
  position:relative;
  margin:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:5;
}

.fbgs-lightbox-img{
  max-width:min(1280px, 96vw);
  max-height:calc(100vh - 150px);
  border-radius:18px;
  box-shadow:0 18px 70px rgba(0,0,0,.45);
  background:#000;
  transition:filter .15s ease;
}
.fbgs-lightbox-img.is-loading{
  filter: blur(6px) brightness(.92);
}

.fbgs-lightbox-cap{
  position:absolute;
  bottom:16px;
  left:50%;
  transform:translateX(-50%);
  max-width: min(980px, 92vw);
  padding:12px 14px;
  border-radius:16px;
  color:#fff;
  font-size:14px;
  font-weight:800;
  background:rgba(0,0,0,.40);
  border:1px solid rgba(255,255,255,.14);
  text-align:center;
  opacity:.96;
  z-index:10;
}

/* ✅ Hit areas start BELOW the top bar, so they never cover X */
.fbgs-lightbox-hit{
  position:absolute;
  top:72px;          /* ✅ below top bar */
  bottom:0;
  width:22%;
  border:0;
  padding:0;
  margin:0;
  background:transparent;
  cursor:pointer;
  z-index:8;         /* below top bar + close */
}
.fbgs-hit-left{
  left:0;
  background: linear-gradient(to right, rgba(0,0,0,.30), rgba(0,0,0,0));
  opacity: 0;
}
.fbgs-hit-right{
  right:0;
  background: linear-gradient(to left, rgba(0,0,0,.30), rgba(0,0,0,0));
  opacity: 0;
}

/* Big arrows */
.fbgs-lightbox-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:74px;
  height:74px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.22);
  background:rgba(0,0,0,.18);
  color:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .15s ease, background .15s ease;
  z-index:15; /* above hit areas */
}
.fbgs-lightbox-nav span{
  font-size:56px;
  line-height:1;
  transform: translateY(-3px);
  color:#fff;
  text-shadow: 0 10px 26px rgba(0,0,0,.55);
}
.fbgs-lightbox-prev{ left:22px; }
.fbgs-lightbox-next{ right:22px; }
.fbgs-lightbox-nav:hover{
  background:rgba(0,0,0,.32);
  transform:translateY(-50%) scale(1.03);
}

/* Mobile */
/* ===== FBGS Lightbox: Mobile fix (fullscreen + safe sizing) ===== */
@media (max-width: 640px){
  .fbgs-lightbox-shell{
    inset: 0 !important;
    border-radius: 0 !important;
  }

  .fbgs-lightbox-top{
    position: sticky;
    width: 100vw;
    top: 0;
    padding: 12px 12px;
    z-index: 30; /* top bar always above */
  }

  .fbgs-lightbox-close{
    width: 44px;
    height: 44px;
    border-radius: 14px;
  }

  /* Make the hit areas start below top bar and not too wide */
  .fbgs-lightbox-hit{
    top: 64px !important;
    width: 24% !important;
  }

  .fbgs-lightbox-figure{
    padding: 10px !important;
    align-items: center;
    justify-content: center;
  }

  /* The key part: do NOT use 100vh math, just fit container */
  .fbgs-lightbox-img{
    max-width: 96vw !important;
    max-height: 72vh !important; /* safer than calc(100vh - ...) on mobile */
    width: auto !important;
    height: auto !important;
    border-radius: 14px !important;
  }

  .fbgs-lightbox-cap{
    position: static !important;
    transform: none !important;
    margin: 10px auto 12px auto !important;
    max-width: 92vw !important;
    font-size: 13px !important;
    border-radius: 14px !important;
  }

  .fbgs-lightbox-nav{
    top: auto !important;
    bottom: 18px !important;
    transform: none !important;
    width: 54px !important;
    height: 54px !important;
    z-index: 20 !important;
  }

  .fbgs-lightbox-prev{ left: 12px !important; }
  .fbgs-lightbox-next{ right: 12px !important; }

  .fbgs-lightbox-nav span{
    font-size: 40px !important;
    transform: translateY(-2px) !important;
  }
}

