/* ==========================================================================
   Project: Visual Works
   ========================================================================== */

.p-visual {
  padding: var(--section-padding-sp) 0;
  background-color: var(--color-white);
}

@media (min-width: 768px) {
  .p-visual {
    padding: var(--section-padding-pc) 0;
  }
}

.p-visual__head {
  margin-bottom: var(--space-md);
}

@media (min-width: 768px) {
  .p-visual__head {
    margin-bottom: var(--space-xl);
  }
}

.p-visual__more {
  margin-top: var(--space-lg);
  text-align: right;
}

.p-visual__more .c-btn--fv {
  display: inline-flex;
}

@media (max-width: 767px) {
  .p-visual__more {
    margin-top: var(--space-sm);
    text-align: center;
  }
}

.p-visual__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  list-style: none;
  margin: 0;
  padding: 0;
}

@media (min-width: 768px) {
  .p-visual__grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

.p-visual__item {
  min-width: 0;
}

.p-visual__figure {
  margin: 0;
  aspect-ratio: 1 / 1;
  border-radius: 2px;
  overflow: hidden;
  background: linear-gradient(160deg, #f4faf9, #dceeea);
}

.p-visual__img,
.p-visual__figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-visual__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.p-visual__placeholder-num {
  font-family: var(--font-script);
  font-size: clamp(28px, 8vw, 48px);
  color: rgba(118, 199, 192, 0.35);
}

@media (hover: hover) {
  .p-visual__item:has(.p-visual__img):hover .p-visual__img {
    transform: scale(1.06);
    transition: transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
  }
}

.p-visual__img {
  transition: transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (prefers-reduced-motion: reduce) {
  .p-visual__img {
    transition: none;
  }

  .p-visual__item:hover .p-visual__img {
    transform: none;
  }
}
