/* ----------------------------------------------------------------------------------------------------
works
---------------------------------------------------------------------------------------------------- */
/* header
----------------------------------------------------------------------*/
header {
  background-image: none;
}

/* deco
----------------------------------------------------------------------*/
.deco img {
  position: absolute;
  z-index: var(--layer-back);
}
.deco img:nth-child(1) {
  top: 26rem;
  left: -0.75rem;
}
.deco img:nth-child(2) {
  top: -0.75rem;
  left: 50%;
  translate: -50% 0;
}
.deco img:nth-child(3) {
  top: 6rem;
  right: -1.5rem;
}

@media screen and (min-width: 60rem) {
  .deco img:nth-child(1) {
    top: 26rem;
    left: -2rem;
    width: 12.5rem;
    height: 12.5rem;
  }
  .deco img:nth-child(2) {
    top: -5.75rem;
    left: 22.5rem;
    translate: 0 0;
    width: 8.5rem;
    height: 8.5rem;
  }
  .deco img:nth-child(3) {
    top: 12.5rem;
    right: -5rem;
    width: 11.25rem;
    height: 11.25rem;
  }
}
/* mv
----------------------------------------------------------------------*/
.mv h1 {
  margin-bottom: 1rem;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2.375rem;
  letter-spacing: 0.04em;
  word-break: keep-all;
  overflow-wrap: break-word;
}
.mv .mv__category {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}
.mv .mv__category li {
  padding: 0.5rem 0.75rem;
  border-radius: 100vmax;
  background-color: #ecf8fc;
  color: #656f84;
  line-height: 1.25rem;
}
.mv .mv__thumbnail img {
  width: 100%;
  height: 31.25rem;
  -o-object-fit: contain;
     object-fit: contain;
}
.mv .mv__lead {
  margin-bottom: 4rem;
  font-weight: 500;
  line-height: 1.5rem;
}

@media screen and (min-width: 60rem) {
  .mv {
    position: relative;
  }
  .mv::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    width: 100vw;
    height: 17.5rem;
    background-color: #fff;
  }
  .mv h1 {
    margin-bottom: 1.25rem;
    font-size: 1.75rem;
    line-height: 2.75rem;
  }
  .mv .mv__category {
    margin-bottom: 1.5rem;
  }
  .mv .mv__thumbnail {
    margin-inline: auto;
    padding-inline: 1.25rem;
    width: min(100%, 75rem);
  }
  .mv .mv__thumbnail img {
    height: 36.25rem;
    border-radius: 2.5rem;
  }
  .mv .mv__lead {
    margin-bottom: 5rem;
  }
}
/* worksContent
----------------------------------------------------------------------*/
.worksContent {
  padding-block: 5rem 2.5rem;
  background-color: #fff;
}
.worksContent h2 {
  margin-block: 5rem 2.5rem;
  padding: 0.75rem 1rem;
  border-left: 1.25rem solid #60d7ed;
  background-color: #f5fcff;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.04em;
}
.worksContent h3 {
  display: inline-block;
  margin-block: 2.5rem 1.5rem;
  padding: 0.25rem 0.5rem;
  background-color: #ffee22;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.04em;
}
.worksContent h4 {
  position: relative;
  margin-block: 2.5rem 1.5rem;
  padding-left: 1.5rem;
  font-weight: 700;
  line-height: 1.375rem;
  letter-spacing: 0.04em;
}
.worksContent h4::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0.5rem;
  height: 100%;
  border-radius: 0.125rem;
  background-image: linear-gradient(#ffe553, #ffc11a);
}
.worksContent p {
  line-height: 1.5rem;
}
.worksContent img {
  margin-block: 2.5rem 1.5rem;
  width: 100%;
  height: 27.875rem;
  border-radius: 1.25rem;
  -o-object-fit: cover;
     object-fit: cover;
}

/* worksPages
----------------------------------------------------------------------*/
.worksPages {
  padding-block: 3rem 4rem;
  background-color: #fcfdfd;
}
.worksPages .worksPages__contents {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: space-between;
  -moz-column-gap: 0.5rem;
       column-gap: 0.5rem;
  margin-bottom: 3rem;
}
.worksPages .worksPages__heading {
  display: flex;
  align-items: baseline;
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
  margin-bottom: 0.75rem;
  color: #676c77;
  font-family: "Quicksand", sans-serif;
  line-height: 1.5;
}
.worksPages .worksPages__heading span {
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: 0.1em;
  text-transform: capitalize;
}
.worksPages .worksPages__heading p {
  font-size: 0.75rem;
}
.worksPages .worksPages__btn {
  display: flex;
  justify-content: center;
}

.worksPagesItem {
  display: grid;
  width: 100%;
  padding: 0.75rem 0.75rem 0.5rem;
  border: 1px solid #d5dbe6;
  border-radius: 0.75rem;
  transition: box-shadow 0.2s;
}
@media (any-hover: hover) {
  .worksPagesItem:hover {
    box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
  }
  .worksPagesItem:hover .worksPagesItem__thumbnail img {
    scale: 1.1;
  }
}
@media (any-hover: none) {
  .worksPagesItem:active {
    box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
  }
  .worksPagesItem:active .worksPagesItem__thumbnail img {
    scale: 1.1;
  }
}
.worksPagesItem .worksPagesItem__thumbnail {
  overflow: hidden;
  margin-bottom: 0.5rem;
  border-radius: 0.75rem;
}
.worksPagesItem .worksPagesItem__thumbnail img {
  width: 100%;
  aspect-ratio: 140/78;
  transition: scale 0.2s;
}
.worksPagesItem .worksPagesItem__title {
  font-weight: 500;
  font-size: 0.75rem;
  line-height: 1.5;
}
.worksPagesItem .worksPagesItem__tag {
  margin-bottom: 0.25rem;
}
.worksPagesItem .worksPagesItem__tag span {
  padding: 0.125rem 0.375rem;
  border-radius: 100vmax;
  background-color: #ecf8fd;
  color: #656f84;
  font-size: 0.75rem;
  line-height: 1.0625rem;
}
.worksPagesItem .worksPagesItem__btn {
  display: flex;
  justify-content: flex-end;
}
.worksPagesItem .worksPagesItem__btn span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background-color: #ffb427;
}

@media screen and (min-width: 60rem) {
  .worksPages {
    padding-block: 3.75rem 7.5rem;
  }
  .worksPages .worksPages__contents {
    -moz-column-gap: 1.25rem;
         column-gap: 1.25rem;
  }
  .worksPagesItem {
    grid-template-rows: initial;
    grid-template-columns: 11.25rem 1fr;
    grid-row: initial;
    -moz-column-gap: 1.25rem;
         column-gap: 1.25rem;
    padding: 0.75rem 1.25rem 0.75rem 0.75rem;
  }
  .worksPagesItem .worksPagesItem__thumbnail {
    margin-bottom: 0;
  }
  .worksPagesItem .worksPagesItem__thumbnail img {
    border-radius: 1.25rem;
  }
  .worksPagesItem .worksPagesItem__info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    -moz-column-gap: 1.25rem;
         column-gap: 1.25rem;
  }
  .worksPagesItem .worksPagesItem__title {
    margin-bottom: 0.625rem;
    padding-top: 1.25rem;
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  .worksPagesItem .worksPagesItem__tag {
    margin-bottom: 0;
  }
  .worksPagesItem .worksPagesItem__tag span {
    padding: 0.25rem 0.625rem;
  }
  .worksPagesItem .worksPagesItem__btn {
    display: flex;
    justify-content: flex-end;
    flex-shrink: 0;
  }
  .worksPagesItem .worksPagesItem__btn span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 50%;
    background-color: #ffb427;
  }
}/*# sourceMappingURL=works-single.css.map */