.gallery {
  display: grid;
}

.gallery-showcase {
  position: relative;
}

.gallery-showcase__gallery {
  margin-top: clamp(-9rem, -11vw, -6rem);
  position: relative;
  z-index: 1;
}

.gallery-showcase--compact .gallery-showcase__gallery {
  margin-top: 0;
}

.gallery-showcase--compact .public-gallery {
  padding-top: var(--space-small);
}

.public-gallery {
  --gallery-gap: 28px;
  --gallery-edge-gap: calc(var(--gallery-gap) * 2);

  display: block;
  overflow: clip;
  padding: 76px var(--gallery-edge-gap) 108px;
  position: relative;
}

.public-gallery::before {
  background: linear-gradient(
    180deg,
    oklch(var(--lch-canvas) / 0) 0%,
    oklch(var(--lch-canvas) / 0.72) 18%,
    oklch(var(--lch-canvas) / 0.98) 34%,
    oklch(var(--lch-canvas) / 0.97) 52%,
    oklch(var(--lch-canvas) / 0.84) 72%,
    oklch(var(--lch-canvas) / 0.36) 90%,
    oklch(var(--lch-canvas) / 0) 100%
  );
  content: "";
  height: 640px;
  inset: -220px 0 auto;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.public-gallery::after {
  background:
    radial-gradient(circle at 18% 18%, oklch(var(--lch-blue-light) / 0.16), transparent 34%),
    radial-gradient(circle at 82% 0%, oklch(var(--lch-orange-medium) / 0.14), transparent 38%);
  content: "";
  inset: -156px 0 auto;
  height: 440px;
  pointer-events: none;
  position: absolute;
  z-index: 0;
}

.public-gallery__grid {
  align-items: start;
  display: grid;
  gap: var(--gallery-gap);
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin: 0 auto;
  position: relative;
  width: 100%;
  z-index: 0;
}

.public-gallery__grid--masonry-ready {
  display: block;
}

.public-gallery__grid--masonry-ready .public-gallery__card {
  margin: 0;
}

.public-gallery__card {
  background: linear-gradient(180deg, oklch(var(--lch-white) / 0.02), transparent), var(--color-canvas-light);
  border: 1px solid oklch(var(--lch-white) / 0.08);
  border-radius: 0.6rem;
  box-shadow: var(--box-shadow-cluster);
  color: inherit;
  display: block;
  isolation: isolate;
  margin: var(--gallery-stagger, 0) 0 0;
  min-width: 0;
  overflow: hidden;
  position: relative;
  text-decoration: none;
  width: 100%;
}

.public-gallery__card:nth-child(5n + 1) {
  --gallery-stagger: 0px;
}

.public-gallery__card:nth-child(5n + 2) {
  --gallery-stagger: 168px;
}

.public-gallery__card:nth-child(5n + 3) {
  --gallery-stagger: 0px;
}

.public-gallery__card:nth-child(5n + 4) {
  --gallery-stagger: 168px;
}

.public-gallery__card:nth-child(5n) {
  --gallery-stagger: 0px;
}

.public-gallery__frame {
  aspect-ratio: var(--gallery-width) / var(--gallery-height);
  background: var(--color-canvas-dark);
  overflow: hidden;
  position: relative;
}

.public-gallery__image {
  display: block;
  height: 100%;
  inset: 0;
  max-width: none;
  object-fit: cover;
  object-position: center 18%;
  position: absolute;
  width: 100%;
}

.public-gallery__frame-overlay {
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.public-gallery__caption {
  align-items: end;
  background: linear-gradient(180deg, transparent 46%, oklch(var(--lch-black) / 0.58));
  display: flex;
  padding: 0.72rem;
}

.public-gallery__caption-text {
  color: oklch(var(--lch-white));
  display: -webkit-box;
  font-family: var(--font-family-cartridge);
  font-size: var(--font-size-xxxx-small);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.16;
  overflow: hidden;
  text-shadow: 0 1px 8px oklch(var(--lch-black) / 0.72);
  text-wrap: balance;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.placeholder-picture {
  display: block;
  height: 100%;
  width: 100%;
}

.gallery-links {
  overflow: clip;
  padding-block: 4px;
  padding-inline: var(--space-large);
}

.gallery-links__grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-inline: auto;
  max-width: 980px;
}

.gallery-link-card {
  background:
    linear-gradient(180deg, oklch(var(--lch-white) / 0.84), oklch(var(--lch-canvas-light) / 0.96)),
    var(--color-canvas-light);
  border: 1px solid oklch(var(--lch-ink-light) / 0.82);
  border-radius: 0.75rem;
  box-shadow:
    inset 0 0 0 1px oklch(var(--lch-white) / 0.38),
    0 0.15em 0.25em -0.2em oklch(var(--lch-black) / 0.05),
    0 0.5em 1.1em -0.8em oklch(var(--lch-black) / 0.12),
    0 1em 1.8em -1.6em oklch(var(--lch-black) / 0.14);
  color: var(--color-ink);
  display: grid;
  gap: 16px;
  grid-template-rows: auto minmax(0, 1fr) auto;
  isolation: isolate;
  min-height: 100%;
  overflow: hidden;
  padding: 16px;
  position: relative;
  text-decoration: none;
}

.gallery-link-card--text-only {
  min-height: 220px;
}

.gallery-link-card__previews {
  align-items: stretch;
  background: linear-gradient(180deg, oklch(var(--lch-canvas-dark) / 0.42), oklch(var(--lch-canvas) / 0.18));
  border: 1px solid oklch(var(--lch-ink-light) / 0.52);
  border-radius: 0.6rem;
  box-shadow: inset 0 0 0 1px oklch(var(--lch-white) / 0.3);
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  min-height: 0;
  padding: 10px;
}

.gallery-link-card__preview {
  aspect-ratio: 5 / 7;
  background: var(--color-canvas-dark);
  border: 1px solid oklch(var(--lch-white) / 0.24);
  border-radius: 0.5rem;
  overflow: hidden;
}

.gallery-link-card__image {
  display: block;
  height: 100%;
  object-fit: cover;
  object-position: center 18%;
  width: 100%;
}

.gallery-link-card__content {
  display: grid;
  gap: 10px;
  min-height: 0;
  min-width: 0;
}

.gallery-link-card--text-only .gallery-link-card__content {
  align-content: center;
}

.gallery-link-card__title {
  color: inherit;
  font-family: var(--font-family-scorekard);
  font-size: var(--font-size-medium);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-tight);
  line-height: var(--line-height-tightest);
  text-wrap: balance;
}

.gallery-link-card__body {
  color: var(--color-ink-dark);
  font-size: var(--font-size-xx-small);
  letter-spacing: 0;
  line-height: var(--line-height-loose);
  text-wrap: pretty;
}

.gallery-link-card__footer {
  align-items: center;
  border-top: 1px solid oklch(var(--lch-ink-light) / 0.7);
  display: flex;
  gap: 12px;
  padding-top: 12px;
}

.gallery-link-card__action {
  color: var(--color-ink);
  font-size: var(--font-size-xxx-small);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-loose);
  line-height: var(--line-height-tight);
}

@media (prefers-color-scheme: dark) {
  .gallery-link-card {
    background:
      linear-gradient(180deg, oklch(var(--lch-white) / 0.05), oklch(var(--lch-canvas-light) / 0.94)),
      var(--color-canvas-light);
    border-color: oklch(var(--lch-white) / 0.12);
    box-shadow:
      inset 0 0 0 1px oklch(var(--lch-white) / 0.06),
      0 0.4em 1.4em -1em oklch(var(--lch-black) / 0.45),
      0 1em 2em -1.8em oklch(var(--lch-black) / 0.62);
  }

  .gallery-link-card__previews {
    background: linear-gradient(180deg, oklch(var(--lch-white) / 0.04), oklch(var(--lch-black) / 0.12));
    border-color: oklch(var(--lch-white) / 0.08);
    box-shadow: inset 0 0 0 1px oklch(var(--lch-white) / 0.04);
  }

  .gallery-link-card__preview {
    border-color: oklch(var(--lch-white) / 0.08);
  }

  .gallery-link-card__footer {
    border-top-color: oklch(var(--lch-white) / 0.1);
  }
}

@media (hover: hover) {
  .public-gallery__card {
    outline: 2px solid transparent;
    outline-offset: 2px;
    transition: outline-color var(--transition);
  }

  .public-gallery__card:focus,
  .public-gallery__card:hover {
    outline-color: oklch(var(--lch-blue-medium));
  }

  .gallery-link-card {
    outline: 2px solid transparent;
    outline-offset: 2px;
    transition: box-shadow var(--transition), outline-color var(--transition);
  }

  .gallery-link-card:focus,
  .gallery-link-card:hover {
    box-shadow:
      inset 0 0 0 1px oklch(var(--lch-white) / 0.42),
      0 0.25em 0.4em -0.25em oklch(var(--lch-black) / 0.08),
      0 0.8em 1.5em -1.1em oklch(var(--lch-black) / 0.18),
      0 1.4em 2.2em -2em oklch(var(--lch-black) / 0.18);
    outline-color: oklch(var(--lch-blue-medium));
  }
}

@media (max-width: 1100px) {
  .public-gallery__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .public-gallery {
    padding-top: 68px;
    padding-bottom: 96px;
  }

  .public-gallery::before {
    height: 520px;
    inset-block-start: -176px;
  }

  .public-gallery::after {
    height: 352px;
    inset-block-start: -116px;
  }

  .public-gallery__card:nth-child(5n + 1),
  .public-gallery__card:nth-child(5n + 2),
  .public-gallery__card:nth-child(5n + 3),
  .public-gallery__card:nth-child(5n + 4),
  .public-gallery__card:nth-child(5n) {
    --gallery-stagger: 0px;
  }

  .public-gallery__card:nth-child(4n + 2) {
    --gallery-stagger: 152px;
  }

  .public-gallery__card:nth-child(4n) {
    --gallery-stagger: 152px;
  }
}

@media (max-width: 860px) {
  .gallery-showcase__gallery {
    margin-top: -4rem;
  }

  .public-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .public-gallery {
    padding: 60px 32px 48px;
  }

  .public-gallery::before {
    height: 396px;
    inset-block-start: -128px;
  }

  .public-gallery::after {
    height: 276px;
    inset-block-start: -84px;
  }

  .public-gallery__card:nth-child(4n + 2),
  .public-gallery__card:nth-child(4n),
  .public-gallery__card:nth-child(4n + 3) {
    --gallery-stagger: 0px;
  }

  .public-gallery__card:nth-child(2n) {
    --gallery-stagger: 120px;
  }

  .gallery-links {
    padding-inline: 32px;
  }

  .gallery-links__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .gallery-showcase__gallery {
    margin-top: -2.75rem;
  }

  .public-gallery {
    padding-inline: 20px;
    padding-top: 44px;
  }

  .public-gallery__grid {
    grid-template-columns: 1fr;
  }

  .public-gallery::before {
    height: 316px;
    inset-block-start: -104px;
  }

  .public-gallery::after {
    height: 208px;
    inset-block-start: -64px;
  }

  .public-gallery__card:nth-child(2n) {
    --gallery-stagger: 0px;
  }

  .gallery-links {
    padding-inline: 20px;
  }

  .gallery-link-card {
    padding: 14px;
  }

  .gallery-link-card__previews {
    padding: 8px;
  }
}
