.works {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: var(--spacer-30);
  align-items: center;
  padding-top: var(--spacer-50);
  padding-bottom: var(--spacer-30);
  padding-left: var(--spacer-40);
  padding-right: var(--spacer-40);
  position: relative;
  width: 100%;
}
.works .section_title--large .section_title__text {
  color: var(--color-black);
}
.works .section_title--large .section_title__caption {
  color: var(--color-black);
}
.works__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacer-20);
  align-items: flex-start;
  position: relative;
  flex-shrink: 0;
  width: 100%;
}
.works__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacer-20) var(--spacer-10);
  position: relative;
  flex-shrink: 0;
  width: 100%;
}
.works__link {
  display: flex;
  flex-direction: column;
  gap: var(--spacer-7);
  align-items: flex-start;
  position: relative;
  flex-shrink: 0;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.works__link:hover {
  opacity: 0.5;
}
.works__link-thumbnail {
  aspect-ratio: 16/9;
  display: block;
  object-fit: cover;
  object-position: center;
  border-radius: 3px;
  flex-shrink: 0;
  width: 100%;
  height: auto;
}
.works__link-desc {
  display: flex;
  flex-direction: column;
  gap: var(--spacer-4r5);
  align-items: flex-start;
  position: relative;
  flex-shrink: 0;
  width: 100%;
}
.works__link-title {
  font-weight: 500;
  line-height: 1.75;
  position: relative;
  flex-shrink: 0;
  color: var(--color-black);
  font-size: var(--fz-4);
  letter-spacing: -0.04em;
  width: 100%;
}
.works__categories {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacer-2);
  align-items: flex-start;
  position: relative;
  flex-shrink: 0;
  width: 100%;
}
.works__categories-link {
  border: 1px solid var(--color-black);
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacer-2r5);
  border-radius: 3px;
  position: relative;
  flex-shrink: 0;
}
.works__categories-link p {
  font-weight: 400;
  line-height: 1;
  position: relative;
  flex-shrink: 0;
  color: var(--color-black);
  font-size: var(--fz-3);
  white-space: nowrap;
  letter-spacing: -0.04em;
}

.category_lists {
  display: flex;
  gap: var(--spacer-4);
  align-items: center;
  position: relative;
  flex-shrink: 0;
  width: 100%;
}
.category_lists__link {
  flex: 1 1 0;
  border: 1px solid var(--color-black);
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 1px;
  min-width: 1px;
  padding: var(--spacer-4r5);
  border-radius: 3px;
  position: relative;
  flex-shrink: 0;
  text-decoration: none;
  background-color: transparent;
  transition: opacity 0.3s ease;
}
.category_lists__link:hover {
  opacity: 0.5;
}
.category_lists__link p {
  font-weight: 500;
  line-height: 1;
  position: relative;
  flex-shrink: 0;
  color: var(--color-black);
  font-size: var(--fz-4);
  white-space: nowrap;
  letter-spacing: -0.04em;
}
.category_lists__link--active {
  background-color: var(--color-black);
  border-color: var(--color-black);
}
.category_lists__link--active p {
  color: var(--color-white);
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-shrink: 0;
  width: 100%;
}
.pagination .nav-links ul.page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacer-3);
  width: 100%;
}
.pagination .nav-links ul.page-numbers li {
  height: 3rem;
  width: 2.5rem;
}
.pagination .nav-links ul.page-numbers li .page-numbers {
  font-family: var(--font-eng);
  font-weight: 500;
  color: var(--color-black);
  font-size: var(--fz-4);
  text-align: center;
  letter-spacing: 0.02em;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-black);
  border-radius: 3px;
}
.pagination .nav-links ul.page-numbers li .page-numbers:not(.current) {
  transition: opacity 0.3s ease;
}
.pagination .nav-links ul.page-numbers li .page-numbers:not(.current):hover {
  opacity: 0.5;
}
.pagination .nav-links ul.page-numbers li .current {
  background-color: var(--color-black);
  color: var(--color-white);
}
.pagination .nav-links ul.page-numbers li .next {
  border: unset;
}
.pagination .nav-links ul.page-numbers li .next svg {
  width: 1.5rem;
  height: 1.5rem;
}
.pagination .nav-links ul.page-numbers li .prev {
  border: unset;
}
.pagination .nav-links ul.page-numbers li .prev svg {
  width: 1.5rem;
  height: 1.5rem;
}

.contact__inner {
  background-color: var(--color-light_gray);
}
.contact__desc-jp {
  color: var(--color-black);
}
.contact__desc-en {
  color: var(--color-black);
  opacity: 0.4;
}
.contact .nav_external__path {
  stroke: var(--color-black);
}

.single__thumbnail {
  padding: 0 var(--spacer-7);
  padding-top: var(--header-height);
}
.single__thumbnail-img {
  aspect-ratio: 16/9;
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
  border-radius: 6px;
}
.single__content {
  margin-top: var(--spacer-20);
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.single__content-inner {
  width: 62.5rem;
}
.single__content-title {
  width: 100%;
  margin-bottom: var(--spacer-8);
}
.single__content-title h1 {
  color: var(--color-black);
  font-size: var(--fz-8);
  line-height: 1.5;
}
.single__content-desc {
  display: flex;
  flex-direction: column;
  gap: var(--spacer-5);
  margin-bottom: var(--spacer-14);
}
.single__content-desc p {
  color: var(--color-black);
  font-size: var(--fz-4);
  line-height: 2;
}
.single__content-index {
  margin-bottom: var(--spacer-25);
}
.single__content-index .single__category {
  margin-bottom: var(--spacer-7);
  display: flex;
  align-items: flex-start;
  gap: var(--spacer-2);
}
.single__content-index .single__category-title {
  color: var(--color-line-gray);
  font-family: var(--font-eng);
  font-size: var(--fz-4);
  font-weight: 400;
  letter-spacing: 0.02em;
  width: 5rem;
}
.single__content-index .single__category-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacer-4);
}
.single__content-index .single__category-item {
  position: relative;
  padding-left: var(--spacer-6);
}
.single__content-index .single__category-item::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.25rem;
  width: 0.5rem;
  height: 1px;
  transform: translateY(-50%);
  background-color: var(--color-line-gray);
}
.single__content-index .single__category-text {
  color: var(--color-line-gray);
  font-size: var(--fz-4);
  font-family: var(--font-eng);
  font-weight: 400;
  letter-spacing: 0.02em;
}
.single__content-index .single__url {
  display: flex;
  align-items: center;
  gap: var(--spacer-2);
}
.single__content-index .single__url-title {
  color: var(--color-line-gray);
  font-family: var(--font-eng);
  font-size: var(--fz-4);
  font-weight: 400;
  letter-spacing: 0.02em;
  width: 5rem;
}
.single__content-index .single__url-link {
  color: var(--color-line-gray);
  font-size: var(--fz-4);
  font-family: var(--font-eng);
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1;
  text-decoration: underline;
  position: relative;
  padding-left: var(--spacer-6);
  transition: opacity 0.3s ease;
}
.single__content-index .single__url-link:hover {
  opacity: 0.5;
}
.single__content-index .single__url-link::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.25rem;
  width: 0.5rem;
  height: 1px;
  transform: translateY(-50%);
  background-color: var(--color-line-gray);
}
.single__images {
  display: flex;
  flex-direction: column;
  gap: var(--spacer-10);
  align-items: flex-start;
  position: relative;
  flex-shrink: 0;
  width: 100%;
  margin-bottom: var(--spacer-30);
}
.single__images-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
  border-radius: 6px;
}
.single__page_link {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--spacer-30);
}
.single__page_link .page_link {
  border: 1px solid var(--color-black);
}
.single__page_link .page_link .page_link__text {
  color: var(--color-black);
}
.single__page_link .page_link .page_link__chevron svg path {
  stroke: var(--color-black);
}

@media screen and (max-width: 1279px) {
  .works {
    padding-top: var(--spacer-45);
    padding-left: var(--spacer-16);
    padding-right: var(--spacer-16);
    padding-bottom: var(--spacer-25);
    gap: var(--spacer-25);
  }
  .works__content {
    gap: var(--spacer-18);
  }
  .works__grid {
    gap: var(--spacer-18) var(--spacer-7);
  }
  .single__content {
    margin-top: var(--spacer-16);
  }
  .single__content-inner {
    width: 100%;
    padding-left: var(--spacer-20);
    padding-right: var(--spacer-20);
  }
  .single__content-index {
    margin-bottom: var(--spacer-20);
  }
  .single__images {
    margin-bottom: var(--spacer-20);
  }
  .single__page_link {
    margin-bottom: var(--spacer-20);
  }
}
@media screen and (max-width: 767px) {
  .works {
    width: 100%;
    padding-top: var(--spacer-30);
    padding-bottom: var(--spacer-20);
    padding-left: var(--spacer-5);
    padding-right: var(--spacer-5);
    gap: var(--spacer-16);
  }
  .works__content {
    gap: var(--spacer-12);
  }
  .works .category_lists {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacer-2);
  }
  .works .category_lists__link {
    min-width: unset;
    min-height: unset;
    padding: var(--spacer-4);
  }
  .works .category_lists__link p {
    font-size: var(--fz-3r5);
  }
  .works__grid {
    grid-template-columns: repeat(1, 1fr);
    gap: var(--spacer-12);
  }
  .works__link {
    gap: var(--spacer-5);
  }
  .works__link-desc {
    gap: var(--spacer-4);
  }
  .works__link-title {
    font-size: var(--fz-3r5);
  }
  .works__categories {
    flex-wrap: wrap;
  }
  .works__categories-link {
    padding: var(--spacer-2);
  }
  .works__categories-link p {
    font-size: var(--fz-3);
  }
  .single__thumbnail {
    padding-left: var(--spacer-5);
    padding-right: var(--spacer-5);
  }
  .single__thumbnail-img {
    border-radius: 3px;
  }
  .single__content {
    margin-top: var(--spacer-8);
  }
  .single__content-inner {
    padding-left: var(--spacer-7);
    padding-right: var(--spacer-7);
  }
  .single__content-title {
    margin-bottom: var(--spacer-5);
  }
  .single__content-title h1 {
    font-size: var(--fz-6);
  }
  .single__content-desc {
    gap: var(--spacer-4);
    margin-bottom: var(--spacer-10);
  }
  .single__content-desc p {
    font-size: var(--fz-3r5);
  }
  .single__content-index {
    margin-bottom: var(--spacer-14);
  }
  .single__content .single__category {
    margin-bottom: var(--spacer-5);
  }
  .single__content .single__category-title {
    font-size: var(--fz-3r5);
    width: 4rem;
  }
  .single__content .single__category-text {
    font-size: var(--fz-3r5);
  }
  .single__content .single__category-item {
    padding-left: var(--spacer-5);
  }
  .single__content .single__category-list {
    gap: var(--spacer-3);
  }
  .single__content .single__url-title {
    font-size: var(--fz-3r5);
    width: 4rem;
  }
  .single__content .single__url-link {
    font-size: var(--fz-3r5);
    padding-left: var(--spacer-5);
  }
  .single__images {
    gap: var(--spacer-6);
    margin-bottom: var(--spacer-16);
  }
  .single__images-img {
    border-radius: 3px;
  }
  .single__page_link {
    margin-bottom: var(--spacer-16);
  }
  .single__page_link .page_link {
    line-height: 1;
    gap: var(--spacer-6);
    padding: var(--spacer-5) var(--spacer-5) var(--spacer-5) var(--spacer-6);
  }
  .single__page_link .page_link__text {
    font-size: var(--fz-4);
  }
  .single__page_link .page_link__chevron {
    width: 1.25rem;
    height: 1.25rem;
  }
}

/*# sourceMappingURL=page.css.map */
