/* photos.css — Individual photo category page + sibling navigation */

@layer components {
  @scope (.project) {
    .project-cover {
      margin-block-end: 2.5rem;
      border-radius: var(--rounded-sm);

      img {
        object-fit: cover;
        inline-size: 100%;
        max-height: 750px;

        @media (min-width: 768px) {
          border-radius: 0.125rem;
        }
      }
    }

    .project-info {
      padding-inline: var(--page-padding);
      margin-block-start: 6rem;
      margin-block-end: 6rem;
      font-size: var(--text-lg);
      font-family: var(--font-norm);

      & > * {
        font-size: var(--text-lg);
        font-family: var(--font-norm);
        font-weight: 300;
      }

      h1 {
        text-transform: uppercase;
      }

      .project-description {
        margin-block-start: 2rem;
        max-width: 52rem;
      }

      .project-collaboration {
        margin-block-start: 1rem;
        max-width: 52rem;
      }

      @media (min-width: 1280px) {
        padding-inline: 0;
      }
    }

    .project-meta__details {
      font-size: var(--text-base);
      line-height: 30px;
    }

    .project-summary {
      inline-size: 100%;

      @media (min-width: 1024px) {
        max-inline-size: 470px;
        justify-self: center;
      }
    }

    /* Comma-separated collaborator / tag lists */
    .list-item::after {
      content: ",";
    }

    .list-item:last-child::after {
      content: "";
    }
  }

  @scope (.photo-siblings) {
    :scope {
      margin-block: 4rem;
      max-inline-size: var(--max-width);
    }

    .photo-siblings__list {
      container-type: inline-size;
      display: grid;
      grid-template-columns: 1fr;
      overflow: clip;
      margin-inline: auto;
      inline-size: 100%;

      @container (min-width: 640px) {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
      }
    }

    .photo-siblings__item {
      position: relative;
      block-size: 15rem;
      overflow: hidden;

      @media (min-width: 1024px) {
        block-size: auto;
      }

      img {
        inline-size: 100%;
      }
    }

    .photo-siblings__caption {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      align-items: flex-end;
      padding-inline: 2rem;
      padding-block: 1rem;
      font-size: var(--text-2xl);
      font-weight: 500;
      font-family: var(--font-norm);
      color: var(--color-white);

      @media (min-width: 768px) {
        align-items: center;
      }

      a {
        &::after {
          content: "";
          position: absolute;
          inset: 0;
        }
      }
    }
  }
}
