/* ============ ALBUM HERO ============ */
.album-hero{
  padding:160px 48px 64px;
  max-width:1400px;
  margin:0 auto;
}
.album-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:0.75rem;
  color:var(--ink-dim);
  letter-spacing:0.05em;
  margin-bottom:20px;
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  opacity:0;
  animation:fadeUp 0.8s ease 0.2s forwards;
}
.album-meta span:first-child{color:var(--accent);}
.album-title{
  font-family:'Archivo',sans-serif;
  font-weight:100;
  font-size:clamp(2.5rem, 7vw, 5.5rem);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin-bottom:20px;
  opacity:0;
  animation:fadeUp 0.8s ease 0.1s forwards;
}
.album-title em{font-style:normal; font-weight:900; color:var(--accent);}
.album-desc{
  font-size:1.05rem;
  color:var(--ink-dim);
  max-width:600px;
  line-height:1.7;
  opacity:0;
  animation:fadeUp 0.8s ease 0.3s forwards;
}

/* ============ ALBUM GRID ============ */
.album-grid{
  padding:0 48px 120px;
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
}
.album-photo{
  position:relative;
  overflow:hidden;
  border-radius:2px;
  background:var(--bg-soft);
  cursor:pointer;
}
.album-photo img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  filter:grayscale(8%) brightness(0.95);
  transition:transform 0.8s cubic-bezier(.16,1,.3,1), filter 0.6s ease;
}
.album-photo:hover img{
  transform:scale(1.04);
  filter:grayscale(0%) brightness(1);
}

/* Default size spans — override per-photo with utility classes */
.album-photo{ grid-column:span 6; aspect-ratio:4/3; }
.album-photo.span-4{ grid-column:span 4; }
.album-photo.span-8{ grid-column:span 8; }
.album-photo.span-12{ grid-column:span 12; }
.album-photo.portrait{ aspect-ratio:3/4; }
.album-photo.square{ aspect-ratio:1/1; }
.album-photo.wide{ aspect-ratio:16/9; }

/* ============ ALBUM NAV (prev/next) ============ */
.album-nav{
  max-width:1400px;
  margin:0 auto;
  padding:0 48px 120px;
  display:flex;
  justify-content:space-between;
  gap:24px;
  border-top:1px solid var(--line);
  padding-top:48px;
}
.album-nav-link{
  text-decoration:none;
  color:var(--ink-dim);
  font-family:'JetBrains Mono',monospace;
  font-size:0.75rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  display:flex;
  flex-direction:column;
  gap:8px;
  transition:color 0.3s ease;
}
.album-nav-link:hover{color:var(--accent);}
.album-nav-link .nav-album-title{
  font-family:'Archivo',sans-serif;
  font-weight:500;
  font-size:1.4rem;
  text-transform:none;
  letter-spacing:normal;
  color:var(--ink);
}
.album-nav-link.next{text-align:right; align-items:flex-end;}

/* ============ LIGHTBOX ============ */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(14,14,14,0.96);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:1000;
  padding:48px;
}
.lightbox.active{display:flex;}
.lightbox img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:2px;
}
.lightbox-close{
  position:absolute;
  top:32px; right:48px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.85rem;
  letter-spacing:0.1em;
  color:var(--ink);
  background:none;
  border:1px solid var(--line);
  padding:8px 16px;
  cursor:pointer;
  border-radius:2px;
  transition:border-color 0.3s ease, color 0.3s ease;
}
.lightbox-close:hover{border-color:var(--accent); color:var(--accent);}

/* ============ LIGHTBOX NAV ============ */
.lightbox-prev, .lightbox-next{
  position:absolute;
  top:50%; transform:translateY(-50%);
  background:rgba(14,14,14,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:var(--ink);
  font-size:1.4rem;
  padding:18px 22px;
  cursor:pointer;
  border-radius:2px;
  z-index:1001;
  transition:border-color 0.25s, background 0.25s, color 0.25s;
  line-height:1;
  font-family:'Archivo',sans-serif;
  font-weight:300;
}
.lightbox-prev{left:28px;}
.lightbox-next{right:28px;}
.lightbox-prev:hover, .lightbox-next:hover{
  border-color:var(--accent);
  background:rgba(217,142,43,0.18);
  color:var(--accent);
}

/* ============ RESPONSIVE ============ */
@media (max-width: 900px){
  .album-hero{padding:120px 24px 48px;}
  .album-grid{padding:0 24px 80px; grid-template-columns:repeat(2,1fr); gap:10px;}
  .album-photo{grid-column:span 1 !important; aspect-ratio:4/3 !important;}
  .album-photo.portrait{aspect-ratio:3/4 !important;}
  .album-photo.square{aspect-ratio:1/1 !important;}
  .album-nav{padding:0 24px 80px; padding-top:32px;}
  .album-nav-link .nav-album-title{font-size:1.1rem;}
  .lightbox{padding:24px;}
  .lightbox-close{top:16px; right:16px;}
}
