@layer components {
  .image-upload {
    display: flex;
    flex-direction: column;
    gap: var(--block-space-half);
  }

  .image-upload__trigger {
    display: grid;
    inline-size: 100%;
    max-inline-size: min(100%, 16rem);
    place-items: stretch;
  }

  .image-upload__trigger--compact {
    max-inline-size: min(100%, 12rem);
  }

  .image-upload__trigger > * {
    grid-area: 1 / 1;
  }

  .image-upload__control-row {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
    gap: var(--inline-space-half);
  }

  .image-upload__frame {
    aspect-ratio: 4 / 5;
    background-color: var(--color-ink-lightest);
    border: 1px dashed var(--color-ink-medium);
    border-radius: 0.75rem;
    overflow: hidden;
    transition: border-color 100ms ease-out, box-shadow 100ms ease-out;
  }

  .image-upload__trigger:has(input[type="file"]:focus-visible) .image-upload__frame {
    border-color: var(--color-selected-dark);
    box-shadow: 0 0 0 1px var(--color-selected-dark);
  }

  .image-upload__image {
    block-size: 100%;
    display: block;
    inline-size: 100%;
    object-fit: cover;
  }

  .image-upload__meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--inline-space-half);
    justify-content: space-between;
    line-height: 1.3;
  }

  .image-upload__meta [data-upload-preview-target="fileName"] {
    color: var(--color-ink);
    font-weight: 600;
  }

  .image-upload__delete {
    white-space: nowrap;
  }

  .image-upload--full .image-upload__trigger {
    max-inline-size: none;
  }

  .image-upload--wide .image-upload__frame {
    aspect-ratio: 16 / 10;
  }
}
