@charset "UTF-8";
/* 基本設定 */
/* --------------------------------------------------
	section size
-------------------------------------------------- */
/* 初期設定 */
/* ----------------------------------------------------------------------
mv
---------------------------------------------------------------------- */
#mv {
  height: 80vh;
}
@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: 354.5%;
  letter-spacing: -0.01em;
  position: relative;
  line-height: 0.8;
}
@media screen and (max-width: 520px) {
  #mv .inner .ttl-box > h2 {
    font-size: 340%;
    line-height: 1.1;
  }
}
#mv .inner .ttl-box > h2 .abs-box {
  position: absolute;
  width: 1.06em;
  inset: auto auto 0 7.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;
}
@media screen and (max-width: 840px) {
  #mv .inner .ttl-box > h1 {
    padding: 1em 0 0.3em;
  }
}
#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;
}
#mv .contactbtn-list .contactbtn-item a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ----------------------------------------------------------------------
works01
---------------------------------------------------------------------- */
#works01 {
  margin-bottom: 23rem;
}
@media screen and (max-width: 520px) {
  #works01 {
    margin-bottom: 20rem;
  }
}
#works01:before {
  content: "";
  display: block;
  width: 100%;
  height: 5.5rem;
  position: absolute;
  inset: auto auto 96.9% 0;
  background-image: url(../img/common/con-bg01@2x.webp);
  background-position: top center;
  background-size: 100%;
}
@media screen and (max-width: 1024px) {
  #works01:before {
    background-size: 140%;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #works01:before {
    background-size: 410%;
  }
}
#works01 .slide-box .works-slide01 .workd-item {
  margin: 0 0 0 2rem;
  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 .txt-box {
  padding: 0 0.9rem;
  letter-spacing: 0.1em;
  line-height: 1.75;
  transition: 0.4s;
  text-align: left;
  font-size: 1.5rem;
  line-height: 1.7333333333;
  letter-spacing: 0.1em;
  font-weight: 600;
}
@media screen and (max-width: 520px) {
  #works01 .slide-box .works-slide01 .workd-item a .txt-box {
    font-size: 1.1rem;
  }
}
#works01 .slide-box .works-slide01 .workd-item a .txt-box > h3 {
  font-size: 126.6%;
}

/* ----------------------------------------------------------------------
what we do
---------------------------------------------------------------------- */
#wwd {
  position: relative;
  margin-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 {
  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;
  flex-direction: row-reverse;
  row-gap: 8rem;
  margin-bottom: 4rem;
}
#wwd .top-Linner .wwd-contents .txt-block {
  max-width: 90rem;
  width: 56%;
  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: 7rem;
}
@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: 5rem;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .ttl-box {
  font-size: 4.4rem;
  position: relative;
  padding-right: 4em;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  #wwd .top-Linner .wwd-contents .txt-block .ttl-box {
    font-size: 4rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents .txt-block .ttl-box {
    font-size: 2.6rem;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .ttl-box:after {
  content: "";
  display: block;
  width: 3em;
  aspect-ratio: 134/70;
  background-image: url(../img/top/wwd-ttl01.svg);
  background-size: cover;
  position: absolute;
  top: 55%;
  right: 0;
  transform: translatey(-50%);
}
#wwd .top-Linner .wwd-contents .txt-block .txt-box {
  font-size: 2rem;
  line-height: 1.7;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 1024px) {
  #wwd .top-Linner .wwd-contents .txt-block .txt-box {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents .txt-block .txt-box {
    font-size: 1.2rem;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .txt-box p span.red {
  color: #C61531;
}
#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 {
  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: 5rem;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl {
  width: 31%;
  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: 2rem;
}
@media screen and (max-width: 520px) {
  #wwd .top-Linner .wwd-contents .txt-block .list-box dl {
    width: 69%;
    margin: 0 auto;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl dt {
  width: 34%;
}
#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-weight: bold;
  font-size: 2.6rem;
  margin-bottom: 0.9em;
}
@media screen and (max-width: 1024px) {
  #wwd .top-Linner .wwd-contents .txt-block .list-box dl dd h4 {
    font-size: 1.8rem;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl dd p {
  font-size: 1.6rem;
}
@media screen and (max-width: 1024px) {
  #wwd .top-Linner .wwd-contents .txt-block .list-box dl dd p {
    font-size: 1.5rem;
  }
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl:first-of-type dd h4 {
  color: #C61531;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl:nth-of-type(2) dd h4 {
  color: #2334af;
}
#wwd .top-Linner .wwd-contents .txt-block .list-box dl:last-of-type dd h4 {
  color: #0bd395;
}
#wwd .top-Linner .wwd-contents > .img-box {
  width: calc(100% - 100rem);
  min-width: 40%;
  height: 82rem;
}
@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 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%;
  }
}

/* ----------------------------------------------------------------------
features
---------------------------------------------------------------------- */
#features {
  margin-bottom: 20rem;
}
#features .inner {
  position: relative;
  z-index: 1;
}
#features .inner .ttl-box {
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 800;
  padding-left: 5em;
  position: relative;
  margin-bottom: 3em;
}
@media screen and (max-width: 520px) {
  #features .inner .ttl-box {
    font-size: 1.2rem;
  }
}
#features .inner .ttl-box > p span {
  font-size: 138%;
  margin-left: 0.3em;
}
#features .inner .ttl-box h3 {
  font-size: 527%;
}
@media screen and (max-width: 520px) {
  #features .inner .ttl-box h3 {
    font-size: 410%;
  }
}
#features .inner .ttl-box:before {
  content: "";
  display: block;
  width: 5em;
  aspect-ratio: 100/167;
  background-image: url(../img/top/features-ttl01.svg);
  background-size: cover;
  position: absolute;
  inset: 50% auto auto 0;
  transform: translate(-40%, -60%);
}
#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: 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;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.12em;
  font-weight: 800;
}
@media screen and (max-width: 1024px) {
  #features .inner .flex-wrapper {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #features .inner .flex-wrapper {
    font-size: 1.2rem;
    row-gap: 46rem;
  }
}
#features .inner .flex-wrapper .txt-block {
  width: 65%;
}
@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%;
  max-width: 38em;
  padding: 3em 2em 5em;
  border: 1px solid #000;
  border-radius: 1em;
  position: relative;
  margin-top: -1em;
  background-color: #fff;
}
#features .inner .flex-wrapper .txt-block .txt-box dt {
  font-size: 160%;
  margin-bottom: 0.6em;
}
@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 span {
  background-color: #C61531;
  color: #fff;
  padding: 0 0.3em;
}
#features .inner .flex-wrapper .txt-block .txt-box:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 90%;
  left: 2em;
  width: 5em;
  aspect-ratio: 1.7;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(1) {
  margin-top: 0;
}
#features .inner .flex-wrapper .txt-block .txt-box:nth-child(1)::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)::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)::before {
  background-image: url(../img/top/features-num03.svg);
}
#features .inner .flex-wrapper .viewmore-btn {
  width: 30%;
  height: 10rem;
  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;
  border: 1px solid #000;
  border-radius: 2rem;
  position: relative;
  background-color: #fff;
}
@media screen and (max-width: 1024px) {
  #features .inner .flex-wrapper .viewmore-btn {
    width: 100%;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #features .inner .flex-wrapper .viewmore-btn {
    height: 6rem;
  }
}
#features .inner .flex-wrapper .viewmore-btn .sub-ttl {
  font-size: 3rem;
  width: fit-content;
  position: absolute;
  inset: auto 0 90% 0;
  margin: 0 auto;
}
@media screen and (max-width: 520px) {
  #features .inner .flex-wrapper .viewmore-btn .sub-ttl {
    font-size: 2rem;
    inset: auto 0 93% 0;
  }
}
#features .inner .flex-wrapper .viewmore-btn .circle-btn-box {
  margin: 0;
}
#features .inner .flex-wrapper .viewmore-btn:before {
  content: "";
  display: block;
  width: 100%;
  height: 10rem;
  border: 1px solid #000;
  border-radius: 2rem;
  background-color: #F19B40;
  position: absolute;
  inset: 1rem auto auto 1rem;
  z-index: -1;
}
@media screen and (max-width: 520px) {
  #features .inner .flex-wrapper .viewmore-btn:before {
    height: 6rem;
  }
}
#features .inner .features-slide {
  position: absolute;
  inset: 0 0 auto auto;
  width: 50%;
  z-index: -1;
}
@media screen and (max-width: 1024px) {
  #features .inner .features-slide {
    inset: 16rem -11% auto auto;
    width: 44%;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #features .inner .features-slide {
    width: 100%;
    inset: auto 0 11.5rem;
  }
}

/* ----------------------------------------------------------------------
works02
---------------------------------------------------------------------- */
#works02 {
  margin-bottom: 21rem;
}
#works02 .inner {
  width: 93%;
  max-width: calc(100vw - (100vw - 146rem) / 2);
  margin: 0 0 0 auto;
}
#works02 .inner .works-wrapper {
  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-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;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 800;
}
@media screen and (max-width: 1024px) {
  #works02 .inner .works-wrapper {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 1024px) and (max-width: 520px) {
  #works02 .inner .works-wrapper {
    font-size: 1.2rem;
  }
}
#works02 .inner .works-wrapper .ttl-box {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  width: 6em;
}
@media screen and (max-width: 520px) {
  #works02 .inner .works-wrapper .ttl-box {
    width: 4em;
  }
}
#works02 .inner .works-wrapper .ttl-box > h3 {
  font-size: 527%;
}
@media screen and (max-width: 520px) {
  #works02 .inner .works-wrapper .ttl-box > h3 {
    font-size: 340%;
  }
}
#works02 .inner .works-wrapper .right-box {
  width: calc(100% - 10em);
}
@media screen and (max-width: 520px) {
  #works02 .inner .works-wrapper .right-box {
    width: calc(100% - 7em);
  }
}
#works02 .inner .works-wrapper .right-box .circle-btn-box {
  margin: 4em 8% 2em auto;
}
@media screen and (max-width: 520px) {
  #works02 .inner .works-wrapper .right-box .circle-btn-box {
    margin: 0 8% 2em auto;
  }
}
#works02 .inner .works-wrapper .right-box .works-slide02 {
  margin-bottom: 0;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item {
  margin-right: 4em;
}
@media screen and (max-width: 520px) {
  #works02 .inner .works-wrapper .right-box .works-slide02 .works-item {
    margin-right: 1em;
  }
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item a {
  display: block;
  width: 54vw !important;
  max-width: 41.1rem;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item a .img-box {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 3%;
  background-color: #e1e1e1;
  position: relative;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item a .img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item a .img-box .gyoushu {
  position: absolute;
  font-size: 75%;
  inset: auto 1em 0 auto;
  transform: translateY(50%);
  padding: 0.3em 1em;
  border-radius: 999px;
  background-color: #fff;
  border: 2px solid #e1e1e1;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item a .ttl {
  font-size: 133%;
  padding: 0.6em 0;
  color: #fff;
}
@media screen and (max-width: 520px) {
  #works02 .inner .works-wrapper .right-box .works-slide02 .works-item a .ttl {
    padding: 1em 0 0.6em;
  }
}
#works02 .inner .works-wrapper .right-box .works-slide02 .works-item a .cate {
  color: #fff;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .slick-dots {
  bottom: -2.3em;
  text-align: left;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .slick-dots li button::before {
  color: #fff;
}
#works02 .inner .works-wrapper .right-box .works-slide02 .slick-dots li.slick-active button:before {
  color: #fff;
}
#works02 .inner .bottom-box {
  margin-top: -9em;
  padding: 4em 0 4em 2em;
  background-color: #000;
  border-radius: 1em 0 0 1em;
  color: #fff;
  font-size: 1.4rem;
}
@media screen and (max-width: 520px) {
  #works02 .inner .bottom-box {
    font-size: 1.2rem;
    margin-top: -6em;
    padding: 2em 0 2em 0.5em;
  }
}
#works02 .inner .bottom-box .txt-box {
  line-height: 1;
}
#works02 .inner .bottom-box .txt-box .all, #works02 .inner .bottom-box .txt-box .works {
  font-size: 185%;
}
@media screen and (max-width: 520px) {
  #works02 .inner .bottom-box .txt-box .all, #works02 .inner .bottom-box .txt-box .works {
    font-size: 130%;
  }
}
#works02 .inner .bottom-box .txt-box .num {
  font-size: 477%;
}
@media screen and (max-width: 520px) {
  #works02 .inner .bottom-box .txt-box .num {
    font-size: 320%;
  }
}

/* ----------------------------------------------------------------------
other
---------------------------------------------------------------------- */
#other {
  margin-bottom: 21rem;
}
#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%);
}