body.gfl-public::before{
  background-image:var(--gfl-topo-url);
}

.gfl-gallery-header{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  width:min(100%, var(--gfl-container-max));
  margin:0 auto;
  padding:14px 18px 6px;
}

.gfl-gallery-brand{
  display:inline-flex;
  width:132px;
  min-width:112px;
}

.gfl-gallery-brand img{
  width:100%;
  height:auto;
}

.gfl-gallery-nav{
  display:flex;
  align-items:center;
  gap:6px;
  max-width:100%;
  overflow-x:auto;
  scrollbar-width:none;
}

.gfl-gallery-nav::-webkit-scrollbar{display:none}

.gfl-gallery-nav a{
  flex:0 0 auto;
  border:1px solid color-mix(in srgb, var(--gfl-primary-light) 26%, transparent);
  border-radius:999px;
  padding:8px 11px;
  color:var(--gfl-text);
  font-size:13px;
  font-weight:900;
  line-height:1;
  text-decoration:none;
  text-transform:uppercase;
}

.gfl-gallery-nav a[aria-current="page"],
.gfl-gallery-nav a:hover{
  background:var(--gfl-primary-light);
  color:var(--gfl-primary-dark);
}

.gfl-gallery-shell{
  position:relative;
  z-index:1;
  width:min(100%, var(--gfl-container-max));
  margin:0 auto;
  padding:12px 18px 44px;
}

.archive-hero,
.album-hero,
.gallery-empty{
  display:grid;
  gap:18px;
  margin:10px 0 18px;
  padding:22px;
  border:1px solid var(--gfl-surface-border);
  border-radius:18px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--gfl-surface) 86%, transparent), color-mix(in srgb, var(--gfl-primary-dark) 82%, transparent)),
    var(--gfl-surface);
  box-shadow:var(--gfl-shadow);
}

.album-hero{
  align-items:end;
}

.eyebrow{
  margin:0 0 8px;
  color:var(--gfl-secondary-light);
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.archive-hero h1,
.album-hero h1{
  max-width:900px;
  margin:0;
  color:var(--gfl-heading);
  font-family:var(--font-heading);
  font-size:3.35rem;
  font-weight:900;
  line-height:.82;
  overflow-wrap:anywhere;
}

.album-lead{
  max-width:720px;
  margin:16px 0 0;
  color:var(--gfl-muted);
  font-size:1.0625rem;
}

.album-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.album-meta span{
  border:1px solid var(--gfl-separator);
  border-radius:999px;
  padding:8px 12px;
  background:color-mix(in srgb, var(--gfl-primary-light) 10%, transparent);
  color:var(--gfl-text);
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

.album-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

.album-card{
  display:grid;
  grid-template-columns:116px minmax(0, 1fr);
  min-height:136px;
  overflow:hidden;
  border:1px solid color-mix(in srgb, var(--gfl-primary-light) 38%, transparent);
  border-radius:18px;
  background:var(--gfl-secondary-dark);
  color:var(--gfl-text);
  text-decoration:none;
  box-shadow:var(--gfl-shadow);
}

.album-card:hover .album-card-media img{
  transform:scale(1.04);
}

.album-card-media{
  position:relative;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:var(--gfl-primary-dark);
}

.album-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .2s ease;
}

.album-card-placeholder{
  color:var(--gfl-primary-light);
  font-family:var(--font-heading);
  font-size:42px;
  font-weight:900;
}

.album-card-body{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
  min-width:0;
  padding:16px;
}

.album-card-body strong{
  color:var(--gfl-primary-light);
  font-family:var(--font-heading);
  font-size:2rem;
  font-weight:900;
  line-height:.9;
  overflow-wrap:anywhere;
}

.album-card-body > span:last-child{
  color:var(--gfl-muted);
  font-weight:700;
}

.photo-grid{
  column-count:1;
  column-gap:12px;
}

.photo-card{
  display:block;
  width:100%;
  margin:0 0 12px;
  padding:0;
  overflow:hidden;
  border:1px solid var(--gfl-surface-border);
  border-radius:14px;
  background:var(--gfl-surface);
  color:var(--gfl-text);
  cursor:pointer;
  text-align:left;
  break-inside:avoid;
  box-shadow:0 10px 28px rgba(0,0,0,.16);
}

.photo-card img{
  width:100%;
  height:auto;
  background:color-mix(in srgb, var(--gfl-primary-dark) 70%, #000 30%);
}

.photo-card span{
  display:block;
  padding:10px 12px;
  color:var(--gfl-muted);
  font-size:13px;
  font-weight:700;
}

.photo-card:focus-visible{
  outline:none;
  box-shadow:var(--gfl-focus-ring);
}

.gallery-empty h1,
.gallery-empty h2{
  margin:0;
  color:var(--gfl-heading);
  font-size:2rem;
  line-height:.94;
  text-transform:uppercase;
}

.gallery-empty code{
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.72em;
  overflow-wrap:anywhere;
}

.gallery-button{
  justify-self:start;
  border-radius:999px;
  padding:11px 15px;
  background:var(--gfl-btn-bg);
  color:var(--gfl-btn-text);
  font-weight:900;
  text-decoration:none;
}

.lightbox{
  position:fixed;
  inset:0;
  z-index:100;
  display:grid;
  grid-template-columns:44px minmax(0, 1fr) 44px;
  align-items:center;
  gap:4px;
  padding:14px;
  background:rgba(0,0,0,.88);
}

.lightbox[hidden]{display:none}

.lightbox figure{
  display:grid;
  gap:10px;
  min-width:0;
  margin:0;
}

.lightbox img{
  width:100%;
  max-height:78vh;
  object-fit:contain;
}

.lightbox figcaption{
  color:#fff;
  font-weight:700;
  text-align:center;
}

.lightbox button{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:#fff;
  cursor:pointer;
  font-size:34px;
  line-height:1;
}

.lightbox-close{
  position:absolute;
  top:12px;
  right:12px;
}

@media (min-width:640px){
  .gfl-gallery-brand{width:180px}
  .archive-hero,
  .album-hero,
  .gallery-empty{padding:32px}
  .archive-hero h1,
  .album-hero h1{font-size:5.25rem}
  .album-card-body strong{font-size:2.9rem}
  .album-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .album-card{grid-template-columns:1fr}
  .album-card-media{aspect-ratio:4 / 3}
  .photo-grid{column-count:2;column-gap:14px}
}

@media (min-width:900px){
  .gfl-gallery-header{padding-top:18px}
  .archive-hero,
  .album-hero,
  .gallery-empty{padding:42px}
  .archive-hero h1,
  .album-hero h1{font-size:8.25rem}
  .album-lead{font-size:1.25rem}
  .gallery-empty h1,
  .gallery-empty h2{font-size:4.25rem}
  .album-hero{grid-template-columns:minmax(0, 1fr) auto}
  .album-grid{grid-template-columns:repeat(3, minmax(0, 1fr))}
  .photo-grid{column-count:3;column-gap:16px}
}
