@charset "UTF-8";
/* 基本設定 */
/* --------------------------------------------------
	section size
-------------------------------------------------- */
/* 初期設定 */
/* ----------------------------------------------------------------------
各アニメーション
---------------------------------------------------------------------- */
/* 背景がコンテンツによって変わる */
body {
  background-color: #fff;
  transition: 0.5s;
}
body.bk {
  background-color: #333;
}
body.red {
  background-color: #C61531;
}

.bk-bg {
  transition: 0.5s;
}
.bk-bg.active {
  color: #fff;
}

.red-bg {
  transition: 0.5s;
}
.red-bg.active {
  color: #fff;
}

/* タイピング風 */
.typing-effect {
  width: 100%;
  opacity: 0;
  overflow: hidden;
  white-space: nowrap;
}
.typing-effect span {
  display: block;
  width: fit-content;
  border-right: 1px solid #333;
  animation: blink-caret 0.75s step-end infinite;
}
.typing-effect.action {
  opacity: 1;
  animation: typing 1s steps(20, end) forwards;
}

@keyframes typing {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
@keyframes blink-caret {
  from, to {
    border-color: transparent;
  }
  50% {
    border-color: orange;
  }
}
/* フェードアウト*/
.fade-out {
  transition: 1s;
}
.fade-out.out {
  opacity: 0;
  transform: translateY(-10%);
}

/* ----------------------------------------------------------------------
mv
---------------------------------------------------------------------- */
#mv {
  height: 100vh;
  margin-top: 1%;
  transition: 1s;
  position: relative;
}
@media screen and (max-width: 520px) {
  #mv {
    height: 80rem;
  }
}
#mv .inner {
  height: 100%;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
}
#mv .inner .ttl-box {
  font-size: 3.3rem;
  line-height: 1;
  letter-spacing: 0.09em;
  font-weight: 600;
}
@media screen and (max-width: 1024px) {
  #mv .inner .ttl-box {
    font-size: 2.5rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 840px) {
  #mv .inner .ttl-box {
    font-size: 2.1rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 840px) and (max-width: 520px) {
  #mv .inner .ttl-box {
    font-size: 1.8rem;
  }
}
#mv .inner .ttl-box > h2 {
  font-size: 400%;
  letter-spacing: -0.01em;
  position: relative;
  line-height: 0.9;
  margin-bottom: 0.2em;
}
@media screen and (max-width: 520px) {
  #mv .inner .ttl-box > h2 {
    font-size: 290%;
    line-height: 1;
  }
}
#mv .inner .ttl-box > h2 .abs-box {
  position: absolute;
  width: 1em;
  inset: auto auto 0 6.6em;
}
@media screen and (max-width: 520px) {
  #mv .inner .ttl-box > h2 .abs-box {
    width: 1.26em;
    inset: auto auto 0 4.2em;
  }
}
#mv .inner .ttl-box > h1 {
  padding: 0.1em 0 0.3em;
}
#mv .inner .ttl-box > h1 span {
  position: relative;
}
#mv .inner .ttl-box > h1 span:before {
  content: "・・・・・・";
  display: block;
  position: absolute;
  inset: auto auto 85% 50%;
  transform: translateX(-50%);
  color: #C61531;
}
@media screen and (max-width: 840px) {
  #mv .inner .ttl-box > h1 {
    padding: 1em 0 0.3em;
  }
}
@media screen and (max-width: 840px) and (max-width: 520px) {
  #mv .inner .ttl-box > h1 {
    padding: 0.4em 0 0.3em;
    line-height: 1.5;
  }
}
#mv .inner .ttl-box > p {
  font-size: 55.21%;
  letter-spacing: 0.09em;
}
#mv .contactbtn-list {
  position: absolute;
  inset: 50% 3% auto auto;
  transform: translateY(-50%);
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
  flex-direction: column;
}
@media screen and (max-width: 520px) {
  #mv .contactbtn-list {
    inset: 81% 3% auto auto;
  }
}
#mv .contactbtn-list .contactbtn-item {
  padding: 17% 0;
  border-bottom: 2px solid #000;
}
#mv .contactbtn-list .contactbtn-item:last-child {
  border: none;
}
#mv .contactbtn-list .contactbtn-item a {
  width: 4rem;
  aspect-ratio: 1;
  padding: 12%;
  display: block;
}
@media screen and (max-width: 520px) {
  #mv .contactbtn-list .contactbtn-item a {
    width: 3.5rem;
  }
}
#mv .contactbtn-list .contactbtn-item a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#mv .scroll_down {
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 600;
  display: block;
  position: absolute;
  inset: auto 0 4em 0;
  text-align: center;
}
@media screen and (max-width: 520px) {
  #mv .scroll_down {
    font-size: 1rem;
  }
}
#mv .scroll_down .mouse {
  position: relative;
  display: block;
  width: 2em;
  height: 3em;
  margin: 0 auto 0.7em;
  border: 1px solid #000;
  border-radius: 1.25em;
}
#mv .scroll_down .mouse > * {
  display: block;
  position: absolute;
  inset: 29% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 0.57em;
  height: 0.57em;
  background: #000;
  border-radius: 999px;
  animation: ani-mouse 2.5s linear infinite;
}

@keyframes ani-mouse {
  0% {
    opacity: 0;
    top: 70%;
  }
  40% {
    opacity: 0;
    top: 30%;
  }
  70% {
    opacity: 1;
    top: 30%;
  }
  100% {
    opacity: 1;
    top: 70%;
  }
}
/* ----------------------------------------------------------------------
works01
---------------------------------------------------------------------- */
#works01 {
  margin-bottom: 25rem;
}
@media screen and (max-width: 520px) {
  #works01 {
    margin-bottom: 20rem;
  }
}
#works01 .slide-box {
  font-size: 1.5rem;
  line-height: 1.7333333333;
  letter-spacing: 0.1em;
  font-weight: 600;
}
@media screen and (max-width: 520px) {
  #works01 .slide-box {
    font-size: 1.1rem;
  }
}
#works01 .slide-box .works-slide01 .slick-list {
  overflow: visible;
}
#works01 .slide-box .works-slide01 .workd-item {
  margin: 0 0 0 3em;
  max-width: 41.1rem;
  width: 57vw !important;
}
#works01 .slide-box .works-slide01 .workd-item a {
  display: block;
}
#works01 .slide-box .works-slide01 .workd-item a .img-box {
  overflow: hidden;
  border-radius: 1em;
}
#works01 .slide-box .works-slide01 .workd-item a .img-box img {
  transition: 0.5s;
  transform-origin: center;
}
#works01 .slide-box .works-slide01 .workd-item a .txt-box {
  padding: 0 0.5em;
  letter-spacing: 0.1em;
  line-height: 1.75;
  transition: 0.4s;
  text-align: left;
  margin-top: 0.6em;
}
#works01 .slide-box .works-slide01 .workd-item a .txt-box > h3 {
  font-size: 150%;
  position: relative;
  margin-bottom: 0.5em;
}
#works01 .slide-box .works-slide01 .workd-item a .txt-box > p {
  font-size: 86.66%;
  font-weight: 400;
}
#works01 .slide-box .works-slide01 .workd-item a .txt-box > p span {
  line-height: 1;
  padding: 0.3em 1.9em;
  border-radius: 999px;
  border: 1px solid #a6a6a6;
  margin-right: 0.5em;
}
#works01 .slide-box .works-slide01 .workd-item a:hover {
  opacity: 1;
}
#works01 .slide-box .works-slide01 .workd-item a:hover .img-box img {
  transform: scale(1.02);
}

/* ----------------------------------------------------------------------
what we do
---------------------------------------------------------------------- */
#wwd {
  position: relative;
  padding-bottom: 15rem;
}
@media screen and (max-width: 520px) {
  #wwd {
    padding-bottom: 20rem;
  }
}
#wwd .top-Linner {
  width: 93%;
  max-width: calc(100vw - (100vw - 170rem) / 2);
  margin: 0 auto 0 0;
}
@media screen and (max-width: 840px) {
  #wwd .top-Linner {
    width: 86%;
    max-width: initial;
    margin: 0 auto;
  }
}
#wwd .top-Linner .wwd-contents {
  flex-direction: row-reverse;
  row-gap: 5em;
  margin-bottom: 4em;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  font-size: 1.7rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 600;
}
@media screen and (max-width: 1024px) {
  #wwd .top-Linner .wwd-contents {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents {
    font-size: 1.2rem;
  }
}
#wwd .top-Linner .wwd-contents .txt-block {
  width: 60%;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  flex-direction: column;
  gap: 4em;
  padding: 1% 0;
}
@media screen and (max-width: 840px) {
  #wwd .top-Linner .wwd-contents .txt-block {
    width: 100%;
  }
}
@media screen and (max-width: 840px) and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents .txt-block {
    gap: 5em;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .ttl-box {
  font-size: 700%;
  position: relative;
  line-height: 0.8;
  font-weight: 800;
  width: 0%;
}
#wwd .top-Linner .wwd-contents .txt-block .ttl-box span {
  position: relative;
}
#wwd .top-Linner .wwd-contents .txt-block .ttl-box span:after {
  content: "";
  display: block;
  width: 0.5em;
  aspect-ratio: 134/70;
  background-image: url(../img/top/wwd-ttl01.svg);
  background-size: cover;
  position: absolute;
  inset: auto 0.2em 0.16em auto;
}
#wwd .top-Linner .wwd-contents .txt-block .txt-box {
  padding: 0 1em;
}
#wwd .top-Linner .wwd-contents .txt-block .txt-box p span.red {
  color: rgb(255, 255, 50);
}
#wwd .top-Linner .wwd-contents .txt-block .txt-box p span.gre-bg {
  color: #fff;
  background-color: #0bd395;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box {
  width: 100%;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  row-gap: 5em;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl {
  width: 32%;
  max-width: 18em;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  flex-direction: column;
  gap: 1em;
}
@media screen and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents .txt-block .list-box dl {
    width: 69%;
    max-width: initial;
    margin: 0 auto;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl dt {
  width: 40%;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl dd {
  text-align: center;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl dd h4 {
  font-size: 120%;
  font-weight: bold;
  margin-bottom: 0.3em;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl dd p {
  font-size: 90%;
  padding: 0 0.5em;
}
#wwd .top-Linner .wwd-contents > .img-box {
  width: 35%;
  border-radius: 0 3rem 3rem 0;
  overflow: hidden;
}
@media screen and (max-width: 840px) {
  #wwd .top-Linner .wwd-contents > .img-box {
    width: 100%;
  }
}
@media screen and (max-width: 840px) and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents > .img-box {
    height: 35rem;
  }
}
#wwd .top-Linner .wwd-contents > .img-box * {
  height: 100%;
}
#wwd .top-Linner .wwd-contents > .img-box img {
  max-width: initial;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right 9%;
}
#wwd > .abs-box {
  position: absolute;
  width: 83rem;
  bottom: -10rem;
  left: 10%;
  z-index: -1;
}
@media screen and (max-width: 520px) {
  #wwd > .abs-box {
    width: 33rem;
    left: -10%;
  }
}
#wwd:before {
  content: "";
  display: block;
  width: 45vw;
  aspect-ratio: 830/600;
  position: absolute;
  inset: -20% 0 auto auto;
  background: url(../img/top/wwd-bg01.svg) no-repeat;
  background-size: cover;
  z-index: -1;
  opacity: 0.05;
  filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(358deg) brightness(111%) contrast(101%);
}

/* ----------------------------------------------------------------------
features
---------------------------------------------------------------------- */
#features {
  padding-bottom: 30rem;
  position: relative;
}
#features .inner {
  position: relative;
  z-index: 1;
  font-size: 1.7rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 600;
}
@media screen and (max-width: 520px) {
  #features .inner {
    font-size: 1.2rem;
  }
}
#features .inner .ttl-box {
  position: relative;
  margin: 0 0 4em 1em;
}
#features .inner .ttl-box > p span {
  font-size: 138%;
  margin-left: 0.3em;
}
#features .inner .ttl-box h3 {
  font-size: 700%;
  font-weight: 800;
  line-height: 0.8;
  width: 0%;
}
@media screen and (max-width: 520px) {
  #features .inner .ttl-box h3 {
    font-size: 410%;
  }
}
#features .inner .ttl-box:before {
  content: "";
  display: block;
  width: 3.5em;
  aspect-ratio: 100/167;
  background-image: url(../img/top/features-ttl01.svg);
  background-size: cover;
  position: absolute;
  inset: auto auto -0.4em -2.1em;
}
#features .inner .flex-wrapper {
  row-gap: 9rem;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #features .inner .flex-wrapper {
    row-gap: 46rem;
  }
}
#features .inner .flex-wrapper .txt-block {
  width: 60%;
}
@media screen and (max-width: 1024px) {
  #features .inner .flex-wrapper .txt-block {
    width: 80%;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #features .inner .flex-wrapper .txt-block {
    width: 100%;
  }
}
#features .inner .flex-wrapper .txt-block .txt-box {
  width: 90%;
  padding: 2em 1em;
  position: relative;
  border-bottom: 1px solid #fff;
}
#features .inner .flex-wrapper .txt-block .txt-box dt {
  font-size: 150%;
  margin-bottom: 0.6em;
  padding-left: 3em;
  position: relative;
}
@media screen and (max-width: 520px) {
  #features .inner .flex-wrapper .txt-block .txt-box dt {
    margin-bottom: 1.2em;
  }
}
#features .inner .flex-wrapper .txt-block .txt-box dt:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0.2em;
  left: 0;
  width: 2.4em;
  aspect-ratio: 1.7;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(358deg) brightness(111%) contrast(101%);
}
#features .inner .flex-wrapper .txt-block .txt-box dt span {
  font-size: 116%;
  background-color: #fff;
  color: #C61531;
  padding: 0 0.3em 0.1em;
  margin-left: 0.2em;
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(1) {
  padding-top: 0;
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(1) dt::before {
  background-image: url(../img/top/features-num01.svg);
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(2) {
  left: 50%;
  transform: translateX(-50%);
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(2) dt::before {
  background-image: url(../img/top/features-num02.svg);
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(3) {
  left: 100%;
  transform: translateX(-100%);
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(3) dt::before {
  background-image: url(../img/top/features-num03.svg);
}
#features .inner .flex-wrapper .img-block {
  width: 37%;
  position: relative;
}
#features .inner .flex-wrapper .img-block .img-box {
  width: 45vw;
  height: 100%;
  position: absolute;
  inset: auto auto 8em 0;
  background-color: #e1e1e1;
}
#features .inner .flex-wrapper .img-block .circle-btn-box {
  position: absolute;
  inset: auto 0 0 auto;
}
#features:before {
  content: "";
  display: block;
  width: 50vw;
  aspect-ratio: 600/472;
  position: absolute;
  inset: auto auto 10% 0;
  background: url(../img/test/features-bg01.svg) no-repeat;
  background-size: cover;
  z-index: -1;
  opacity: 0.1;
}

/* ----------------------------------------------------------------------
works02
---------------------------------------------------------------------- */
#works02 {
  margin-bottom: 25rem;
  position: relative;
}
#works02 .inner.first {
  position: relative;
  margin: 0 auto 7em;
  z-index: -1;
  font-size: 1.7rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 600;
}
@media screen and (max-width: 520px) {
  #works02 .inner.first {
    font-size: 1.2rem;
  }
}
#works02 .inner.first:after {
  content: "";
  display: block;
  position: absolute;
  inset: auto auto -82% 80%;
  width: 47vw;
  aspect-ratio: 1;
  border-radius: 999px;
  border: 12rem solid #C61531;
}
#works02 .inner.first .ttl-box {
  position: relative;
  margin-bottom: 1em;
}
#works02 .inner.first .ttl-box > p span {
  font-size: 138%;
  margin-left: 0.3em;
}
#works02 .inner.first .ttl-box h3 {
  font-size: 700%;
  font-weight: 800;
  line-height: 0.8;
  width: 0%;
}
@media screen and (max-width: 520px) {
  #works02 .inner.first .ttl-box h3 {
    font-size: 410%;
  }
}
#works02 .inner.first .ttl-box:before {
  content: "";
  display: block;
  width: 3.5em;
  aspect-ratio: 100/167;
  background-image: url(../img/top/features-ttl01.svg);
  background-size: cover;
  position: absolute;
  inset: auto auto -0.4em -2.1em;
}
#works02 .works-wrapper {
  margin-bottom: 5em;
}
#works02 .works-wrapper .works-slide02 .slick-list {
  overflow: visible;
}
#works02 .works-wrapper .works-slide02 .works-item {
  margin-right: 4em;
  transition: 0.3s;
}
#works02 .works-wrapper .works-slide02 .works-item a {
  display: block;
  width: 54vw !important;
  max-width: 32em;
  aspect-ratio: 490/713;
  position: relative;
}
#works02 .works-wrapper .works-slide02 .works-item a .img-box {
  width: 100%;
  height: 100%;
  border-radius: 1em;
  overflow: hidden;
}
#works02 .works-wrapper .works-slide02 .works-item a .img-box img {
  transition: 0.7s;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#works02 .works-wrapper .works-slide02 .works-item a .img-box:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 60%;
  border-radius: 0 0 1em 1em;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 100%); /* 上から下へ、透明から半透明の黒へ */
  pointer-events: none;
}
#works02 .works-wrapper .works-slide02 .works-item a .gyoushu {
  position: absolute;
  inset: -1px -1px auto auto;
  padding: 0.7em 2em;
  background-color: #333;
  border-radius: 0 0 0 1em;
}
#works02 .works-wrapper .works-slide02 .works-item a .gyoushu:before, #works02 .works-wrapper .works-slide02 .works-item a .gyoushu:after {
  content: "";
  display: block;
  width: 1em;
  aspect-ratio: 1;
  background: url(../img/test/kadomaru.svg) no-repeat;
  background-size: cover;
  position: absolute;
}
#works02 .works-wrapper .works-slide02 .works-item a .gyoushu:before {
  inset: 0 calc(100% - 1px) auto auto;
}
#works02 .works-wrapper .works-slide02 .works-item a .gyoushu:after {
  inset: calc(100% - 1px) 0 auto auto;
}
#works02 .works-wrapper .works-slide02 .works-item a .txt-box {
  position: absolute;
  inset: auto auto 0 0;
  width: 100%;
  padding: 1em 0.6em;
  color: #fff;
}
#works02 .works-wrapper .works-slide02 .works-item a .txt-box .ttl {
  font-size: 160%;
  margin-bottom: 0.6em;
}
#works02 .works-wrapper .works-slide02 .works-item a:hover {
  opacity: 1;
}
#works02 .works-wrapper .works-slide02 .works-item a:hover .img-box img {
  transform: scale(1.03);
}
#works02 .works-wrapper .works-slide02 .works-item.slick-current {
  transform: translateY(-3em);
}
#works02 .works-wrapper .works-slide02 .slick-prev, #works02 .works-wrapper .works-slide02 .slick-next {
  top: auto;
  bottom: 100%;
  left: auto;
  width: 3em;
  height: 3em;
  font-size: inherit;
}
#works02 .works-wrapper .works-slide02 .slick-prev:before, #works02 .works-wrapper .works-slide02 .slick-next:before {
  font-size: 300%;
}
#works02 .works-wrapper .works-slide02 .slick-prev {
  right: 4em;
}
#works02 .works-wrapper .works-slide02 .slick-next {
  right: 0em;
}

/* ----------------------------------------------------------------------
other
---------------------------------------------------------------------- */
#other {
  margin-bottom: 21rem;
  padding: 30rem 0 0;
  position: relative;
  background: rgb(240, 243, 246);
}
#other .inner .ttl-box {
  text-align: center;
  width: fit-content;
  margin: 0 auto 3em;
  position: relative;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 800;
}
@media screen and (max-width: 520px) {
  #other .inner .ttl-box {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 520px) {
  #other .inner .ttl-box p {
    line-height: 1.5;
    margin-bottom: 0.3em;
  }
}
#other .inner .ttl-box p span {
  color: #C61531;
}
#other .inner .ttl-box h3 {
  font-size: 311%;
  letter-spacing: 0;
}
#other .inner .ttl-box .abs.ttl {
  position: absolute;
  width: 6em;
  inset: 50% auto auto 104%;
  transform: translateY(-60%);
}
#other .inner .service-list {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.12em;
  font-weight: 800;
  gap: 2em;
}
@media screen and (max-width: 1024px) {
  #other .inner .service-list {
    font-size: 1.2rem;
  }
}
#other .inner .service-list .service-item {
  padding: 4em 5%;
  position: relative;
  width: calc((100% - 2em) / 2);
  row-gap: 1.6em;
  border: 2px solid #ccc;
  border-radius: 1em;
  background-color: #fff;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
}
@media screen and (max-width: 520px) {
  #other .inner .service-list .service-item {
    width: 100%;
  }
}
#other .inner .service-list .service-item.big {
  width: 100%;
}
#other .inner .service-list .service-item dt, #other .inner .service-list .service-item dd {
  position: relative;
  z-index: 1;
}
#other .inner .service-list .service-item dt {
  font-size: 183%;
  transition: 0.3s;
}
#other .inner .service-list .service-item dd {
  max-width: 50em;
}
#other .inner .service-list .service-item .circle-btn-box {
  position: absolute;
  inset: -1em -1em auto auto;
}
#other .inner .service-list .service-item .abs {
  position: absolute;
  width: 10%;
  max-width: 7.8em;
  inset: 50% 0 auto auto;
  transform: translateY(-50%);
}
@media screen and (max-width: 520px) {
  #other .inner .service-list .service-item .abs {
    width: 27%;
    opacity: 0.4;
  }
}
#other .inner .service-list .service-item:hover {
  opacity: 1;
}
#other .inner .service-list .service-item:hover dt {
  color: #C61531;
}
#other .inner .service-list .service-item:hover .circle-btn-box button:before {
  transform: translate(0, -50%);
}
#other .inner .service-list .service-item:hover .circle-btn-box button:after {
  scale: 1.05;
}
#other .img-box {
  margin-top: -8rem;
}
#other .img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#other .img-box .abs {
  position: absolute;
  width: 20%;
  inset: auto auto 0 0;
  transform: translate(-20%, 40%);
}

/* ----------------------------------------------------------------------
news
---------------------------------------------------------------------- */
#news {
  position: relative;
  margin-bottom: 21rem;
}
#news .inner {
  width: 93%;
  max-width: calc(100vw - (100vw - 146rem) / 2);
  margin: 0 0 0 auto;
}
#news .inner .ttl-block {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 800;
  width: 90%;
  position: relative;
  margin-bottom: 1.7em;
  row-gap: 1em;
}
@media screen and (max-width: 520px) {
  #news .inner .ttl-block {
    font-size: 1.2rem;
  }
}
#news .inner .ttl-block .ttl-box h3 {
  font-size: 311%;
  letter-spacing: 0;
}
#news .inner .ttl-block .abs-box.ttl {
  position: absolute;
  width: 7em;
  top: 50%;
  right: 102%;
  transform: translatey(-50%);
}
@media screen and (max-width: 520px) {
  #news .inner .ttl-block .abs-box.ttl {
    top: -70%;
    right: 92%;
  }
}
#news .inner .slide-wrap .news-slide .slick-slide {
  margin: 0 2rem 0 0;
  max-width: 46rem;
  width: 64vw !important;
}
#news .inner .slide-wrap .news-slide .slick-slide a {
  display: block;
  width: 100%;
  border: 3.5px solid #fff;
  border-radius: 0.9rem;
}
#news .inner .slide-wrap .news-slide .slick-slide a .img-box {
  width: 100%;
  aspect-ratio: 462/231;
  background-color: #e1e1e1;
  border-radius: 0.9rem 0.9rem 0 0;
}
#news .inner .slide-wrap .news-slide .slick-slide a .img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#news .inner .slide-wrap .news-slide .slick-slide a .txt-box {
  padding: 2em 1.5em;
  background-color: #f5f5f5;
  border-radius: 0 0 0.9rem 0.9rem;
}
#news .inner .slide-wrap .news-slide .slick-slide a .txt-box .ttl {
  font-size: 1.9rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.75;
  height: 3.5em;
  margin-bottom: 0.7em;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
@media screen and (max-width: 520px) {
  #news .inner .slide-wrap .news-slide .slick-slide a .txt-box .ttl {
    font-size: 1.5rem;
  }
}
#news .inner .slide-wrap .news-slide .slick-slide a .txt-box .info {
  font-size: 1.4rem;
  color: #808080;
  gap: 1em;
  justify-content: flex-start;
}
#news .inner .slide-wrap .news-slide .slick-slide a .txt-box .info .cate span {
  margin-right: 1em;
}
@media screen and (max-width: 520px) {
  #news .inner .slide-wrap .news-slide .slick-slide a .txt-box .info {
    font-size: 1.1rem;
  }
}
#news .inner .slide-wrap .news-slide .slick-slide a:hover .txt-box {
  transition: 0.4s;
  color: #C61531;
}
#news .inner .slide-wrap .news-slide .slick-dots {
  text-align: left;
}
#news .abs-box.bg {
  position: absolute;
  width: 49%;
  top: 50%;
  left: -10%;
  transform: translatey(-50%);
  z-index: -1;
}
@media screen and (max-width: 520px) {
  #news .abs-box.bg {
    width: 80%;
    top: 30%;
    left: -33%;
  }
}

/* ----------------------------------------------------------------------

---------------------------------------------------------------------- */
#com {
  margin-bottom: 28rem;
}
#com .inner {
  row-gap: 5rem;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
}
#com .inner .txt-block {
  width: 53%;
}
@media screen and (max-width: 840px) {
  #com .inner .txt-block {
    width: 100%;
  }
}
#com .inner .txt-block .ttl-box {
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 800;
  width: 90%;
  position: relative;
  margin-bottom: 1.7em;
}
@media screen and (max-width: 520px) {
  #com .inner .txt-block .ttl-box {
    font-size: 1.2rem;
  }
}
#com .inner .txt-block .ttl-box h3 {
  font-size: 311%;
  letter-spacing: 0;
}
#com .inner .txt-block .btn-list {
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 800;
}
@media screen and (max-width: 1024px) {
  #com .inner .txt-block .btn-list {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #com .inner .txt-block .btn-list {
    font-size: 1.2rem;
  }
}
#com .inner .txt-block .btn-list .btn-item a {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  padding: 3.6em 1em;
  border-bottom: 2px solid #ccc;
}
#com .inner .txt-block .btn-list .btn-item a .txt-box p {
  font-size: 222%;
}
#com .inner .txt-block .btn-list .btn-item a:hover {
  opacity: 1;
}
#com .inner .txt-block .btn-list .btn-item a:hover .circle-btn-box button:before {
  transform: translate(0, -50%);
}
#com .inner .txt-block .btn-list .btn-item a:hover .circle-btn-box button:after {
  scale: 1.05;
}
#com .inner .txt-block .btn-list .btn-item:first-child a {
  border-top: 2px solid #ccc;
}
#com .inner .txt-block .btn-list .btn-item:nth-child(odd) a {
  background-color: #F2F2F2;
}
#com .inner .img-block {
  position: relative;
  width: 42.7%;
}
@media screen and (max-width: 840px) {
  #com .inner .img-block {
    width: 100%;
  }
}
#com .inner .img-block .img-box {
  width: 100%;
}
#com .inner .img-block .img-box img {
  max-width: initial;
  width: 100%;
}
#com .inner .img-block .abs {
  position: absolute;
  width: 20%;
  inset: auto 0 0 auto;
  transform: translateX(42%);
}