/* ===== NoraLee — archive.css (v1.2, responsive 2–3 cols on small) ===== */

:root{
  --gap: 15px;
}

/* Wrapper */
.archive-wrap{
  color: var(--fg);
}

/* ===== Titel wie About (ohne Stern) ===== */
.archive-title{
  position: sticky;
  top: calc(var(--header-h, 66px) + 8px);
  z-index: 2;
  text-align: center;
  margin: clamp(24px, 4vw, 48px) 0 clamp(28px, 5vw, 56px);
  mix-blend-mode: difference;
  color: #fff;
}
.archive-title h1 {
  margin: 0;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: .06em;
  line-height: .9;
  font-size: clamp(64px, 14vw, 300px);
}

.archive-title .sub{
  margin: 8px 0 0;
  font-size: 16px;
  letter-spacing: .12em;
}


/* ===== Grid ===== */
.archive-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
  padding-left: 15px;
  padding-right: 15px;
  margin-bottom: clamp(60px, 8vw, 120px);
}

.card a{ display:block; width:100%; height:100%; }
.card img{ width:100%; height:100%; object-fit:cover; display:block; }
.card .ph{
  width:100%; height:100%;
  display:grid; place-items:center;
  aspect-ratio:1/1; color:#111; font-size:12px; letter-spacing:.1em;
  background:#e6e6e6;
}

/* Aspect-Ratios */
.card.square img, .card.square .ph{ aspect-ratio:1/1; }
.card.wide   img, .card.wide   .ph{ aspect-ratio:4/3; }
.card.tall   img, .card.tall   .ph{ aspect-ratio:3/4; }

/* ===== Scroll-Animation ===== */
.reveal{
  opacity:0;
  transform: translateY(28px) scale(.985);
  transition: opacity .6s ease, transform .6s ease;
  transition-delay: var(--d, 0s);
  will-change: opacity, transform;
}
.reveal.in{
  opacity:1;
  transform: translateY(0) scale(1);
}

/* ===== Breakpoints ===== */
/* gross → 4 Spalten (default) */
@media (max-width: 1200px){
  /* etwas kompakter, 3 Spalten */
  .archive-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px){
  .archive-title{ top: calc(var(--header-h, 66px) + 6px); }
  .archive-grid{
    grid-template-columns: repeat(3, 1fr);   /* 3 Spalten halten bis ~760px */
    margin-bottom: clamp(40px, 10vw, 80px);
  }
}
/* ab ~Tablet/kleines Phone: 2 Spalten */
@media (max-width: 760px){
  .archive-grid{ grid-template-columns: repeat(2, 1fr); }
}
/* ganz klein: erst dann 1 Spalte */
@media (max-width: 420px){
  .archive-grid{ grid-template-columns: 1fr; }
}

/* Mehr Luft auf sehr grossen Screens (wie Single-Galerien) */
@media (min-width: 1440px){
  .archive-grid{ padding-left: 6vw; padding-right: 6vw; }
}
