#contents {
  position: relative;
  padding: 80px 0 0;
}
/* =======================================
	contents-header
======================================= */
.contents-header {
  position: relative;
}
.contents-header__inner{
  height: 485px;
}
.home .contents-header__inner{
  position: relative;
  background: url(../img/background/bg_contentsheader.jpg) center right/cover no-repeat;
  min-height: 940px;
}
  @media only screen and (min-width: 768px) {
    .contents-header__inner{
      height: 400px;
    }
    .home .contents-header__inner{
      min-height: 650px;
      background: url(../img/background/bg_contentsheader.jpg) center/cover no-repeat;
    }

  }
.contents-header__inner::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: #0785f2;
  opacity: .7;
}
.page-ttl__area,
.catch-copy {
  position: absolute;
  left: 50%;
  top: 110px;
  transform: translate(-50%,0);
  transition: var(--transition);
  z-index:1;
  margin:0;
}
.catch-copy h2{
  max-width: 350px;
  width: 90%;
  height: 190px;
  transition: var(--transition);
}
  @media only screen and (min-width: 400px) {
    .catch-copy h2{
      width: 100%;
    }

  }
.catch-copy h2 img{
  object-fit: contain;
  width: 100%;
  height: 100%;
}
/* 下層ページ */
.contents-header__inner img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.contents-header__inner .page-ttl__area{
  text-align: center;
  color: #fff;
  width: 100%;
}
.bloc-header__inner .page-ttl,
.contents-header__inner .page-ttl__area h2{
  font-size: 6rem;
  font-weight: 400;
  line-height: 1;
  margin-bottom: 50px;
}
.bloc-header__inner .page-ttl{
  margin-bottom: 10px;
}
.bloc-header__inner .page-message,
.contents-header__inner .page-ttl__area p{
  font-size: 2rem;
  max-width: 483px;
  margin: auto;
}
  @media only screen and (min-width: 768px) {
    .contents-header__inner .page-ttl__area h2{
      margin-bottom: 30px;
    }

  }

/* =======================================
	Search
======================================= */
.top-search__area{
  /* margin-top: -345px; */
  margin-top: -560px;
  margin-bottom: calc(560px - 430px);
  position: relative;
  height: 430px;
  padding: 0 20px;
  box-sizing: border-box;
}
  @media only screen and (min-width: 768px) {
  .top-search__area{
    /* margin-top: -345px; */
    margin-top: -310px;
    margin-bottom: calc(310px - 200px);
    position: relative;
    height: 200px;
  }

  }
.top-search__area::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: var(--container-bg);
  opacity: .6;
}
.top-search__area img{
  height: 50px;
  /* width: 100%; */
}
.top-search__area__inner{
  max-width: 450px;
  margin: auto;
  height: 430px;
  display: flex;
  align-items: center;
}
  @media only screen and (min-width: 768px) {
    .top-search__area__inner{
      max-width: 640px;
      height: 200px;
    }

  }
.top-search__input > .flex{
  flex-wrap: nowrap;
  /* justify-content: center; */
}
/* .page-search__keyword, */
.top-search__input{
  margin: auto;
      font-size: 2.5rem;
  width: 100%;
}
  @media only screen and (min-width: 768px) {
    .top-search__input > .flex{
      flex-wrap: wrap;
      /* justify-content: left; */
    }
    /* .page-search__keyword, */
    .top-search__input{
      font-size: 1.6rem;
    }

  }
.top-search__input input.top-search__keyword{
  border-radius: 5px;
  width: 100%;
}
.top-search__button__area{
  margin: 30px auto 0;
  width: 100%;
  position: relative;
  z-index: 1;
}
  @media only screen and (min-width: 400px) {
    .top-search__button__area{
      width: 320px;
    }

  }
.top-search__input button.top-search__btn{
  width: 100%;
  height: 75px;
  min-width: inherit;
  border-radius: 5px;
  font-size: 3rem;
}
a.top-search__modal__btn,
.top-search__area label{
  color: #fff;
  text-decoration: none;
}
a.top-search__modal__btn{
  text-decoration: underline;
}
@media only screen and (min-width: 768px) {
.top-search__button__area{
  margin: 0;
}
.top-search__input input.top-search__keyword{
  border-radius: 5px 0 0 5px;
  width: calc(100% - 135px);
}
.top-search__button__area{
  width: 135px;
}
.top-search__input button.top-search__btn{
  height: 100%;
  border-radius: 0 5px 5px 0;
  font-size: 1.4rem;
}

}
.top-search__area .top-search__detail{
  padding: 20px 15px 0;
  text-align: center;
}
.top-search__area .top-search__detail div {
  font-size: 2.5rem;
  line-height: 1;
  position: relative;
}
  @media only screen and (min-width: 768px) {
    .top-search__area .top-search__detail{
      text-align: left;
    }
      .top-search__area .top-search__detail div {
        font-size: 1.6rem;
      }

  }
.top-search__area .top-search__detail button{
  color: #fff;
}
.top-search__area .top-search__detail .icon-arrow{
  margin-left: 10px;
}
/* モーダル */

.modal1,
.modal2,
.modal3{
  display: none;
  padding-bottom: 100px;
}
.modal1-open .modal1,
.modal2-open .modal2,
.modal3-open .modal3{
  display: block;
}
.top-search__modal {
  display: none;
  position: relative;
  z-index: 110;
  width: 100%;
  height: 100vh;
  position: fixed;
  left: 0;
  top: 0;
}
.top-search__modal__wrap{
  width: 100%;
  height: 100%;
  text-align: center;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none;
  overflow: -moz-scrollbars-none;
  white-space: nowrap;
  position: relative;
  z-index: 2;
}
.top-search__modal__wrap::after {
  content: '';
  display: inline-block;
  vertical-align: middle;
  width: 1px;
  height: 100%;
}
.modal-bg {
  background-color: rgba(43, 46, 56, 0.9);
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 1;
}
.top-search__modal__content {
  margin: 0 5vw;
  width: calc(100% - 10vw);
  max-width: 900px;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  z-index: 2;
}
.modal-close{
  height: 60px;
  width: 60px;
  margin-right: 0;
  margin-left: auto;
  color: #fff;
  position: relative;
}
.close-btn{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  display: inline-block;
  width: 25px;
  height: 25px;
}
.modal__whitearea{
  border-radius: 5px;
  background: #fff;
  height: 800px;
  width: 100%;
  overflow: hidden;
}
.top-search__modal__content .top-search__detail {
  width: 100%;
  height: 100%;
}
.modal-container{
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
}
.modal-header__list{
  height: 60px;
}
.modal-form__footer{
  height: 100px;
  position: absolute;
  bottom: 0;
  background: #f2f2f2;
  padding: 0 20px;
  box-sizing: border-box;
  width: 100%;
}
.modal-footer__list{
  height: 100px;
  justify-content: space-between;
  align-items: center;
}
.modal-header__list > div{
  width: calc(100% / 4);
  background: #f2f2f2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  border-right: 1px solid var(--table-border);
  border-bottom: 1px solid var(--table-border);
  cursor: pointer;
  font-weight: bold;
}
@media only screen and (min-width: 768px) {

  .modal1{
    padding-bottom: 0;
  }
  .modal-header__list > div{
    width: calc((100% - 160px) / 3);
  }
}
.modal-header__list > div span:nth-of-type(1){
  width: calc(100% - 50px);
  text-align: center;
}
.modal-header__list > div span:nth-of-type(2){
  margin-right: 25px;
  text-align: center;
}
.modal1-open .for-modal1__active,
.modal2-open .for-modal2__active,
.modal3-open .for-modal3__active{
  background: #ecf3fe;
  color: var(--link-hover-color-dark);
}
.modal-footer__list .link-area__left > div,
.modal-footer__list .link-area__right > div{
  cursor: pointer;
  font-weight: bold;

}
.modal-footer__list .link-area__left .icon-arrow__left{
  margin-right: 10px;
}
.modal-footer__list .link-area__right .icon-arrow{
  margin-left: 10px;
}
.modal-search__header__btn{
  width: calc(100% / 4);
  min-width: inherit;
  border-radius: 0;
}

@media only screen and (min-width: 768px) {
  .modal-search__header__btn{
    width: 160px;
  }
}
button.no-form.modal-search__footer__btn{
  width: auto;
  min-width: inherit;
  padding: 0 50px;
  box-sizing: border-box;
  height: 58px;
  border-radius: 5px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}
button.no-form.search-footer__btn{
  width: auto;
  min-width: inherit;
  padding: 0 50px;
  box-sizing: border-box;
  height: 75px;
  border-radius: 5px;
  font-size: 3rem;
  width: 100%;
}
@media only screen and (min-width: 500px) {
  button.no-form.search-footer__btn{
    width: auto;
    min-width: 320px;
  }

}
@media only screen and (min-width: 768px) {
  button.no-form.modal-search__footer__btn{
    min-width: 290px;
  }
  button.no-form.search-footer__btn{
    height: 58px;
    font-size: 1.8rem;

  }
}
.modal-form__main{
  width: 100%;
  /* height: 100%; */
  overflow: auto;
  text-align: left;
}
.for-modal1__link,
.for-modal2__link,
.for-modal3__link{
  display: none;
}
.modal1-open .for-modal1__link,
.modal2-open .for-modal2__link,
.modal3-open .for-modal3__link{
  display: block;
}
/* モーダル１ */
@media only screen and (max-width: 767px) {
  .area-map {
    padding: 0;
    margin: 50px 15px;
    border-top: 1px solid var(--table-border);
    border-bottom: 1px solid var(--table-border);
  }
  .area-map dl{
    width: 100%;
    flex-direction: column;
  }
  .area-map dl:last-child{
    border-bottom: none;
  }
  .area-map dt{
    /* background: var(--table-bg); */
    border-bottom: 1px solid var(--table-border);
    width: 100%;
    padding: 10px 30px 10px 10px;
    box-sizing: border-box;
    position: relative;
  }
  .area-map dt.open{
    background-color: #ecf3fe;
  }
  .area-map dt h3{
    position: relative;
  }
  .area-map dt h3 .icon-arrow{
    position: absolute;
    top: calc(50% + -3.5px);
    right: 0;
  }
  .area-map dd{
    background: #fff;
    width: 100%;
    box-sizing: border-box;
  }
  .area-map dd .flex{
    flex-direction: column;
  }
  .area-map dd p{
    padding: 10px 20px;
    box-sizing: border-box;
    border-bottom: 1px solid var(--table-border);
  }
  .area-map h3 label {
    font-size: 2rem;
    font-weight: normal;
  }
}
@media only screen and (min-width: 768px) {
  .modal1{
    min-width: 800px;
  }
  .area-map{
    position: relative;
    width: 760px;
    margin: 50px auto;
  }
  .area-map h3{
    font-size: 1.6rem;
    font-weight: bolder;
    line-height: 1.4;
    margin-bottom: 10px;
  }
  .area-map p{
    font-size: 1.4rem;
    line-height: 1.2;
    width: 50%;
  }
  .area-shikoku p,
  .area-tokai p{
    width: 100%;
  }
  .area-hokkaido{
    position: absolute;
    top: 132px;
    left: 572px;
    display: inline-block;
    width: 188px;
    height: 155px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-hokuriku{
    position: absolute;
    top: 0px;
    left: 257px;
    display: inline-block;
    width: 188px;
    height: 130px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-kanto{
    position: absolute;
    top: 358px;
    left: 572px;
    display: inline-block;
    width: 188px;
    height: 155px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-tokai{
    position: absolute;
    top: 358px;
    left: 455px;
    display: inline-block;
    width: 100px;
    height: 155px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-kansai{
    position: absolute;
    top: 0px;
    left: 2px;
    display: inline-block;
    width: 188px;
    height: 130px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-chugoku{
    position: absolute;
    top: 177px;
    left: 2px;
    display: inline-block;
    width: 188px;
    height: 130px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-shikoku{
    position: absolute;
    top: 358px;
    left: 340px;
    display: inline-block;
    width: 100px;
    height: 155px;
    box-sizing: border-box;
    padding: 15px 10px;
  }
  .area-kyusyu{
    position: absolute;
    top: 358px;
    left: 0px;
    display: inline-block;
    width: 190px;
    height: 155px;
    box-sizing: border-box;
    padding: 15px 0 15px  10px;
  }
}
/* モーダル2・3 */
.search-table{
  margin: 50px 15px;
  border-top: 1px solid var(--table-border);
}
.modal3 .search-table{
  border: 1px solid var(--table-border);
}
.search-table dl{
  width: 100%;
  flex-direction: column;
}
.search-table dl:last-child{
  border-bottom: none;
}
.search-table dt{
  width: 100%;
  padding: 10px 30px 10px 10px;
  box-sizing: border-box;
  border-bottom: 1px solid var(--table-border);
  position: relative;
}
.search-table.other dt{
  padding: 10px 20px;
}
.modal3 .search-table dt{
  background: var(--table-bg);
}
.search-table dt h3{
  position: relative;
}
.search-table dt label span{
  display: inline-block;
}
.search-table dt .ac-button{
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  display: inline-block;
  width: 50px;
  height: 100%;
  cursor: pointer;
  display: flex;
  align-content: center;
}
.search-table dt .ac-button span{
  margin: auto;
}
.search-table dd{
  background: #fff;
}
.modal3 .search-table dd{
  padding: 10px 20px;
  box-sizing: border-box;
  display: block;
}
.search-table dd p{
  width: 100%;
  padding: 10px 20px 10px 30px;
  box-sizing: border-box;
  border-bottom: 1px solid var(--table-border);
}
.search-table dd .w12{
  width: 100%;
  box-sizing: border-box;
}
.input2{
  padding-top: 0;
}
.input2 .flex div{
  margin-top: 10px;
}
.price{
  color: #808080;
}
.search-table.other{
  border: 1px solid var(--table-border);
}
.search-table.other dt{
  background: var(--table-bg);
  border-bottom: none;
}
.search-table.other dd{
  padding: 10px 15px;
  box-sizing: border-box;
}
@media only screen and (min-width: 768px) {
  .search-table{
    margin: 50px;
    border: 1px solid var(--table-border);
    max-width: 800px;
  }
  .search-table dl{
    flex-direction: inherit;
    border-bottom: 1px solid var(--table-border);
  }
  .search-table dt{
    width: 250px;
    padding: 10px 10px;
    background: var(--table-bg);
    border-bottom: none;
  }
  .search-table dd{
    padding: 10px 15px;
    box-sizing: border-box;
    width: calc(100% - 250px);
  }
  .modal2 .search-table dd p{
    width: 50%;
    padding: 0;
    border-bottom: none;
  }
}
.other-list .flex{
  flex-direction: column;
}
input[type="text"].cost-length{
  width: 150px;
}
input[type="text"].cost-length_l{
  width: calc(100% - 100px);
}
.modal3 h3,
.modal2 h3 label{
  font-size: 2rem;
  font-weight: normal;
}
.modal3 div:not(.modal-ttl),
.modal3 label,
.modal2 label{
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .modal3 h3,
  .modal2 h3 label{
    font-size: 1.6rem;
    font-weight: bold;
  }
  .modal3 div:not(.modal-ttl),
  .modal3 label,
  .modal2 label{
    font-size: 1.4rem;
  }
  .search-table dd p{
    width: calc(100% / 3);
    min-width: 140px;
    border: none;
    padding: 0;
  }
}
.modal-ttl{
  display: inline-block;
  width: 100%;
  text-align: center;
  color: var(--link-hover-color);
  font-weight: bold;
  font-size: 2.4rem;
  margin-top: 50px;
}
/* モーダル　アコーディオン開閉 */
@media only screen and (max-width: 767px) {
  /* .industry-parent{
    display: none;
  } */
  .area-map dt.open,
  .search-table dt.open{
    background-color:#e5ebef;
  }
  .area-map dd,
  .search-table dd{
    display: none;
  }
  .search-table.other dd{
    display: block;
  }
  .area-map dt .ac-button{
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    display: inline-block;
    width: 50px;
    height: 100%;
    cursor: pointer;
    display: flex;
    align-content: center;
  }
  .area-map dt .ac-button span{
    margin: auto;
  }
}
@media only screen and (min-width: 768px) {
  .area-map dt .ac-button,
  .search-table dt .ac-button{
    display: none;
  }
  .modal-ttl{
    display: none;
  }
}
/* =======================================
	TITLE
======================================= */
h3.top-ttl{
  display:inline-block;
  font-size:1.6rem;
  margin-top:20px;
}
.ttl-area{
  margin-left: 0;
  position: relative;
  padding-left: 50px;
}
.ttl-area__page{
  margin-left: 0;
  position: relative;
  padding-left: 30px;
}
@media only screen and (min-width: 768px) {
  .ttl-area{
    margin-left: -50px;
  }
  .ttl-area__page{
    margin-left: -30px;
  }

}

.ttl-area__page::before,
.ttl-area::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: url(../img/common/deco_ttl_blue.png)  center/contain no-repeat;
  width: 40px;
}
.ttl-area__page::before{
  height: 45px;
  width: 20px;
}
.ttl-area__page.white::before{
  background: url(../img/common/deco_ttl_white.png)  center/contain no-repeat;
}
.main-ttl{
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1.2;
}
.main-sub__ttl{
  font-size: 1.4rem;
  line-height: 1;
}
.bloc-header p{
  font-size: 2.1rem;
  font-weight: bold;
}

.tt2,
.tt1{
  position: relative;
  padding-left: 30px;
}

.tt2::before,
.tt1::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 20px;
  height: 100%;
  background: url(../img/common/deco_ttl_blue.png) no-repeat center/ contain;
}
.tt2::before{
  background: url(../img/common/deco_ttl_blue.png) no-repeat center/ contain;
}
.page-s__ttl.tt2::before{
  height: 54px;
}
.about-main__box .tt2::before{
  height: 45px;
}
@media only screen and (min-width: 768px) {
  .tt2{
    padding-left: 0;
  }
  .tt2::before{
    left: -30px;
  }
}
.tt1.white::before{
  background: url(../img/common/deco_ttl_white.png) no-repeat center/ contain;
}
.bg-black__center h3,
.bg-gray__center h3,
.bg-blue__center h3{
  display: table;
  margin: auto;
  font-size: 3.6rem;
  font-weight: bold;
}
.bg-black__center{
  background: url(../img/background/bg_black_center_sp.png)  center/cover no-repeat;
}
.bg-gray__center{
  background: url(../img/background/bg_gray_center_sp.png)  center/cover no-repeat;
}
.bg-blue__center{
  background: url(../img/background/bg_black_center_sp.png)  center/cover no-repeat;
}
@media only screen and (min-width: 768px) {
  .bg-black__center{
    background: url(../img/background/bg_black_center.png)  center/cover no-repeat;
  }
  .bg-gray__center{
    background: url(../img/background/bg_gray_center.png)  center/cover no-repeat;
  }
  .bg-blue__center{
    background: url(../img/background/bg_black_center.png)  center/cover no-repeat;
  }
}
.page-s__ttl{
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1.5;
}
.about-main__box .page-s__ttl{
  font-size: 3rem;
}
.num-ttl {
  padding-left: 1.2em;
  line-height: 1.5;
}
.num-ttl .ttl-num{
  position: absolute;
  left: 30px;
}
.tt2.num-ttl{
  padding-left: calc(1.2em + 30px );
}
@media only screen and (min-width: 768px) {
.tt2.num-ttl{
  padding-left: 1.2em;
}
.tt2.num-ttl .ttl-num{
  left: 0;
}

}
.sub-ttl{
  font-size: 2rem;
  font-weight: bold;
}
/* =======================================
	共通
======================================= */
.text-center{
  width: 100%;
  text-align: center;
}
.bg-black__center{
  background-color: var(--container-bg);
  color: #fff;
}
.bg-gray__center,
.bg-gray{
  background-color: var(--container-bg-gray);
}
.bg-blue__center{
  background-color: #32a6e7;
  color: #fff;
}
.bg-gray__center .bloc-header,
.bg-black__center .bloc-header,
.bg-blue__center .bloc-header{
  text-align: center;
}
.bg-gray__center .bloc-header .ttl-area__page,
.bg-black__center .bloc-header .ttl-area__page,
.bg-blue__center .bloc-header .ttl-area__page{
  display: inline-block;
}

.bg-gray__center .bloc-header h3,
.bg-black__center .bloc-header h3,
.bg-blue__center .bloc-header h3{
  line-height: 1.2;
}

.faq + .faq{
  margin-top: 50px;
}
.casestudy-q,
.faq > dt{
  margin-bottom: 30px;
  font-size: 1.8rem;
  font-weight: bold;
  border-bottom: 1px solid #c1c1c1;
}
.casestudy-q{
  letter-spacing: 0.08rem;
}
.faq > dt .flex{
  justify-content: space-between;
  align-items: center;
}
.faq > dt .ac-icon{
  margin-right: 20px;
  width: 10px;
}
.faq > dt p{
  width: calc(100% - 40px);
}
.faq.ac > dd{
  display: none;
}
.company-rank {
  display: inline-block;
  padding: 0 10px;
  background: var(--link-hover-color);
  color: #fff;
  line-height: 1.4;
  font-size: 1.2rem;
}
.mb-20{
  margin-bottom: -20px;
}
.flex.flex-vertical{
  flex-direction: column;
}

.noimg-top{
  padding-top: 70px;
}
.noimg-top .bloc-header{
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .noimg-top{
    padding-top: 90px;
  }
}
/* =======================================
	contents-body
======================================= */
.contents-body__inner{
  position: relative;
  padding: 70px 0 30px 0;
}

.contents-body__inner.pt0{padding-top:0px;}
.wrap-container,
.wrap-container__narrow{
  margin-left:5vw;
  margin-right:5vw;
}
.bloc-header{
  margin-bottom: 50px;
}
/* @media only screen and (min-width: 768px) {
  body:not(.home) .contents-body__inner{
    padding-top: 100px;
  }
} */
@media only screen and (min-width: 990px) {
  .wrap-container__narrow{
    margin: 0 auto;
    max-width: 950px;
  }
}
@media only screen and (min-width: 1280px) {
  .wrap-container{
    margin: 0 auto;
    max-width: 1240px;
  }
}
.intro-area p + p{
  margin-top: 30px;
}
.font-red{
  color: #e82212;
}
/* =======================================
	TOP-About
======================================= */
#top-about::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: var(--container-bg-gray);
  opacity: .54;
  z-index: -2;
}
#top-about::after{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: url(../img/background/bg_about_sp.png)  center/cover no-repeat;
  z-index: -1;
}
@media only screen and (min-width: 768px) {
#top-about::after{
  background: url(../img/background/bg_about.png)  center/contain no-repeat;
}

}
#top-about .about-main{
  width: 100%;
  margin-bottom: 50px;
}
#top-about .about-img{
  margin-bottom: 50px;
  width: 100%;
  /* height: 300px; */
  aspect-ratio: 640 / 443;
  background: url(../img/background/bg_top_about.jpg)  center/cover no-repeat;
}
.about-for{
  background: #fff;
  padding: 15px 15px 30px;
  border-radius: 5px;
}

.about-for .tab-menu{
  margin: 0 -10px;
  justify-content: space-between;
}
.about-for .tab-menu button{
  font-size: 1.6rem
}
.about-for .tab-menu li{
  padding-bottom: 4px;
  margin: 0 10px;
  width: calc(100% / 3 - 20px);
  text-align: center;
  line-height: 3;
  position: relative;
}

.about-for.only-sp h3{
  display: inline-block;
  padding: 0 50px 4px;
  text-align: center;
  line-height: 3;
  position: relative;
}
.about-for.only-sp h3::after,
.about-for .tab-menu li::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  display: inline-block;
  width: 100%;
  height: 4px;
  background:  var(--border-color);;
}
.about-for.only-sp h3::after,
.about-for .tab-menu li.open::after{
  background: var(--gradient-bg);
  background: var(--gradient-linear);
}
.tab-txt{
  padding: 50px 0;
}
.tab-txt:not(.active){
  display: none;
}
.tab-txt__ttl{
  margin-bottom: 20px;
  width: 100%;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
}
.tab-txt__txt{
  width: 100%;
}
.tab-txt__txt p{
  margin-left: 20px;
  margin-bottom: 20px;
}
.tab-txt__txt p:last-child{
  margin-bottom: 0;
}
#top-about .about-main p+p{
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
#top-about .about-main{
  width: 60%;
}
#top-about .about-img{
  margin-bottom: 0;
  position: absolute;
  top: 100px;
  right: 0;
  /* display: inline-block; */
  width: calc(40% - 50px);
  height: 560px;
  background: url(../img/background/shutterstock_1931506244.jpg)  center/cover no-repeat;
}
.tab-txt__ttl{
  margin-bottom: 0;
  width: calc(30% + 20px);
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
}
.tab-txt__txt{
  width: calc(70% - 20px);
}
}
/* =======================================
	TOP-ability
======================================= */
.top-ability__ttl{
  text-align: center;
  font-size: 3rem;
  font-weight: bold;
  line-height: 1.8;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-color);
}
.flex-bloc3 {
  margin: 0 -25px -30px;
}
.flex-bloc3 dl{
  margin: 0 25px 50px;
  width: calc(100% - 50px);
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
.flex-bloc3 dl{
  width: calc(100% / 3 - 50px);
}

}

.flex-bloc3 dt.ability-ttl{
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 auto 20px;
  width: 100%;
  max-width: 270px;
  border: 1px solid;
  border-radius: 10px;
}
.flex-bloc3 dd:not(.ability-img,.value-img){
  flex-grow: 1;
}
.flex-bloc3 dd.ability-img{
  margin-top: 20px;
  border-radius: 5px;
  overflow: hidden;
  width: 100%;
}
.flex-bloc3 dd.value-img img,
.flex-bloc3 dd.ability-img img{
  object-fit: cover;
  width: 100%;
  height: 100%;
  aspect-ratio: 370 / 250;
}
/* =======================================
	TOP-value
======================================= */
#top-value::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: #32a6e7;
  opacity: .95;
  z-index: -2;
}
#top-value::after{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: auto;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: url(../img/background/bg_value_sp.png)  top center/cover no-repeat;
  z-index: -1;
}
@media only screen and (min-width: 768px) {
#top-value::after{
  right: -5vw;
  background: url(../img/background/bg_value.png)  top right/contain no-repeat;
}
}
#top-value{
  color: #fff;
  overflow: hidden;
}
#top-value .top-ability__ttl{
  color: #fff;
  border-color: #fff;
}
.value-img{
  width: 100%;
  aspect-ratio: 16 / 10;
  margin-bottom: 20px;
}
.value-img img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.value-ttl{
  text-align: left;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 10px;
  /* flex-wrap: nowrap; */
}
.value-ttl .ttl-img{
  width: 90px;
  padding-right: 20px;
  box-sizing: border-box;
}
/* =======================================
	TOP-valuation
======================================= */
.valuation-main{
  width: 100%;
}
#top-valuation .valuation-img{
  width: 100%;
  height: calc(100% - 50px);
  background: url(../img/background/bg_valuation.jpg)  center/cover no-repeat;
  position: absolute;
  right: 0;
  left: 30%;
  top: 50px;
  bottom: 0;
  z-index: -1;
}
@media only screen and (min-width: 768px) {
  .valuation-main{
    width: 50%;
  }
  #top-valuation::before{
    content: "";
    position: absolute;
    top: 50px;
    right: 0;
    left: auto;
    bottom: 100px;
    width: calc(50% - 30px);
    height: calc(100% - 150px);
    background: url(../img/background/bg_valuation.jpg)  top center/cover no-repeat;
    z-index: -1;
  }

}
.left-open__area__wrap{
  padding-top: 370px;
  position: relative;
}
.valuation-simulation{
  width: 100%;
  padding: 30px 50px;
  box-sizing: border-box;
  background: rgba(220, 220, 220, 0.8);
}
@media only screen and (min-width: 768px) {
.left-open__area__wrap{
  padding-top: 50px;
}
.valuation-simulation{
  border-radius: 5px;
  padding: 20px 50px;
}
}
.valuation-simulation .flex{
  margin-top: -20px;
  justify-content: space-between;
  flex-direction: column;
}
.valuation-simulation p{
  margin-top: 30px;
  color: #000;
  font-size: 2rem;
  line-height: 1.4;
  display: block;
}
@media only screen and (min-width: 768px) {
.valuation-simulation .flex{
  flex-direction: inherit;
}
.valuation-simulation p{
  margin-top: 20px;
}

}
/* =======================================
	TOP-case study
======================================= */
#top-casestudy{
  /*padding-top: 0;*/
}
.casestudy-box{
  margin-bottom: 50px;
}
.casestudy-box .case-study__img{
  width: 100%;
  margin-bottom: 30px;
}
.casestudy-box .case-study__img img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.casestudy-box .case-study__txt{
  width: 100%;
  flex-direction: column;
  justify-content: space-between;
}
@media only screen and (min-width: 768px) {
.casestudy-box .case-study__img{
  margin-right: 25px;
  width: calc(40% - 25px);
  margin-bottom: 0;
}
.casestudy-box .case-study__txt{
  margin-left: 25px;
  width: calc(60% - 25px);
  flex-direction: column;
  justify-content: space-between;
}

}
.casestudy-box .case-study__ttl{
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 30px;
}
.casestudy-box .case-study__ttl span{
  border-bottom: 1px solid;
}
.casestudy-box .intro{
  /* font-size: 1.4rem; */
  margin-bottom: 30px;
  flex-grow: 1;
}
.casestudy-box .case-study__link{
  text-align: center;
  width: 100%;
}
@media only screen and (min-width: 768px) {
.casestudy-box .case-study__link{
  text-align: right;
}
}
/* =======================================
	TOP-ask
======================================= */
.ask-area{
  margin: 0 auto 100px;
  background: var(--container-bg-gray);
  padding: 30px;
  width: 100%;
  box-sizing: border-box;
}
.ask-area h3{
  font-size: 1.8rem;
  margin-bottom: 20px;
  font-weight: 500;
}

/* =======================================
	PAGE- casestudy
======================================= */
#page-casestudy{
  padding-top: 0px;
}
#page-casestudy p+p{
  margin-top: 30px;
}
.main-visual__area{
  width: 100%;
  margin-bottom: 50px;
  position: relative;
}
.main-visual__area .main-img__area{
  height: 485px;
}
.main-visual__area .intro-area{
  position: relative;
  padding: 30px;
  background: rgba(34, 34, 34, 0.8);
  color: #fff;
  z-index: 1;
}
.main-visual__area .intro-area p{
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  .main-visual__area .intro-area{
    position: absolute;
    left: 30px;
    bottom: 30px;
    max-width: 40%;
  }
  .main-visual__area .intro-area.right{
    left: auto;
    right: 30px;
  }
  .main-visual__area .main-img__area{
    height: 550px;
  }
}
.main-visual__area img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#page-casestudy .main-ttl {
  margin-bottom: 40px;
  font-size: 3rem;
  line-height: 1.5;
}
#page-casestudy .midashi{
  margin-top: 80px;
  margin-bottom: 40px;
  font-size: 2rem;
  font-weight: bold;
}
#page-casestudy .midashi.tt1::before{
  height: 50px;
}

#page-casestudy .point dt{
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 20px;
}
#page-casestudy .with-img__area{
  margin-top: 80px;
}
/* #page-casestudy .txt-area{
  margin-bottom: 50px;
} */
.with-img__area .img-area{
  margin-top: 50px;
}
#page-casestudy .txt-area,
#page-casestudy .img-area{
  width: 100%;
}
#page-casestudy .img-area img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media only screen and (min-width: 768px) {
  #page-casestudy .txt-area{
    margin-right: 25px;
    width: calc(60% - 25px);
  }
  #page-casestudy .img-area{
    margin-left: 25px;
    width: calc(40% - 25px);
  }
  .with-img__area .img-area{
    margin-top: 0;
  }
}
#page-casestudy .txt-area .midashi{
  margin-top: 0;
}
.success-point{
  margin-top: 80px;
  border: 1px solid var(--body-color);
  padding: 0;
  box-sizing: border-box;
}
.success-point h3{
  padding: 30px;
  color: #fff;
  font-size: 2rem;
  line-height: 1;
  font-weight: bold;
  background: var(--gradient-bg);
  background: var(--gradient-linear);
}
.success-point p{
  padding: 20px 30px;
}
.story p+p{
  margin-top: 30px;
}

/* =======================================
	PAGE- about
======================================= */
.about-top__txt h3{
  font-size: 3rem;
  font-weight: bold;
  width: 100%;
  text-align: center;
  margin: 0 auto 50px;
}
.about-top__txt p{
  text-align: left;
}
.about-top__txt p + p{
  padding-top: 20px;
}
.page-about .text-center{
  font-size: 2rem;
}
.about-main__box{
  margin-bottom: 50px;
}
#about-main h4{
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 20px;
}
@media only screen and (min-width: 768px) {
  .about-top__txt p{
    text-align: center;
  }
  .about-main__box{
    margin-bottom: 100px;
  }
  #about-main .only-left__wrap{
    padding-right: 50px;
  }
}
.black-box{
  background: var(--body-color);
  padding: 30px;
  color: #fff;
}
.black-box p{
  text-align: center;
  font-size: 2.4rem;
  font-weight: bold;
}
/* 右画像固定 */
.img-fix__area{
  display: flex;
  position: relative;
  justify-content: space-between;
}
.left-roll__area,
.right-img__area{
  width: 100%;
}
@media only screen and (min-width: 768px) {
.left-roll__area{
  width: 60%;
}
.right-img__area{
  width: 40%;
}
}
.right-img__area > div{
  height: 100vh;
  display: flex;
  align-items: center;
	position: sticky;
	top:0;
}
.right-img__area p{
  /* height: 400px; */
  height: 100%;
  width: 100%;
	margin: auto;
	display: block;
	/* visibility: hidden; */
	position: absolute;
	top: 0;
	bottom: 0;
	/* フェード速度 */
	/* transition: .8s; */
	/* opacity: 0; */
}
.right-img__area p img{
  object-fit: cover;
  width: 100%;
  height: 100%;
}

/* =======================================
	PAGE- search
======================================= */
.search-container{
  border: 1px solid var(--body-color);
  border-radius: 5px;
  overflow: hidden;
}
.search-form__main__inner{
  padding: 30px;
}

.search-form__main .close-area{
  display: none;
}
.search-form__main .box-ttl label{
  font-size: 1.8rem;
  font-weight: bold;
}
.search-box__contents{
  text-align: right;
}
.flex-vertical__sp .search-box__contents{
  text-align: center;
}
.search-box__contents .ac-open{
  color: #808080;
  line-height: 36px;
  justify-content: space-between;
}
.select-data{
  background: #eee;
  padding: 0 10px;
  color: var(--body-color);
  opacity: 0;
  visibility: hidden;
}
.page-simulation .search-box__list.flex:not(.flex-vertical__sp) > div.select-data{
  width: 100%;
}
.search-box__contents .ac-open div p:nth-of-type(2),
.search-box__contents .ac-open.open div p:nth-of-type(1){
  display: none;
}
.search-box__contents .ac-open.open div p:nth-of-type(2){
  display: block;
}
.search-box__list.flex{
  justify-content: space-between;
}
.search-box__list.flex:not(.flex-vertical__sp) > div:nth-of-type(1){
  width: 160px;
}
.search-box__list.flex:not(.flex-vertical__sp) > div:nth-of-type(2){
  width: calc(100% - 160px);
}
.flex-vertical__sp > div{
  width: 100%;
}
.flex-vertical__sp > div.label-area {
  margin-bottom: 10px;
}
/* .page-simulation .search-form__top{
  margin: 0 60px;
} */
.page-simulation .search-box__list.flex:not(.flex-vertical__sp) > div{
  width: auto;
}
.search-box__main{
  display: none;
}
.search-box__main.first{
  overflow-x: auto;
}
.search-box__main .search-table,
.search-box__main .area-map{
  margin: 30px 15px;
}
.page-simulation .search-box__main .search-table,
.page-simulation .search-box__main .area-map,
#page-search .search-box__main .search-table,
#page-search .search-box__main .area-map{
  margin:  0;
}
@media only screen and (min-width: 768px) {
  .search-box__contents{
    text-align: left;
  }
  .search-box__main .search-table,
  .search-box__main .area-map{
    margin: 30px auto;
  }
  .page-simulation .search-box__main .search-table,
  .page-simulation .search-box__main .area-map,
  #page-search .search-box__main .search-table,
  #page-search .search-box__main .area-map{
    margin: 20px auto;
  }
  .page-simulation .search-box__list.flex > div:nth-of-type(1){
    width: 300px;
  }
  .page-simulation .search-box__list.flex > div:nth-of-type(2){
    width: calc(100% - 320px);
  }
  .flex-vertical__sp .search-box__contents{
    text-align: left;
  }
  .flex-vertical__sp > div.label-area{
    margin-bottom: 0;
  }
  .page-simulation .search-box__list.flex:not(.flex-vertical__sp) > div.select-data{
    width: auto;
  }
}
.search-form__footer{
  padding: 30px;
  background-color: #f2f2f2;
  position: relative;
  text-align: center;
}
@media only screen and (min-width: 768px) {
.search-form__footer{
  padding: 30px;
}

}
/* 検索結果一覧 */
.result-area{
  margin-top: 20px;
}
.result-area > div + div{
  margin-top: 10px;
}
.result-area .result-footer .result-link__area .link-area{
  margin-left: auto;
  margin-right: 0;
}
.result-footer {
  width: 100%;
  box-sizing: border-box;
  justify-content: space-between;
}
.result-area .result-footer .result-link__area{
  margin-top: 50px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .result-footer > div:not(.result-link__area){
    margin-right: -45px;
  }
  .result-area .result-footer .result-link__area{
    margin-top: 0;
    width: 350px;
  }
}

/* 一覧デザイン　まとめ */
.company-information{
  border: 1px solid var(--body-color);
  padding: 30px 25px;
  font-size: 1.4rem;
}
.company-information .info-header{
  padding: 0 10px 20px;
  margin: 0;
  border-bottom: 1px solid var(--body-color);
}
.company-information h4{
  font-size: 2rem;
}
.company-information h5 {
  margin-top: 30px;
  font-size: 1.8rem;
  padding: 0 10px 10px;
  border-bottom: 1px solid var(--body-color);
}
.company-information .company-information__inner{
  padding: 20px 5px 0;
}
.company-information .company-information__inner > .flex:not(.short-dl__area){
  margin-right: -45px;
  margin-bottom: -20px;
  width: 100%;
  box-sizing: border-box;
}
.company-information .company-information__inner > .flex:not(.short-dl__area).result-footer{
  margin-bottom: 0;
}
.company-information .short-dl__area{
  margin-right: -45px;
}
.company-information dl{
  flex-direction: column;
}
.company-information .short-dl__area{
  flex-direction: column;
}
.company-information .short-dl__area dl{
  margin-right: 45px;
  width: auto;
  /* align-items: center; */
}
.company-information ul,
.company-information dl{
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  width: 100%;
}
.company-information ul{
  margin-right: -20px;
  margin-bottom: -20px;
}
.company-information .company-information__inner > .flex.info-list{
  margin-right: -10px;
  margin-bottom: -10px;
}
.company-information .info-list li,
.company-information dt{
  margin-bottom: 10px;
  padding: 5px 25px;
  background: #e4e4e4;
  border-radius: 5px;
  text-align: center;
  margin-right: 10px;
}
.company-information li,
.company-information dt,
.company-information dd{
  box-sizing: border-box;
  word-break: break-word;
}
.company-information dd{
  margin-bottom: 20px;
  flex: auto;
  padding-left: 1em;
}
.company-information li{
  margin-right: 20px;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .company-information dl{
    flex-direction: inherit;
  }
  .company-information .company-information__inner > .flex.info-list{
    margin-right: -20px;
    margin-bottom: -20px;
  }
  .company-information dt{
    margin-right: 20px;
    margin-bottom: 20px;
    padding: 5px 30px;
  }
  .company-information dd{
    padding-left: 0;
  }
  .company-information .info-list li{
    margin-right: 20px;
    margin-bottom: 20px;
    padding: 5px 30px;
  }
  .company-information .short-dl__area{
    flex-direction: inherit;
  }
}
  /* ページ詳細のみ */
  .ctoc{
    justify-content: space-between;
  }
  .ctoc .ac-icon{
    align-self: center;
    margin: 0 auto 30px;
  }
  .ctoc .ac-icon .icon-arrow{
    width: 30px;
    height: 30px;
    transform: translateX(-25%) rotate(135deg);
  }
  .company-information.page-detail{
    width: 100%;
    box-sizing: border-box;
  }
  .company-information.page-detail:nth-of-type(1){
    margin-bottom: 30px;
  }
  .company-information.page-detail:nth-of-type(1)::after{
    content: "";

  }
  .company-information.page-detail dt,
  .company-information.page-detail dl{
    margin-right: 0;
    width: 100%;
  }
  .company-information.page-detail dd{
    width: 100%;
  }
  .company-information.page-detail dt,
  .company-information.page-detail dd{
    font-size: 1.8rem;
  }
  @media only screen and (min-width: 768px) {
    .company-information.page-detail{
      width: calc(50% - 50px);
    }
  .ctoc .ac-icon .icon-arrow{
    transform: translateX(-25%) rotate(45deg);
  }
    .ctoc .ac-icon,
    .company-information.page-detail:nth-of-type(1){
      margin: 0;
    }
    .company-information.page-detail dt{
      font-size: 1.6rem;
      margin-right: 20px;
      width: 150px;
    }
    .company-information.page-detail dd{
      width: calc(100% - 150px - 20px);
    }
  }
  /* 検索結果のみ */
  .result-area .result-half dl{
    width: 100%;
  }
  .result-area dt{
    width: 100%;
  }
  .result-area dd{
    width: 100%;
    padding: 5px 0;
    padding-left: 1em;
  }
  .result-area dd.company-cat{
    padding: 0;
  }
  .result-area .result-footer .result-link__area p{
    text-align: center;
  }
  .result-area .result-footer > div:nth-of-type(1){
    width: 100%;
  }
  @media only screen and (min-width: 768px) {
    .result-area .result-half dl{
      margin-right: 45px;
      width: calc(50% - 45px);
    }
    .result-area dt{
      width: 200px;
    }
    .result-area dd{
      padding: 5px 0;
      width: calc(100% - 220px);
    }
    .result-area .result-footer > div:nth-of-type(1){
      width: calc(100% - 350px);
    }
    .result-area .result-footer .result-link__area p{
      text-align: right;
    }
  }
  .result-area .company-service span{
    display: block;
  }
  .company-cat li{
    margin-right: 20px;
    font-size: 1.4rem;
    line-height: 2;
    padding: 5px 30px;
    box-sizing: border-box;
    background-color: #ecf3fe;
    border-radius: 5px;
    text-align: center;
  }

/* =======================================
	PAGE-simulation
======================================= */
.search-result__txt{
  font-size: 3.6rem;
  font-weight: bold;
  color: var(--link-hover-color);
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .search-result__txt{
    font-size: 2rem;
  }

}
.search-box__list .label-area{
  justify-content: space-between;
  align-items: center;
}
.label-area .box-ttl{
  margin-left: 60px;
}
span.required{
  padding: 0 7px;
  background-color: #e82212;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #fff;
  border-radius: 5px;
  box-sizing: border-box;
  position: absolute;
  left: 0;
}
.flex-vertical__sp{
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .label-area .box-ttl{
    margin-left: 0;
  }
  span.required{
    position: relative;
    left: auto;
  }
  .flex-vertical__sp{
    flex-direction: inherit;
  }
}
/* =======================================
	PAGE-contact
======================================= */
#contact h3{
  font-size: 1.8rem;
  font-weight: bold;
}
#contact h3.thanks-ttl {
  font-size: 3rem;
  font-weight: bold;
  width: 100%;
  text-align: center;
  margin: 0 auto 50px;
}
#contact h3 span{
  display: inline-block;
}
#contact .description{
  text-align: center;
  margin: 0 auto 50px;
  width: 100%;
}

#contact-table {
	margin: 0 auto 50px;
	padding: 0;
	width: 100%;
	display: table;
	box-sizing: border-box
}

#contact-table .tr {
	padding: 0 1% 30px;
	margin-bottom: 30px;
	display: table;
	width: 100%;
	box-sizing: border-box;
	border-bottom: 1px solid var(--table-border);
}

#contact-table .tr:last-child {
	margin-bottom: 0;
	border-bottom: none
}

#contact-table .tr>div.th {
	margin: 0 auto 5px;
	padding: 0;
	vertical-align: top;
	text-align: left;
  font-weight: bold;
	position: relative;
	display: block;
	/* width: 98% */
  width: 100%;
}

#contact-table .tr>div.th > p.flex{
  justify-content: space-between;
  align-items: center;
}

#contact-table .tr>div.td {
	margin: auto;
	display: block;
	width: 100%;
	padding-left: 0
}

@media only screen and (min-width:940px) {
  #contact-table {
    margin: 0 auto 50px;
    /* padding: 0 50px; */
  }
  #contact-table .tr {
    padding: 0;
    border: none;
  }
	#contact-table .tr>div.th {
		display: table-cell;
		width: 220px
	}

	#contact-table .tr>div.td {
		display: table-cell;
		width: calc(100% - 200px);
		padding-left: 20px
	}
}

#contact-table .tr>div.td>div.tel {
	font-size: 90%
}

#contact-table .tr>div.td>div.fax {
	font-size: 90%
}

#contact-table .agree {
	display: block;
	margin-top: 15px
}

.thanks {
	margin: 100px auto;
	padding: 50px;
	display: table;
	max-width: 900px;
	line-height: 2;
	font-size: 1.6rem;
	box-sizing: border-box;
	background: #fff
}
#contact span.required{
  position: relative;
  left: auto;
  display: inline-block;
}
.wpcf7-list-item {
  width: calc(100% - 1em);
}
.form-check{
  text-align: center;
}
#contact .ask-area{
  margin-bottom: 0;
}
.contact-link__return,
.contact-link{
  text-align: center;
}
#contact input[type="submit"]:disabled{
  opacity: .75;
  background: #e4e4e4;
}
#contact input[type="submit"]{
  opacity: 1;
}
#contact input[type="button"],
#contact input[type="submit"],
#contact input[type="submit"]:disabled{
  border-radius: 5px;
  border: none;
  transition: var(--transition);
}
#contact input[type="button"],
#contact input[type="submit"]:hover{
  transition: var(--transition);
}
#contact .wpcf7-spinner{
  position: absolute;
}
.form-check .wpcf7-form-control-wrap{
  display: inline-block;
}
.wpcf7-response-output{
  display: none;
}
/* =======================================
	Privacy / Terms
======================================= */
.long-s__area .parttl {
  margin-top: 30px;
  margin-bottom: 30px;
  font-size: 2rem;
  font-weight: bold;
  border-bottom: 1px solid #c1c1c1;
}
.long-s__area ul{
  margin-top: 20px;
  margin-left: 1em;

}
.long-s__area ul li{
  position: relative;
}
.long-s__area ul li + li{
  margin-top: 20px;
}
.long-s__area ul.disc > li + li{
  margin-top: 10px;
}
.long-s__area ul.disc > li{
  list-style: disc;
}
.long-s__area ul.num-main,
.long-s__area ul.num{
  counter-reset: li_count;
}
.long-s__area ul.num > li{
  padding-left: 30px;
}
.long-s__area ul.num > li:before  {
  position: absolute;
  top: 0;
  left: 0;
  counter-increment: li_count;
  content: "("counter(li_count)")";
  margin-right: 5px;
}
.long-s__area ul.num-main > li:before  {
  counter-increment: li_count;
  content: counter(li_count)".";
}
.long-s__area ul.sub-num{
  counter-reset: li_count;
}
.long-s__area ul.sub-num > li:before  {
  position: absolute;
  top: 0;
  left: 0;
  counter-increment: li_count;
  content: "8-"counter(li_count);
  margin-right: 5px;
}
.long-s__area ul.sub-num > li{
  padding-left: 35px;
}
.long-s__area .address{
  margin: 20px 20px 0;
}
.long-s__area .date{
  margin-top: 50px;
}