.gallery-page{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.gallery-hero{
  margin-top:0;
  padding-top:20px;
  border-color:rgba(168,85,247,.24);
  background:
    radial-gradient(circle at top right, rgba(168,85,247,.14), transparent 32%),
    radial-gradient(circle at left center, rgba(216,180,254,.08), transparent 26%),
    linear-gradient(180deg, rgba(28,18,44,.98), rgba(12,15,20,.99));
  box-shadow:
    0 0 0 1px rgba(168,85,247,.08),
    0 12px 28px rgba(0,0,0,.20),
    0 0 18px rgba(168,85,247,.10);
}

.gallery-title-row{
  position:relative;
  padding:0 0 12px;
  margin-bottom:6px;
}

.gallery-hero .gallery-title-row::before{
  content:none;
}

.gallery-hero .gallery-title-row::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,255,255,.96), rgba(255,255,255,.34) 62%, transparent 100%);
}

.gallery-page-title{
  margin:0;
  color:#ffffff;
}

.gallery-helper-copy{
  margin:6px 0 0;
  color:#dfe7ef;
  line-height:1.5;
  max-width:76ch;
}

.gallery-shell-copy{
  margin:0 0 10px;
  color:#dfe7ef;
  line-height:1.5;
  max-width:none;
  width:100%;
}

.gallery-shell{
  border-color:rgba(168,85,247,.20);
  background:
    radial-gradient(circle at top right, rgba(168,85,247,.10), transparent 32%),
    radial-gradient(circle at left center, rgba(59,130,246,.06), transparent 24%),
    linear-gradient(180deg, rgba(18,24,32,.98), rgba(12,15,20,.99));
  box-shadow:
    0 0 0 1px rgba(168,85,247,.08),
    0 12px 28px rgba(0,0,0,.22),
    0 0 18px rgba(168,85,247,.08);
}

.gallery-toolbar{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
  margin:0 0 18px;
  padding:14px 16px;
  border:1px solid rgba(168,85,247,.18);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(168,85,247,.08), rgba(168,85,247,.02)),
    linear-gradient(180deg, rgba(18,24,32,.98), rgba(12,15,20,.99));
}

.gallery-toolbar-copy{
  color:#dfe7ef;
  line-height:1.3;
}

.gallery-count-label{
  color:var(--muted);
  margin-right:6px;
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 320px));
  justify-content:center;
  gap:28px 30px;
  padding:10px 6px 4px;
}

.gallery-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(168,85,247,.10), rgba(168,85,247,.02) 20%, rgba(12,15,20,.98) 100%);
  box-shadow:
    0 0 0 1px rgba(168,85,247,.06),
    0 10px 26px rgba(0,0,0,.24);
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
  max-width:320px;
  margin:0 auto;
}

.gallery-card:hover{
  transform:translateY(-3px);
  border-color:rgba(168,85,247,.32);
  box-shadow:
    0 0 0 1px rgba(168,85,247,.12),
    0 14px 30px rgba(0,0,0,.28),
    0 0 18px rgba(168,85,247,.12);
}

.gallery-poster-button{
  display:block;
  width:100%;
  padding:0;
  margin:0;
  border:none;
  background:none;
  cursor:pointer;
  text-align:left;
}

.gallery-poster-frame{
  position:relative;
  aspect-ratio:2 / 3;
  overflow:hidden;
  margin:18px 18px 0;
  padding:14px;
  border-radius:10px;
  background:
    linear-gradient(135deg, #6b4a18 0%, #c89b3c 18%, #f2dd9b 34%, #9a6d26 52%, #5c3d12 100%);
  box-shadow:
    inset 0 0 0 2px rgba(62,40,10,.55),
    inset 0 0 0 8px rgba(201,160,72,.22),
    0 10px 22px rgba(0,0,0,.28);
}

.gallery-poster-frame::before{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(66,44,14,.55);
  pointer-events:none;
  z-index:2;
  box-shadow:
    inset 0 0 0 1px rgba(255,235,170,.12),
    0 0 0 1px rgba(0,0,0,.18);
}

.gallery-poster-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  position:relative;
  z-index:1;
  border:2px solid rgba(28,18,10,.70);
  box-shadow:
    0 6px 16px rgba(0,0,0,.28);
}

.gallery-card-meta{
  padding:14px 14px 16px;
}

.gallery-card-title{
  margin:0 0 8px;
  color:#fff;
  font-size:1rem;
  line-height:1.25;
}

.gallery-card-date{
  margin:0;
  color:#cdb7ef;
  font-size:.84rem;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.gallery-empty{
  padding:20px 0 4px;
  color:var(--muted);
}

.gallery-lightbox{
  position:fixed;
  inset:0;
  z-index:12000;
}

.gallery-lightbox[hidden]{
  display:none;
}

.gallery-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:#000000;
}

.gallery-lightbox-dialog{
  position:relative;
  z-index:2;
  width:max-content;
  max-width:92vw;
  margin:3vh auto 0;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}

.gallery-lightbox-frame{
  position:relative;
  display:inline-block;
  padding:18px;
  border-radius:10px;
  background:
    linear-gradient(135deg, #6b4a18 0%, #c89b3c 18%, #f2dd9b 34%, #9a6d26 52%, #5c3d12 100%);
  box-shadow:
    inset 0 0 0 2px rgba(62,40,10,.55),
    inset 0 0 0 8px rgba(201,160,72,.22),
    0 18px 38px rgba(0,0,0,.50);
}

.gallery-lightbox-frame::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(66,44,14,.55);
  pointer-events:none;
  z-index:2;
  box-shadow:
    inset 0 0 0 1px rgba(255,235,170,.12),
    0 0 0 1px rgba(0,0,0,.18);
}

.gallery-lightbox-image{
  width:auto;
  max-width:min(88vw, 720px);
  max-height:78vh;
  height:auto;
  display:block;
  position:relative;
  z-index:1;
  border:2px solid rgba(28,18,10,.70);
  box-shadow:
    0 6px 16px rgba(0,0,0,.28);
  background:#090b10;
}

.gallery-lightbox-meta{
  padding:14px 4px 0;
}

.gallery-lightbox-meta h3{
  margin:0 0 6px;
  color:#fff;
}

.gallery-lightbox-meta p{
  margin:0;
  color:#d8b4fe;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.gallery-lightbox-close{
  position:absolute;
  top:16px;
  right:18px;
  z-index:3;
  width:42px;
  height:42px;
  border:none;
  border-radius:999px;
  cursor:pointer;
  font-size:1.65rem;
  line-height:1;
  color:#fff;
  background:
    linear-gradient(180deg, rgba(168,85,247,.34), rgba(66,24,94,.94));
  box-shadow:
    0 8px 18px rgba(0,0,0,.28),
    0 0 0 1px rgba(168,85,247,.16);
}

@media (max-width:1000px){
  .gallery-grid{
    grid-template-columns:repeat(2, minmax(0, 300px));
    gap:24px;
  }
}

@media (max-width:640px){
  .gallery-grid{
    grid-template-columns:minmax(0, 320px);
    gap:22px;
    padding:6px 0 0;
  }

  .gallery-lightbox-dialog{
    width:min(94vw, 860px);
    margin:3vh auto 0;
    padding:14px;
  }
}
