#archive-main {
  width: 100%;
  height: 100%;
  min-height: 0;
  position: relative;
}

#nav {
  position: relative;
  z-index: 50;
}

#dark-mode-button {
  z-index: 51;
}

#archive-motion-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 4;
  overflow: hidden;
  opacity: 1;
  transition: opacity 700ms ease;
}

body.archive-piece-transitioning #archive-motion-layer,
body.archive-piece-mode #archive-motion-layer {
  opacity: 0;
}

.archive-lsq {
  position: absolute;
  width: var(--square-size);
  height: var(--square-size);
  pointer-events: none;
  will-change: transform, opacity;
}

html.dark-mode .archive-lsq {
  background: rgba(255, 255, 255, 1);
}

html:not(.dark-mode) .archive-lsq {
  background: rgba(0, 0, 0, 1);
}

#archive-view,
#archive-piece-view {
  width: 100%;
  height: 100%;
  min-height: 0;
}

#archive-view {
  position: relative;
  z-index: 1;
  transition: opacity 260ms ease;
}

#archive-piece-view {
  position: absolute;
  inset: 0;
  z-index: 6;
  display: none;
  opacity: 0;
  pointer-events: none;
}

body.archive-piece-transitioning #archive-view {
  opacity: 1;
  pointer-events: none;
}

body.archive-piece-mode #archive-view {
  visibility: hidden;
  pointer-events: none;
}

body.archive-piece-transitioning #archive-piece-view {
  display: block;
  opacity: 0;
  pointer-events: none;
}

body.archive-piece-mode #archive-piece-view {
  display: block;
  opacity: 1;
  pointer-events: auto;
  transition: opacity 220ms ease;
}

#archive-scroll {
  position: fixed;
  inset: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
  z-index: 1;
  pointer-events: none;
}

#archive-scroll::-webkit-scrollbar {
  display: none;
}

#archive-track {
  min-width: max-content;
  height: 100%;
  display: flex;
  align-items: flex-end;
  gap: var(--gutter);
  padding-left: var(--page-margin);
  padding-right: var(--page-margin);
  padding-bottom: var(--page-margin);
  box-sizing: border-box;
  pointer-events: auto;
}

.archive-item {
  flex: 0 0 auto;
  opacity: 0.16;
  transform: translateY(0);
  transition:
    opacity 480ms ease,
    transform 480ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.archive-item.is-visible {
  opacity: 1;
}

.archive-item.is-filter-hidden {
  display: none !important;
}

.archive-item.is-filter-exit {
  opacity: 0 !important;
  transform: translateY(18px) !important;
  pointer-events: none !important;
}

.archive-item.is-filter-enter {
  opacity: 0 !important;
  transform: translateY(-18px) !important;
}

body.archive-piece-transitioning .archive-item {
  opacity: 0 !important;
}

.archive-item-link {
  display: inline-flex;
  align-items: flex-end;
  justify-content: flex-start;
  text-decoration: none;
  color: inherit;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

.archive-image {
  display: block;
  width: auto;
  height: auto;
  max-width: clamp(180px, 18vw, 33vw);
  max-height: 42vh;
  opacity: 0;
  filter: blur(16px);
  transform: scale(1.015);
}

.archive-image.is-loaded {
  opacity: 1;
  filter: blur(0);
  transform: scale(1);
  transition:
    opacity 420ms ease,
    filter 520ms ease,
    transform 520ms ease;
}

#archive-shared-transition-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 90;
}

#archive-shared-transition-image {
  position: fixed;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  display: block;
  object-fit: contain;
  object-position: right bottom;
  opacity: 0;
  will-change: left, top, width, height, opacity;
}

#archive-shared-transition-image.is-active {
  opacity: 1;
}

#piece-main {
  width: 100%;
  height: 100%;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--gutter);
  align-items: stretch;
}

#piece-left,
#piece-right {
  min-width: 0;
  min-height: 0;
  height: 100%;
}

#piece-left {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
}

#piece-text-stack {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 24px;
  padding-bottom: 16px;
  box-sizing: border-box;
}

#piece-nav-row,
#piece-prompt,
#piece-caption,
#piece-date,
#piece-author,
.piece-nav-button,
.piece-nav-slash {
  font-family: "HelveticaNeueRoman", Helvetica, Arial, sans-serif;
  font-size: calc(var(--text-size) + 4px);
  line-height: 1;
  letter-spacing: var(--tracking);
  color: var(--fg);
  text-transform: uppercase;
}

#piece-nav-row {
  display: flex;
  align-items: center;
  gap: 18px;
  opacity: 0;
  transition: opacity 220ms ease;
}

.piece-nav-group {
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.piece-nav-return {
  flex: 0 0 auto;
}

body.archive-piece-mode #piece-nav-row {
  opacity: 1;
}

.piece-nav-button {
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  color: var(--fg);
  cursor: pointer;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  opacity: 1;
  transition: opacity 180ms ease;
}

.piece-nav-button:hover,
.piece-nav-button:focus-visible {
  opacity: 0.45;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  outline: none;
}

.piece-nav-slash {
  margin: 0 2px;
  user-select: none;
}

#piece-prompt {
  max-width: 100%;
}

#piece-caption {
  max-width: 50%;
  white-space: pre-line;
}

#piece-meta-row {
  display: flex;
  align-items: center;
  gap: 48px;
  flex-wrap: wrap;
}

#piece-right {
  min-width: 0;
  min-height: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  overflow: hidden;
  opacity: 1;
}

#piece-image-wrap {
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  padding-bottom: 16px;
  box-sizing: border-box;
  overflow: hidden;
}

#piece-image {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: right bottom;
  flex: 0 0 auto;
  opacity: 1;
}

#piece-image.is-transition-hidden {
  opacity: 0 !important;
}

.piece-word {
  display: inline-block;
  opacity: 0;
  transition: opacity 70ms linear;
  will-change: opacity;
}

.piece-word.is-visible {
  opacity: 1;
}

@media (max-width: 1100px) {
  #piece-main {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
    row-gap: var(--gutter);
  }

  #piece-left {
    align-items: flex-start;
  }

  #piece-text-stack {
    gap: 18px;
    padding-bottom: 0;
  }

  #piece-right {
    justify-content: flex-start;
  }

  #piece-image-wrap {
    justify-content: flex-start;
    padding-bottom: 16px;
  }

  #piece-image {
    max-width: 100%;
    max-height: 60vh;
    object-position: left bottom;
  }
}

/* ---------------------------------
   ARCHIVE FILTER UI
---------------------------------- */

#archive-filter-ui {
  position: fixed;
  inset: 0;
  z-index: 80;
  pointer-events: none;
}

#archive-filter-ui.is-hidden-for-piece {
  opacity: 0;
  transform: translateY(14px);
  pointer-events: none;
  transition:
    opacity 220ms ease,
    transform 220ms ease;
}

#archive-filter-trigger-wrap,
#archive-filter-chooser,
#archive-filter-active {
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%) translateY(0);
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 4px;
  width: max-content;
  max-width: calc(100vw - 32px);
}

#archive-filter-trigger-wrap {
  opacity: 1;
  pointer-events: none;
  transition:
    opacity 220ms ease,
    transform 220ms ease;
}

#archive-filter-trigger {
  width: 52px;
  min-width: 52px;
  height: 48px;
  min-height: 48px;
  padding: 0;
  display: grid;
  place-items: center;
  cursor: pointer;
  pointer-events: auto;
}

#archive-filter-trigger:hover,
#archive-filter-trigger:focus-visible {
  outline: none;
}

.archive-filter-trigger-icon-stack {
  position: relative;
  width: 22px;
  height: 22px;
  display: block;
}

.archive-filter-trigger-icon {
  position: absolute;
  inset: 0;
  width: 22px;
  height: 22px;
  object-fit: contain;
  opacity: 0;
  transform: translateY(3px);
  transition:
    opacity 220ms ease,
    transform 220ms ease;
  pointer-events: none;
}

.archive-filter-trigger-icon.is-visible {
  opacity: 1;
  transform: translateY(0);
}

#archive-filter-panel {
  position: fixed;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}

#archive-filter-chooser,
#archive-filter-active {
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 220ms ease,
    transform 220ms ease;
}

#archive-filter-chooser {
  transform: translateX(-50%) translateY(10px);
}

#archive-filter-active {
  transform: translateX(-50%) translateY(10px);
}

#archive-filter-ui[data-filter-stage="collapsed"] #archive-filter-trigger-wrap {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: none;
}

#archive-filter-ui[data-filter-stage="collapsed"] #archive-filter-panel {
  opacity: 0;
  pointer-events: none;
}

#archive-filter-ui[data-filter-stage="chooser"] #archive-filter-trigger-wrap,
#archive-filter-ui[data-filter-stage="active"] #archive-filter-trigger-wrap {
  opacity: 0;
  transform: translateX(-50%) translateY(10px);
  pointer-events: none;
}

#archive-filter-ui[data-filter-stage="chooser"] #archive-filter-panel,
#archive-filter-ui[data-filter-stage="active"] #archive-filter-panel {
  opacity: 1;
  pointer-events: none;
}

#archive-filter-ui[data-filter-stage="chooser"] #archive-filter-chooser {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

#archive-filter-ui[data-filter-stage="active"] #archive-filter-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.archive-filter-box {
  height: 48px;
  min-height: 48px;
  border: 1px solid rgba(0, 0, 0, 0.26);
  background: rgba(255, 255, 255, 0.82);
  color: var(--fg);
  box-sizing: border-box;
  font-family: "HelveticaNeueRoman", Helvetica, Arial, sans-serif;
  font-size: 15px;
  line-height: 1;
  letter-spacing: var(--tracking);
  text-transform: uppercase;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

html.dark-mode .archive-filter-box {
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(0, 0, 0, 0.72);
}

.archive-filter-choice,
.archive-filter-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  cursor: pointer;
  white-space: nowrap;
  transition:
    transform 180ms ease,
    opacity 180ms ease,
    border-color 180ms ease,
    color 180ms ease;
}

.archive-filter-choice:hover,
.archive-filter-choice:focus-visible,
#archive-filter-back:hover,
#archive-filter-back:focus-visible,
#archive-filter-close:hover,
#archive-filter-close:focus-visible {
  transform: translateY(-4px);
  outline: none;
}

#archive-filter-close,
#archive-filter-back {
  min-width: 52px;
  width: 52px;
  padding: 0;
  flex: 0 0 52px;
}

#archive-filter-active-panel {
  flex: 0 1 auto;
  min-width: 0;
  width: auto;
  max-width: calc(100vw - 32px - 52px - 8px);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 7px 0 6px;
  overflow: hidden;
}

#archive-filter-active-panel[data-panel-type="prompt"] {
  min-width: 280px;
  width: min(420px, calc(100vw - 32px - 52px - 8px));
}

#archive-filter-active-panel[data-panel-type="search"],
#archive-filter-active-panel[data-panel-type="date"] {
  flex: 0 0 auto;
}

.archive-filter-active-inner {
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.archive-filter-prompt-scroll {
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
  white-space: nowrap;
  padding-top: 2px;
  padding-bottom: 2px;
}

.archive-filter-prompt-scroll::-webkit-scrollbar {
  display: none;
}

.archive-filter-prompt-option {
  border: none;
  background: transparent;
  margin: 0;
  padding: 2px 0 1px;
  color: rgba(0, 0, 0, 0.34);
  font: inherit;
  letter-spacing: inherit;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.05;
  display: inline-flex;
  align-items: center;
  transition:
    color 180ms ease,
    opacity 180ms ease;
}

html.dark-mode .archive-filter-prompt-option {
  color: rgba(255, 255, 255, 0.34);
}

.archive-filter-prompt-option:hover,
.archive-filter-prompt-option:focus-visible {
  color: var(--fg);
  outline: none;
}

.archive-filter-prompt-option.is-selected {
  opacity: 1 !important;
}

html:not(.dark-mode) .archive-filter-prompt-option.is-selected {
  color: #000 !important;
}

html.dark-mode .archive-filter-prompt-option.is-selected {
  color: #fff !important;
}

.archive-filter-prompt-option::before {
  content: "[ ";
}

.archive-filter-prompt-option::after {
  content: " ]";
}

.archive-filter-input-wrap {
  width: auto;
  min-width: 0;
  display: block;
}

.archive-filter-date-shell,
.archive-filter-search-shell {
  width: max-content;
  min-width: 0;
  display: grid;
  grid-template-columns: auto auto auto;
  align-items: center;
  column-gap: 0;
  line-height: 1;
}

.archive-filter-date-shell .shell-left,
.archive-filter-date-shell .shell-right,
.archive-filter-search-shell .shell-left,
.archive-filter-search-shell .shell-right {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transform: translateY(1px);
}

.archive-filter-date-shell .shell-input,
.archive-filter-search-shell .shell-input {
  min-width: 0;
  display: flex;
  align-items: center;
  width: auto;
}

.archive-filter-bracket-input {
  width: 100%;
  min-width: 0;
  border: none;
  background: transparent;
  color: var(--fg);
  font: inherit;
  letter-spacing: inherit;
  text-transform: uppercase;
  outline: none;
  padding: 0;
  margin: 0;
  line-height: 1;
  appearance: none;
  -webkit-appearance: none;
  transform: translateY(1px);
}

#archive-filter-active-panel[data-panel-type="date"] .archive-filter-bracket-input {
  width: 10ch;
}

#archive-filter-active-panel[data-panel-type="search"] .archive-filter-bracket-input {
  width: 17ch;
}

.archive-filter-bracket-input::placeholder {
  color: rgba(0, 0, 0, 0.34);
  opacity: 1;
}

html.dark-mode .archive-filter-bracket-input::placeholder {
  color: rgba(255, 255, 255, 0.34);
}

.archive-filter-empty {
  color: rgba(0, 0, 0, 0.42);
}

html.dark-mode .archive-filter-empty {
  color: rgba(255, 255, 255, 0.38);
}

@media (pointer: coarse) and (max-width: 900px) {
  body {
    --page-margin: 16px;
    --gutter: 16px;
  }

  #app {
    display: block;
    padding: var(--page-margin);
  }

  #nav {
    position: fixed;
    top: 18px;
    left: 16px;
    right: 16px;
    width: auto;
    z-index: 50;
  }

  #archive-main {
    position: fixed;
    top: 16px;
    right: 16px;
    bottom: 16px;
    left: 16px;
    width: auto;
    height: auto;
    min-height: 0;
  }

  #archive-motion-layer {
    display: none !important;
  }

  #archive-view,
  #archive-piece-view {
    position: absolute;
    inset: 0;
    width: auto;
    height: auto;
    min-height: 0;
  }

  #archive-scroll {
    position: absolute;
    inset: 0;
    overflow-x: hidden;
    overflow-y: auto;
    pointer-events: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  #archive-scroll::-webkit-scrollbar {
    display: none;
  }

  #archive-track {
    min-width: 0;
    width: 100%;
    height: auto;
    min-height: max-content;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-rows: clamp(140px, 19svh, 210px);
    gap: 34px 8px;
    align-items: stretch;
    align-content: start;
    padding: 52px 0 24px;
    box-sizing: border-box;
    pointer-events: auto;
  }

  .archive-item {
    opacity: 0;
    transform: translateY(12px);
    transition:
      opacity 560ms ease,
      transform 560ms cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
    min-width: 0;
    min-height: 0;
  }

  .archive-item.is-visible {
    opacity: 1;
    transform: translateY(0);
  }

  .archive-item-link {
    display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
    overflow: hidden;
  }

  .archive-item:nth-child(3n + 1) .archive-item-link {
    justify-content: flex-start;
  }

  .archive-item:nth-child(3n + 2) .archive-item-link {
    justify-content: center;
  }

  .archive-item:nth-child(3n) .archive-item-link {
    justify-content: flex-end;
  }

  .archive-image {
    display: block;
    flex: 0 0 auto;
    width: clamp(92px, 24vw, 116px);
    height: auto;
    max-width: none;
    max-height: none;
    object-fit: contain;
    opacity: 0;
    filter: blur(16px);
    transform: scale(1.015);
  }

  .archive-image.is-loaded {
    opacity: 1;
    filter: blur(0);
    transform: scale(1);
    transition:
      opacity 420ms ease,
      filter 520ms ease,
      transform 520ms ease;
  }

  body.archive-piece-transitioning .archive-item {
    opacity: 0 !important;
    transform: translateY(0) !important;
  }

  #archive-piece-view {
    overflow: hidden;
  }

  #piece-main {
    width: 100%;
    height: 100%;
    min-height: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    row-gap: 16px;
    padding-top: 52px;
    padding-bottom: 0;
    box-sizing: border-box;
    overflow: hidden;
  }

  #piece-right,
  #piece-left {
    width: 100%;
    min-width: 0;
    min-height: 0;
  }

  #piece-right {
    order: 1;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: hidden;
  }

  #piece-left {
    order: 2;
    display: flex;
    align-items: stretch;
    justify-content: flex-start;
    min-height: 0;
    overflow: hidden;
  }

  #piece-image-wrap {
    width: 100%;
    max-width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    min-height: 0;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 0;
    overflow: hidden;
  }

  #piece-image {
    width: auto;
    height: auto;
    max-width: none;
    max-height: none;
    object-fit: contain;
    object-position: left top;
    flex: 0 0 auto;
  }

  #piece-text-stack {
    width: 100%;
    min-height: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0;
    padding-bottom: 0;
    overflow: hidden;
  }

  #piece-nav-row,
  #piece-prompt,
  #piece-caption,
  #piece-date,
  #piece-author,
  .piece-nav-button,
  .piece-nav-slash {
    font-size: calc(var(--text-size) + 3px);
  }

  #piece-nav-row {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 0;
  }

  .piece-nav-group {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
  }

  #piece-prompt,
  #piece-caption,
  #piece-meta-row {
    width: 100%;
    max-width: 100%;
  }

  #piece-prompt {
    margin-top: auto;
    margin-bottom: 10px;
  }

  #piece-caption {
    white-space: pre-line;
    margin-top: 0;
    margin-bottom: 10px;
  }

  #piece-meta-row {
    margin-top: 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 16px;
    flex-wrap: nowrap;
  }

  #piece-date,
  #piece-author {
    width: auto;
    max-width: none;
    flex: 0 0 auto;
  }

  #archive-shared-transition-image {
    object-position: left top;
  }

  #archive-filter-trigger-wrap,
  #archive-filter-chooser,
  #archive-filter-active {
    bottom: max(12px, env(safe-area-inset-bottom, 0px));
    max-width: calc(100vw - 24px);
  }

  .archive-filter-box {
    height: 48px;
    min-height: 48px;
    font-size: 14px;
  }

  #archive-filter-active-panel {
    max-width: calc(100vw - 24px - 52px - 6px);
    padding: 0 6px 0 5px;
  }

  #archive-filter-active-panel[data-panel-type="prompt"] {
    width: min(320px, calc(100vw - 24px - 52px - 6px));
    min-width: min(320px, calc(100vw - 24px - 52px - 6px));
  }

  .archive-filter-choice {
    padding: 0 13px;
  }

  .archive-filter-choice:hover,
  .archive-filter-choice:focus-visible,
  #archive-filter-back:hover,
  #archive-filter-back:focus-visible,
  #archive-filter-close:hover,
  #archive-filter-close:focus-visible {
    transform: none;
  }

  .archive-filter-prompt-scroll {
    gap: 10px;
    padding-top: 3px;
    padding-bottom: 2px;
  }

  .archive-filter-prompt-option {
    padding-top: 3px;
  }

  .archive-filter-prompt-option:hover,
  .archive-filter-prompt-option:focus-visible {
    color: inherit;
  }

  html:not(.dark-mode) .archive-filter-prompt-option:not(.is-selected) {
    color: rgba(0, 0, 0, 0.34);
  }

  html.dark-mode .archive-filter-prompt-option:not(.is-selected) {
    color: rgba(255, 255, 255, 0.34);
  }

  html:not(.dark-mode) .archive-filter-prompt-option.is-selected {
    color: #000 !important;
  }

  html.dark-mode .archive-filter-prompt-option.is-selected {
    color: #fff !important;
  }

  #archive-filter-active-panel[data-panel-type="search"] .archive-filter-bracket-input {
    width: 18ch;
  }
}

@media (pointer: coarse) and (max-width: 600px) {
  #archive-track {
    grid-auto-rows: clamp(132px, 18svh, 190px);
    gap: 28px 6px;
    padding-top: 50px;
    padding-bottom: 20px;
  }

  .archive-image {
    width: clamp(84px, 25vw, 104px);
  }

  #piece-main {
    row-gap: 14px;
    padding-top: 50px;
  }

  #piece-nav-row,
  #piece-prompt,
  #piece-caption,
  #piece-date,
  #piece-author,
  .piece-nav-button,
  .piece-nav-slash {
    font-size: calc(var(--text-size) + 2px);
  }

  #piece-prompt {
    margin-bottom: 8px;
  }

  #piece-caption {
    margin-bottom: 8px;
  }

  #piece-meta-row {
    gap: 14px;
  }

  #archive-filter-trigger-wrap,
  #archive-filter-chooser,
  #archive-filter-active {
    bottom: max(10px, env(safe-area-inset-bottom, 0px));
  }
}