/* ═══════════════════════════════════════
   GALLERY — DESTINY PLAYGROUND
   gallery.css — link on gallery.html only
   ═══════════════════════════════════════ */

/* ── HERO ── */
.gal-hero {
  position: relative; padding: 10rem 3rem 5rem; overflow: hidden;
}
.gal-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 70% at 25% 55%, rgba(201,168,76,.05) 0%, transparent 60%),
    radial-gradient(ellipse 45% 55% at 80% 25%, rgba(136,196,232,.025) 0%, transparent 55%),
    linear-gradient(180deg, #090806 0%, #0c0a07 60%, #090806 100%);
}
.gal-hero-grid {
  position: absolute; inset: 0; opacity: .03;
  background-image:
    linear-gradient(rgba(201,168,76,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,76,.5) 1px, transparent 1px);
  background-size: 50px 50px;
}
.gal-hero-inner { position: relative; max-width: 1400px; margin: 0 auto; }
.gal-hero-eyebrow {
  font-size: .68rem; letter-spacing: .38em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.2rem;
  display: flex; align-items: center; gap: 1rem;
}
.gal-hero-eyebrow::before { content: ''; width: 32px; height: .5px; background: var(--gold-dim); }
.gal-hero-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(2.4rem, 5.5vw, 4.5rem);
  font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  color: var(--white); line-height: 1.05; margin-bottom: 1.2rem;
}
.gal-hero-desc {
  font-size: 1rem; line-height: 1.9; color: var(--body-text);
  font-weight: 300; max-width: 560px; margin-bottom: 1.8rem;
}
.gal-hero-count {
  display: flex; align-items: baseline; gap: .55rem;
}
.gal-count-num {
  font-family: 'Cinzel', serif; font-size: 1.6rem; font-weight: 700;
  color: var(--gold); letter-spacing: .04em;
}
.gal-count-label {
  font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--muted);
}

/* ── MAIN GRID SECTION ── */
.gal-section {
  max-width: 1400px; margin: 0 auto;
  padding: 0 3rem 6rem;
}

/* ── MASONRY-STYLE GRID ── */
.gal-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 1.5px;
  background: var(--border);
}

/* ── GRID ITEM ── */
.gal-item {
  position: relative; overflow: hidden; cursor: pointer;
  background: rgba(201,168,76,.02);
  transition: background .25s;
  outline: none;
}
.gal-item:focus-visible { box-shadow: inset 0 0 0 2px var(--gold); }
.gal-item--wide { grid-column: span 2; }
.gal-item--tall { grid-row: span 2; }

.gal-item-inner {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.gal-item-inner img {
  width: 100%; height: 100%; object-fit: cover;
  opacity: .85; transition: opacity .35s, transform .5s;
  display: block;
}
.gal-item:hover .gal-item-inner img {
  opacity: 1; transform: scale(1.04);
}

/* Placeholder (shown when no image) */
.gal-placeholder {
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
  color: rgba(201,168,76,.15); font-size: 1.4rem;
  transition: color .25s;
  user-select: none;
}
.gal-item:hover .gal-placeholder { color: rgba(201,168,76,.28); }
.gal-placeholder-label {
  font-size: .6rem; letter-spacing: .2em; text-transform: uppercase;
  color: rgba(201,168,76,.18); font-size: .6rem;
}

/* Hover overlay */
.gal-item-overlay {
  position: absolute; inset: 0;
  background: rgba(9,8,6,.55);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: .5rem;
  opacity: 0; transition: opacity .22s;
}
.gal-item:hover .gal-item-overlay { opacity: 1; }
.gal-item-overlay-icon {
  font-size: 1.3rem; color: rgba(201,168,76,.6);
}
.gal-item-overlay-label {
  font-size: .6rem; letter-spacing: .28em; text-transform: uppercase; color: var(--gold);
}

/* corner accents on hover */
.gal-item::before, .gal-item::after,
.gal-item-inner::before, .gal-item-inner::after {
  content: ''; position: absolute; width: 12px; height: 12px;
  border-color: var(--gold); border-style: solid;
  opacity: 0; transition: opacity .22s; z-index: 2; pointer-events: none;
}
.gal-item::before    { top: 8px; left: 8px;   border-width: 1px 0 0 1px; }
.gal-item::after     { top: 8px; right: 8px;  border-width: 1px 1px 0 0; }
.gal-item-inner::before { bottom: 8px; left: 8px;  border-width: 0 0 1px 1px; }
.gal-item-inner::after  { bottom: 8px; right: 8px; border-width: 0 1px 1px 0; }
.gal-item:hover::before,
.gal-item:hover::after,
.gal-item:hover .gal-item-inner::before,
.gal-item:hover .gal-item-inner::after { opacity: 1; }

/* ── EMPTY STATE ── */
.gal-empty {
  display: flex; flex-direction: column; align-items: center;
  padding: 6rem 3rem; text-align: center;
  border: .5px solid rgba(201,168,76,.08);
  background: #0a0906;
}
.gal-empty-icon {
  font-size: 1.6rem; color: rgba(201,168,76,.15); margin-bottom: 1.4rem;
  animation: gal-breathe 4s ease-in-out infinite;
}
@keyframes gal-breathe { 0%,100%{opacity:1;} 50%{opacity:.3;} }
.gal-empty-title {
  font-family: 'Cinzel', serif; font-size: 1.1rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; color: var(--white);
  margin-bottom: .6rem;
}
.gal-empty-desc {
  font-size: .86rem; line-height: 1.8; color: var(--muted);
  font-weight: 300; max-width: 420px;
}

/* ── LIGHTBOX ── */
.gal-lightbox {
  position: fixed; inset: 0; z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .25s;
}
.gal-lightbox.open {
  opacity: 1; pointer-events: all;
}

/* Scroll lock when lightbox is open */
body.gal-lb-open { overflow: hidden; }

.gal-lightbox-backdrop {
  position: absolute; inset: 0;
  background: rgba(7,6,9,.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  cursor: pointer;
}

/* Frame */
.gal-lb-frame {
  position: relative; z-index: 1;
  display: flex; flex-direction: column;
  max-width: min(1100px, 92vw);
  width: 100%;
  transform: translateY(12px);
  transition: transform .3s ease;
}
.gal-lightbox.open .gal-lb-frame {
  transform: translateY(0);
}

/* Image wrap */
.gal-lb-img-wrap {
  position: relative;
  background: rgba(12,10,7,.8);
  border: .5px solid rgba(201,168,76,.15);
  min-height: 300px;
  max-height: 72vh;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  opacity: 0; transition: opacity .3s .05s;
}
.gal-lb-img-wrap.loaded { opacity: 1; }

.gal-lb-img-wrap img {
  max-width: 100%; max-height: 72vh;
  object-fit: contain; display: block;
}

/* Lightbox placeholder */
.gal-lb-placeholder {
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
  padding: 5rem 3rem; color: rgba(201,168,76,.2); font-size: 2.5rem;
}
.gal-lb-ph-label {
  font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(201,168,76,.2); font-size: .68rem;
}

/* Corner accents on lightbox frame */
.gal-lb-img-wrap::before,
.gal-lb-img-wrap::after {
  content: ''; position: absolute; width: 16px; height: 16px;
  border-color: rgba(201,168,76,.35); border-style: solid; z-index: 2;
}
.gal-lb-img-wrap::before { top: 10px; left: 10px;  border-width: 1px 0 0 1px; }
.gal-lb-img-wrap::after  { bottom: 10px; right: 10px; border-width: 0 1px 1px 0; }

/* Meta strip */
.gal-lb-meta {
  display: flex; align-items: center; gap: 1.5rem;
  padding: .9rem 1.2rem;
  background: rgba(10,9,6,.9);
  border: .5px solid rgba(201,168,76,.1);
  border-top: none;
}
.gal-lb-caption {
  font-family: 'Cinzel', serif; font-size: .88rem; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase; color: var(--white); flex: 1;
}
.gal-lb-sub {
  font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted);
}
.gal-lb-counter {
  font-size: .6rem; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(201,168,76,.4); white-space: nowrap; flex-shrink: 0;
}

/* Nav buttons */
.gal-lb-close,
.gal-lb-prev,
.gal-lb-next {
  position: fixed;
  background: none; border: .5px solid rgba(201,168,76,.18); cursor: pointer;
  color: var(--muted); transition: all .18s;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.gal-lb-close {
  top: 1.5rem; right: 1.5rem;
  width: 40px; height: 40px; font-size: .9rem;
}
.gal-lb-prev,
.gal-lb-next {
  top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; font-size: 1rem;
}
.gal-lb-prev { left: 1.5rem; }
.gal-lb-next { right: 1.5rem; }

.gal-lb-close:hover,
.gal-lb-prev:hover,
.gal-lb-next:hover {
  color: var(--gold); border-color: rgba(201,168,76,.5);
  background: rgba(201,168,76,.06);
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .gal-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .gal-hero  { padding: 8rem 1.5rem 3rem; }
  .gal-section { padding: 0 1.5rem 4rem; }
  .gal-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 180px;
  }
  .gal-item--wide { grid-column: span 2; }
  .gal-item--tall { grid-row: span 1; }
  .gal-lb-prev { left: .5rem; }
  .gal-lb-next { right: .5rem; }
  .gal-lb-close { top: .75rem; right: .75rem; }
}

@media (max-width: 480px) {
  .gal-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 200px;
  }
  .gal-item--wide { grid-column: span 1; }
}