@charset "utf-8";



@media all and (min-width: 1001px)  {
/* //    |- PC  */
  .elmSP {  display:none !important;  }
} /* TB: min-width: 560px max-width: 1079px */
@media all and (max-width: 1000px)  {
/* //    |- SP  */
  .elmPC{ display:none !important;  }
} /* SP: max-width: 559px */






input, button, textarea, select {
  outline: none;
}
button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

a.anchor {
  display: block;
  padding-top: 60px;
  margin-top: -60px;
  clear: both;
}

.fwBold {
  font-weight: 700;
}

.f-en {
font-family: "Lato", serif;
  font-weight: 400;
  font-style: normal;
}
.txt_link {
  color: #3CC1A7;
  font-weight: 700;
  transition: .3s;
  word-break: break-all;
  overflow-wrap: break-word;
  display: inline-block; /* 必要なら追加 */
}
.txt_link:hover {
  opacity: 0.7;
}
.clr-grn {
  color: #3CC1A7;
}
.clr-grn2 {
  color: #6FC07C;
}
.clr-blu {
  color: #6CABCB;
}




/* ----------------- 共通 ----------------- */
.widthFix {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
.h2_ttl_wrap {
  margin: 0 0 50px;
}
.h2_ttl_wrap h2 {
  font-size: clamp(36px, 48 / 1500 * 100vw, 48px);
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
}
.h2_ttl_en {
  font-size: 20px;
  text-align: center;
  font-weight: 700;
  margin-bottom:15px;
}
.h2_ttl_en span {
  background: linear-gradient(-45deg, #d75e36 0%, #d75e36 40%, #62a0c0 80%, #62a0c0 100%);
  color: #fff;
  padding: 6px 30px;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.widthFix {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 20px;
}
.h2_ttl_wrap {
  margin: 0 0 30px;
}
.h2_ttl_wrap h2 {
  font-size: 30px;
}
.h2_ttl_en {
  font-size: 16px;
  text-align: center;
  font-weight: 700;
  margin-bottom:10px;
}
.h2_ttl_en span {
  color: #fff;
  padding: 6px 20px;
}
}




/* ----------------- KV ----------------- */
.kv {
  padding: 10px 0 clamp(70px, 130 / 1500 * 100vw, 130px);
}
.kv_wrap {
  width: 100%;
  max-width: 1500px;
  margin:0 auto;
  display: flex;
  align-items: center;
  position: relative;
  height: 600px;
}
.kvContent {
  position: absolute;
  left: clamp(80px, 120 / 1500 * 100vw, 120px);
  z-index: 2;
  top: 50%;
  transform: translateY(-50%);
}
.kvContent_ttlSub {
  font-size: clamp(16px, 20 / 1500 * 100vw, 20px);
  font-weight: 700;
  display: inline-block;
  margin-bottom: 10px;
}
.kvContent_ttlMain1 {
  display: flex;
  align-items: center;
}
.kvContent_ttlMain1_txt {
  font-size: clamp(26px, 54 / 1500 * 100vw, 54px);
  font-weight: 700;
  text-shadow: #fff 0 0 15px;
}
.kvContent_ttlMain2 {
  font-size: clamp(32px, 68 / 1500 * 100vw, 68px);
  font-weight: 700;
  text-shadow: #fff 0 0 15px;
  display: inline-block;
  margin: 15px 0 50px;
}
.kv_img {
  width: 100%;
  max-width: 65%;
  position: absolute;
  right: 0;
  z-index: 1;
}
.kvBtn_wrap {
  margin: auto;
}
.kvBtn1_link {
  width: clamp(370px, 420 / 1500 * 100vw, 420px);
  padding: 20px 0;
  font-size: clamp(16px, 20 / 1500 * 100vw, 20px);
  font-weight: 700;
  display: inline-block;
  text-align: center;
  position: relative;
  background: linear-gradient(90deg, #eb724a 0%, #d75e36 100%);
  color: #fff;
  border-radius: 100px;
      transition: .3s;
}
.kvBtn1_link:after {
  position: absolute;
  background: url(../img/icon_arrow_wht.svg) no-repeat;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  content: "";
  width: 16px;
  height: 9px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
    transition: .3s;
}
.kvBtn1_link:hover:after {
  right: 25px;
}
.kvBtn1_link span {
  position: relative;
}
.kvBtn1_link span:before {
  position: absolute;
  background: url(../img/icon_document.svg) no-repeat;
  top: 50%;
  left: -35px;
  transform: translateY(-50%);
  content: "";
  width: 22px;
  height: 27px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
    transition: .3s;
}
.kvBtn2_link {
  width: clamp(270px, 320 / 1500 * 100vw, 320px);
  padding: 12px 0;
  font-size: clamp(14px, 16 / 1500 * 100vw, 16px);
  font-weight: 700;
  display: inline-block;
  text-align: center;
  position: relative;
  background: #fff;
  color: #277299;
  border-radius: 100px;
  border:1px solid #277299;
  margin: 20px 0 0 50px ;
    transition: .3s;
}
.kvBtn2_link:after {
  position: absolute;
  background: url(../img/icon_arrow_blu.svg) no-repeat;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  content: "";
  width: 16px;
  height: 9px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
    transition: .3s;
}
.kvBtn2_link:hover:after {
  right: 25px;
}
.kvBtn_link:hover {
  opacity: 0.6;
}
.kvContent_ttl {
  display: flex;
  align-items: center;
  gap: 10px;
}
.kvContent_ttlMain_logo {
  display: inline-block;
  width: clamp(240px, 340 / 1500 * 100vw, 340px);
  height: clamp(76px, 110 / 1500 * 100vw, 110px);
  background-image: url("../img/dtoshgai_logo.jpg");
  background-size: contain;
  background-repeat: no-repeat;
  text-indent: -9999px;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.kv {
  padding: 15px 15px 60px;
  overflow: hidden;
}
.kv_wrap {
  width: 100%;
  max-width: 100%;
  min-width: 100%;
  margin:0 auto;
  display: block;
  height: 100%;
}
.kvContent {
  position: inherit;
  left: inherit;
  z-index: 2;
  top: inherit;
  transform: inherit;
}
.kvContent_ttlSub {
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}
.kvContent_ttlMain1 {
  display: flex;
  align-items: center;
  justify-content: center;
}
.kvContent_ttlMain1_txt {
  font-size: 34px;
  font-weight: 700;
}
.kvContent_ttlMain2 {
  font-size: 50px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  letter-spacing: 0.08em;
  margin: 10px 0 0;
}
@media only screen and (max-width: 340px) 
{
.kvContent_ttlMain2 {
  font-size: 42px;
}
}
.kv_img {
  width: 106%;
  max-width: 106%;
  position: inherit;
  right: inherit;
  z-index: 1;
}
.kvBtn_wrap {
  margin: 25px auto;
}
.kvBtn1_link {
  width: 100%;
  padding: 16px 0;
  font-size: 16px;
  font-weight: 700;
  display: block;
  text-align: center;
  position: relative;
  background: linear-gradient(90deg, #eb724a 0%, #d75e36 100%);
  color: #fff;
  border-radius: 100px;
}
.kvBtn2_link {
  width: 80%;
  padding: 10px 0;
  font-size: 14px;
  font-weight: 700;
  display: block;
  text-align: center;
  position: relative;
  background: #fff;
  color: #277299;
  border-radius: 100px;
  border:1px solid #277299;
  margin: 20px auto 0 ;
}
.kvContent_ttlMain {
  text-align: center;
}
.kvContent_ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.kvContent_ttlMain_logo {
  display: inline-block;
  width: 270px;
  height:86px;
  background-image: url("../img/dtoshgai_logo.jpg");
  background-size: contain;
  background-repeat: no-repeat;
  text-indent: -9999px;
}
}





/* ----------------- Problem ----------------- */
.problem {
  padding: 120px 0 100px;
  background: linear-gradient(0deg, #cccccc 0%, #f1f1f1 100%);
  position: relative;
}
.problem h2 span {
background:linear-gradient(transparent 65%, #d0e2ec 65%);
background-position-y:-17px;
}
.problem:before {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  border: 110px solid transparent;
  border-top: 80px solid #cccccc;
  bottom: -182px;
  left: 50%;
  transform: translateX(-50%);
}
.problem_wrap {
  width: 100%;
  max-width: 850px;
  margin:180px auto 0;
  position: relative;
}
.problem_list_item:nth-child(1) .problem_list_itemWrap:before,
.problem_list_item:nth-child(2) .problem_list_itemWrap:before {
  content: '';
  position: absolute;
  background: url(../img/speechbubble1.png) no-repeat;
  background-size: contain;
  width: 51px;
  height: 38px;
  right: 10px;
  bottom: -27px;
  z-index: 2;
}
.problem_list_item:nth-child(3) .problem_list_itemWrap:before{
  content: '';
  position: absolute;
  background: url(../img/speechbubble2.png) no-repeat;
  background-size: contain;
  width: 51px;
  height: 38px;
  right: 90px;
  bottom: -27px;
  z-index: 2;
}
.problem_list_item:nth-child(4) .problem_list_itemWrap:before,
.problem_list_item:nth-child(5) .problem_list_itemWrap:before {
  content: '';
  position: absolute;
  background: url(../img/speechbubble2.png) no-repeat;
  background-size: contain;
  width: 51px;
  height: 38px;
  left: 10px;
  bottom: -27px;
  z-index: 2;
}
.problem_list_item:nth-child(6) .problem_list_itemWrap:before{
  content: '';
  position: absolute;
  background: url(../img/speechbubble3.png) no-repeat;
  background-size: contain;
  width: 44px;
  height: 45px;
  left: -32px;
  top: 23px;
  z-index: 2;
}
.problem_list_item:nth-child(1) {
  position: absolute;
  left:clamp(-100px, -150 / 1500 * 100vw, -150px);
  bottom: 160px;
}
.problem_list_item:nth-child(2) {
  position: absolute;
  left: -45px;
  top: -70px;
}
.problem_list_item:nth-child(3) {
  position: absolute;
  left:50%;
  transform: translateX(-50%);
  top: -110px;
}
.problem_list_item:nth-child(4) {
  position: absolute;
  right:clamp(-48px, -78 / 1500 * 100vw, -78px);
  top: -70px;;
}
.problem_list_item:nth-child(5) {
  position: absolute;
  right:clamp(-110px, -140 / 1500 * 100vw, -140px);
  bottom: 205px;
}
.problem_list_item:nth-child(6) {
  position: absolute;
  right:clamp(-60px, -90 / 1500 * 100vw, -90px);
  bottom: 40px;
}
.problem_list_itemWrap {
  font-size: 18px;
  line-height: 1.6;
  padding: 30px;
  background: #fff;
  border-radius: 20px;
  display: inline-block;
  position: relative;
  box-shadow: 0 0 16px rgba(39,114,153,.12);
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.problem {
  padding: 70px 0 60px;
}
.problem h2 span {
background-position-y:-10px;
}
.problem:before {
  border: 75px solid transparent;
  border-top: 55px solid #cccccc;
  bottom: -120px;
}
.problem_wrap {
  width: 100%;
  max-width: 100%;
  margin:0 auto 0;
  position: inherit;
}
.problem_list_item:nth-child(1) .problem_list_itemWrap:before,
.problem_list_item:nth-child(3) .problem_list_itemWrap:before,
.problem_list_item:nth-child(5) .problem_list_itemWrap:before {
  content: '';
  position: absolute;
  background: url(../img/speechbubble1.png) no-repeat;
  background-size: contain;
  width: 45px;
  height: 27px;
  right: 20px;
  bottom: -20px;
  z-index: 2;
    left: inherit;
}
.problem_list_item:nth-child(2) .problem_list_itemWrap:before,
.problem_list_item:nth-child(4) .problem_list_itemWrap:before,
.problem_list_item:nth-child(6) .problem_list_itemWrap:before {
  content: '';
  position: absolute;
  background: url(../img/speechbubble2.png) no-repeat;
  background-size: contain;
  width: 45px;
  height: 27px;
  left: 20px;
  bottom: -20px;
  z-index: 2;
  top: inherit;
}
.problem_list_item:nth-child(1) {
  position: inherit;
  left:inherit;
  bottom: inherit;
}
.problem_list_item:nth-child(2) {
  position: inherit;
  left: inherit;
  top: inherit;
}
.problem_list_item:nth-child(3) {
  position: inherit;
  left:inherit;
  transform: inherit;
  top: inherit;
}
.problem_list_item:nth-child(4) {
  position: inherit;
  right:inherit;
  top: inherit;;
}
.problem_list_item:nth-child(5) {
  position: inherit;
  right:inherit;
  bottom: inherit;
}
.problem_list_item:nth-child(6) {
  position: inherit;
  right:inherit;
  bottom: inherit;
}
.problem_list_itemWrap {
  font-size: 16px;
  line-height: 1.6;
  padding: 20px 15px;
  background: #fff;
  border-radius: 16px;
  display: inline-block;
  position: relative;
  box-shadow: 0 0 16px rgba(39,114,153,.12);
}
.problem_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 30px 10px;
}
.problem_img {
  margin:20px 0 0;
}
}





/* ----------------- Solution ----------------- */
.solution {
  padding: 140px 0 100px;
  background: linear-gradient(-45deg, #f9e5df 0%, #e6f0f5 100%);
}
.solution h2 {
  position: relative;
  z-index: 1;
}
.solution h2 span {
  background:linear-gradient(transparent 65%, #f8d2c5 65%);
  background-position-y:-17px; 
}
.solution .f-en {
  font-size: 180px;
  font-weight: 700;
  opacity: 0.5;
  text-align: center;
  color: #fff;
  line-height: 100%;
  margin: 0 0 -70px;
  position: relative;
  z-index: 0;
}
.solution_list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 25px;
  grid-row-gap: 40px;
}
.solution_listItem:nth-child(1) { grid-area: 1 / 1 / 2 / 3; }
.solution_listItem:nth-child(2) { grid-area: 1 / 3 / 2 / 5; }
.solution_listItem:nth-child(3) { grid-area: 1 / 5 / 2 / 7; }
.solution_listItem:nth-child(4) { grid-area: 2 / 2 / 3 / 4; }
.solution_listItem:nth-child(5) { grid-area: 2 / 4 / 3 / 6; }

.solution_listItem {
  background: #fff;
  border-radius: 20px;
  padding: 30px;
}
.solution_listItem_img {
  max-width: 132px;
  margin: 0 auto 10px;
}
.solution_listItem_ttl {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 5px;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.solution {
  padding: 120px 0 80px;
}
.solution h2 span:after {
  height: 18px;
}
.solution h2 span {
  background-position-y:-10px; 
}
.solution .f-en {
  font-size: 60px;
  font-weight: 700;
  opacity: 0.5;
  text-align: center;
  color: #fff;
  line-height: 100%;
  margin: 0 0 -20px;
  position: relative;
  z-index: 0;
}
.solution_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 2列レイアウト */
  grid-template-rows: auto; /* 高さは自動調整 */
  grid-column-gap: 15px; /* 列間の余白 */
  grid-row-gap: 15px; /* 行間の余白 */
}
.solution_listItem {
  grid-column: auto !important; /* 自動配置 */
  grid-row: auto !important; /* 自動配置 */
}
.solution_listItem {
  background: #fff;
  border-radius: 16px;
  padding: 20px 15px;
}
.solution_listItem_img {
  max-width: 60%;
  margin: 0 auto 10px;
}
.solution_listItem_ttl {
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
  margin: 0 0 10px;
}
}






/* ----------------- CV ----------------- */
.cv {
position: relative;
padding: 90px 0;
overflow: hidden;
min-width: 1024px;
width: 100%;
background: url(../img/cv_img.jpg) no-repeat;
background-size: cover;
z-index: 4;
background-position-x: center;
}
.cv .widthFix {
  max-width: 860px;
}
.cvContent_ttlSub {
  font-size: clamp(16px, 20 / 1500 * 100vw, 20px);
  font-weight: 700;
  margin-left: 25px;
}
.cvContent_ttlMain1 {
  display: flex;
  align-items: center;
  justify-content: center;
}
.cvContent_ttlMain1_txt {
  font-size: clamp(40px, 46 / 1500 * 100vw, 46px);
  font-weight: 700;
  text-shadow: #fff 0 0 15px;
}
.cvContent_ttlMain2 {
  font-size: clamp(48px, 54 / 1500 * 100vw, 54px);
  font-weight: 700;
  text-shadow: #fff 0 0 15px;
}
.cvContent_ttlMain1_img {
  width: clamp(240px, 280 / 1500 * 100vw,280px);
}
.cvBtn_wrap {
  margin: 35px auto 0;
  display: flex;
  justify-content: space-between;
}
.cvBtn1_link {
  width: clamp(420px, 420 / 1500 * 100vw, 420px);
  padding: 20px 0;
  font-size: clamp(16px, 20 / 1500 * 100vw, 20px);
  font-weight: 700;
  display: inline-block;
  text-align: center;
  position: relative;
  background: linear-gradient(90deg, #eb724a 0%, #d75e36 100%);
  color: #fff;
  border-radius: 100px;
  transition: .3s;
}
.cvBtn1_link:after {
  position: absolute;
  background: url(../img/icon_arrow_wht.svg) no-repeat;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  content: "";
  width: 16px;
  height: 9px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
  transition: .3s;
}
.cvBtn1_link:hover:after {
  right: 25px;
}

.cvBtn1_link span {
  position: relative;
}
.cvBtn1_link span:before {
  position: absolute;
  background: url(../img/icon_document.svg) no-repeat;
  top: 50%;
  left: -35px;
  transform: translateY(-50%);
  content: "";
  width: 22px;
  height: 27px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
    transition: .3s;
}
.cvBtn2_link {
  width: clamp(420px, 420 / 1500 * 100vw, 420px);
  padding: 20px 0;
  font-size: clamp(16px, 20 / 1500 * 100vw, 20px);
  font-weight: 700;
  display: inline-block;
  text-align: center;
  position: relative;
  background: #fff;
  color: #277299;
  border-radius: 100px;
  border:1px solid #277299;
    transition: .3s;
}
.cvBtn2_link:after {
  position: absolute;
  background: url(../img/icon_arrow_blu.svg) no-repeat;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  content: "";
  width: 16px;
  height: 9px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
    transition: .3s;
}
.cvBtn2_link:hover:after {
  right: 25px;
}
.cvBtn_link:hover {
  opacity: 0.6;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.cv {
  position: relative;
  padding: 90px 0 80px;
  overflow: hidden;
  min-width: 100%;
  width: 100%;
  background: url(../img/cv_img.jpg) no-repeat;
  background-size: cover;
  z-index: 4;
  background-position-x: 60%;
}
.cv .widthFix {
  max-width: 100%;
}
.cvContent_ttlSub {
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  margin-left: 0;
}
.cvContent_ttlMain1 {
  display: flex;
  align-items: center;
  justify-content: center;
}
.cvContent_ttlMain1_txt {
  font-size: 32px;
  font-weight: 700;
}
.cvContent_ttlMain2 {
  font-size: 42px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  letter-spacing: 0.08em;
}
.cvContent_ttlMain1_img {
  width: 45%;
}
.cvBtn_wrap {
  margin: 25px auto;
  display: block;
}
.cvBtn1_link {
  width: 100%;
  padding: 16px 0;
  font-size: 16px;
  font-weight: 700;
  display: block;
  text-align: center;
  position: relative;
  background: linear-gradient(90deg, #eb724a 0%, #d75e36 100%);
  color: #fff;
  border-radius: 100px;
}
.cvBtn2_link {
  width: 100%;
  padding: 16px 0;
  font-size: 16px;
  font-weight: 700;
  display: block;
  text-align: center;
  position: relative;
  background: #fff;
  color: #277299;
  border-radius: 100px;
  border:1px solid #277299;
  margin: 20px auto 0 ;
}
}





/* ----------------- Feature ----------------- */
.feature {
  padding: 100px 0;
}
.feature_block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 1260px;
  margin: 0 auto;
  /*background: #f7f7f7;*/
  padding: 50px;
  border-radius: 0 40px 40px 0 ;
}
.feature_block.reverse {
  flex-direction: row-reverse;
  border-radius: 40px 0 0 40px;
}
.feature_blockImg {
  width: 100%;
  max-width: 490px;
  margin-left: 50px;
}
.feature_block.reverse .feature_blockImg {
  width: 100%;
  max-width: 490px;
  margin-left: inherit;
  margin-right: 50px;
}
/*
.feature_wrap1,
.feature_wrap2 {
  position: relative;
}
.feature_wrap2 {
  margin: 60px 0;
}
.feature_wrap1:before {
  height: 100%;
  top: 50%;
  transform: translateY(-50%);
  background-color: #f7f7f7;
  right: 0;
  content: "";
  display: block;
  width: calc(100% - 25vw);
  position: absolute;
  transition: none;
  border-radius: 40px 0 0 40px;
  z-index: -1;
}
.feature_wrap2:before {
  height: 100%;
  top: 50%;
  transform: translateY(-50%);
  background-color: #f7f7f7;
  left: 0;
  content: "";
  display: block;
  width: calc(100% - 25vw);
  position: absolute;
  transition: none;
  border-radius: 0 40px 40px 0;
  z-index: -1;
}
*/
.feature_wrap1 .feature_block {
  position: relative;
}
.feature_wrap1 .feature_block:before {
position: absolute;
  background: #f7f7f7;
  content: "";
  width: 100%;
  height: 100%;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  display: inline-block;
  background-size: cover;
  z-index: 0;
  margin-right: calc(50% - 50vw);
  padding-right: calc(50vw - 50%);
  background-position-y: center;
  z-index: -1;
  border-radius: 40px 0 0 40px;
}
.feature_wrap2 .feature_block {
  position: relative;
}
.feature_wrap2 .feature_block:before {
  position: absolute;
  background: #f7f7f7;
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  display: inline-block;
  background-size: cover;
  z-index: 0;
  margin-left: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
  background-position-y: center;
  z-index: -1;
  border-radius:  0 40px 40px 0 ;
}
.feature_wrap2 {
  margin: 60px 0;
}
.feature_blockDetail_num {
  color: #277299;
  display: flex;
  align-items: center;
}
.feature_blockDetail_numen {
  font-size: 14px;
  font-weight: 900;
  border-bottom: 1px solid #277299;
  margin-right: 10px;
}
.feature_blockDetail_numjp {
  font-size: 36px;
  font-weight: 900;
}
.feature_blockDetail_ttl {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 30px;
}

@media only screen and (max-width: 1000px) 
{ /* SP start */
.feature {
  padding: 80px 0;
}
.feature .h2_ttl_wrap {
  padding: 0 20px;
}
.feature_block {
  display: block;
  align-items: center;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  background: #f7f7f7;
  padding: 30px 20px;
  border-radius: 0 40px 40px 0 ;
}
.feature_blockImg {
  width: 100%;
  max-width: 100%;
  margin-left: inherit;
  margin-top: 30px;
}
.feature_block.reverse .feature_blockImg {
  width: 100%;
  max-width: 100%;
  margin-left: inherit;
  margin-right: inherit;
  margin-top: 20px;
}
.feature_wrap2 {
  margin: 40px 0;
}
.feature_blockDetail_num {
  color: #277299;
  display: flex;
  align-items: center;
}
.feature_blockDetail_numen {
  font-size: 13px;
  font-weight: 900;
  border-bottom: 1px solid #277299;
  margin-right: 10px;
}
.feature_blockDetail_numjp {
  font-size: 32px;
  font-weight: 900;
}
.feature_blockDetail_ttl {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 20px;
}
}




/* ----------------- Interface ----------------- */
.interface {
  padding:80px 80px 60px;
  background: linear-gradient(-45deg, #f9e5df 0%, #e6f0f5 100%);
  width: 100%;
  max-width: 1260px;
  margin: auto;
  border-radius: 20px;
  position: relative;
  margin-bottom: 120px;
}
.interface_ttl {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 30px;
}
.interface .img{
  width: 100%;
  max-width: 1400px;
  margin:0 auto;
}
.scrollable-element {
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch; /* スムーズなスクロールを有効にする */
}
.interface_ttl_en {
  font-size: 120px;
  font-weight: 700;
  color: #fff;
  opacity: 0.5;
  line-height: 80%;
  position: absolute;
  right: 0;
  bottom: 0;
}
/*SP*/
@media screen and (max-width:1000px){
.interface {
  padding:60px 0 50px 20px;
    width: 100%;
  max-width: 100%;
  margin-bottom: 80px;
}
.interface_ttl {
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 30px;
  padding-right: 20px;
}
.interface .img{
  width: 700px;
  max-width: 700px;
  height: auto;
}
.interface_ttl_en {
  font-size: 60px;
}
}




























/* ----------------- case Study ----------------- */
.casestudy {
  padding: 100px 0;
  background: linear-gradient(-45deg, #f9e5df 0%, #e6f0f5 100%);
}
.casestudy_wrap {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 28px;
}
.casestudy_block_ttl {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
}
.casestudy_block_ttl span {
  border-bottom: 2px solid #ccc;
  padding-bottom: 5px;
  position: relative;
}
.casestudy_block_ttl span:after {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  border: 7px solid transparent;
  border-top: 9px solid #cccccc;
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%);
}
.casestudy_block_txt {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  margin: 30px 0 20px;
}
.casestudy_illust {
  background: #fff;
  border-radius: 12px;
  padding: 30px 12px;
  position: relative;
}
.casestudy_illust:after {
  position: absolute;
  background: url(../img/img_arrow.png) no-repeat;
  bottom: -50px;
 left:50%;
transform: translateX(-50%);
  content: "";
  width: 80px;
  height: 50px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.casestudy_illust_img {
  margin: 15px 0;
}
.casestudy_illust_ttl {
  font-size: 16px;
  font-weight: 500;
  text-align: center;
}
.casestudy_illust_ttl span {
  position: relative;
  padding-left: 25px;
}
.casestudy_illust_ttl span:before {
  position: absolute;
  background: url(../img/icon_person.svg) no-repeat;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: "";
  width: 16px;
  height: 30px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.casestudy_illust_txt {
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}
.casestudy_illust_txt span {
  font-size: 20px;
  font-weight: 700;
}
.casestudy_result {
  margin-top: 40px;
  border-radius: 12px;
  background: #ccc;
  padding: 25px 15px;
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
  color: #fff;
}
.casestudy_result span {
  font-size: 20px;
  font-weight: 700;
}
.casestudy_arrow {
  position: relative;
}
.casestudy_arrow {
  position: relative;
  margin-top: 50px;
}
.casestudy_arrow:before {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  border: 55px solid transparent;
  border-top: 65px solid #d75e36;
  bottom: -120px;
  left: 50%;
  transform: translateX(-50%);
}
.casestudy_copy {
  background: #fff;
  padding: 40px 65px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  border-radius: 20px;
  margin-top: 90px;
}
.casestudy_copy span {
  background:linear-gradient(transparent 65%, #f8d2c5 65%);
  background-position-y:-10px;
}


.casestudy_block:nth-child(1) .casestudy_block_ttl span {
  border-bottom: 2px solid #93bb4f;
}
.casestudy_block:nth-child(1) .casestudy_block_ttl span:after {
  border-top: 9px solid #93bb4f;
}
.casestudy_block:nth-child(1) .casestudy_result {
  background: #93bb4f;
}


.casestudy_block:nth-child(2) .casestudy_block_ttl span {
  border-bottom: 2px solid #d8b151;
}
.casestudy_block:nth-child(2) .casestudy_block_ttl span:after {
  border-top: 9px solid #d8b151;
}
.casestudy_block:nth-child(2) .casestudy_result {
  background: #d8b151;
}


.casestudy_block:nth-child(3) .casestudy_block_ttl span {
  border-bottom: 2px solid #4ba2cc;
}
.casestudy_block:nth-child(3) .casestudy_block_ttl span:after {
  border-top: 9px solid #4ba2cc;
}
.casestudy_block:nth-child(3) .casestudy_result {
  background: #4ba2cc;
}


.casestudy_block:nth-child(4) .casestudy_block_ttl span {
  border-bottom: 2px solid #d176a4;
}
.casestudy_block:nth-child(4) .casestudy_block_ttl span:after {
  border-top: 9px solid #d176a4;
}
.casestudy_block:nth-child(4) .casestudy_result {
  background: #d176a4;
}





@media only screen and (max-width: 1000px) 
{ /* SP start */
.casestudy {
  padding: 80px 0 ;
}
.casestudy_wrap {
  display: block;
}
.casestudy_block:not(:last-child) {
  margin-bottom: 40px;
}
.casestudy_block_ttl {
  font-size: 22px;
  font-weight: 700;
  text-align: center;
}
.casestudy_block_txt {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  margin: 20px 0 15px;
}
.casestudy_illust {
  background: #fff;
  border-radius: 12px;
  padding: 30px 25px;
  position: relative;
}
.casestudy_illust:after {
  position: absolute;
  background: url(../img/img_arrow.png) no-repeat;
  bottom: -50px;
  left:50%;
  transform: translateX(-50%);
  content: "";
  width: 80px;
  height: 50px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.casestudy_illust_img {
  margin: 15px 0;
}
.casestudy_illust_ttl {
  font-size: 16px;
  font-weight: 500;
  text-align: center;
}
.casestudy_illust_ttl span {
  position: relative;
  padding-left: 25px;
}
.casestudy_illust_ttl span:before {
  position: absolute;
  background: url(../img/icon_person.svg) no-repeat;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: "";
  width: 16px;
  height: 30px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.casestudy_illust_txt {
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}
.casestudy_illust_txt span {
  font-size: 20px;
  font-weight: 700;
}
.casestudy_result {
  margin-top: 40px;
  border-radius: 12px;
  background: #ccc;
  padding: 25px 15px;
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
  color: #fff;
}
.casestudy_result span {
  font-size: 20px;
  font-weight: 700;
}
.casestudy_arrow {
  position: relative;
}
.casestudy_arrow {
  position: relative;
  margin-top: 50px;
}
.casestudy_arrow:before {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  border: 40px solid transparent;
  border-top: 50px solid #d75e36;
  bottom: -110px;
  left: 50%;
  transform: translateX(-50%);
}
.casestudy_copy {
  background: #fff;
  padding: 30px 20px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  border-radius: 20px;
  margin-top: 90px;
}
.casestudy_copy span {
  background-position-y:-5px;
}
}






/* ----------------- よくあるご質問 ----------------- */
.faq {
  padding: 100px 0;
}
.faq .widthFix  {
  max-width: 960px;
}
/*アコーディオン全体*/
.accordion-area{
  list-style: none;
  width: 100%;
}
.accordion-area li:first-child {
  padding-top: 30px;
  border-top: 1px solid #dddddd;
}
.accordion-area li{
  padding-bottom: 30px;
  margin-bottom: 30px;
  border-bottom: 1px solid #dddddd;
}
/*アコーディオンタイトル*/
.accordion-area .faq_title {
  position: relative;/*+マークの位置基準とするためrelative指定*/
  cursor: pointer;
  font-size:18px;
  font-weight: normal;
  padding:0 3% 0 0;
  transition: all .5s ease;
  background-color: #fff;
  border-radius: 5px;
  color: #222;
  font-weight: 700;
  display: flex;
  align-items: center;
}
.accordion-area .faq_title span.icon {
  font-size: 28px;
  padding-right: 20px;
  font-weight: 700;
  color: #277299;
  line-height: 100%;
}
/*アイコンの＋×*/
.accordion-area .faq_title::after{    
  content: " ";
  position: absolute;
  display: block;
  width: 14px;
  height: 14px;
  right: 20px;
  top: 10px;
  background: url(../img/icon_open.png) no-repeat left top;
  background-size: contain;
}
/*　closeというクラスがついたら形状変化　*/
.accordion-area .faq_title.close::after{
  content: " ";
  position: absolute;
  display: block;
  width: 14px;
  height: 14px;
  right: 20px;
  top: 10px;
  background: url(../img/icon_close.png) no-repeat left top;
  background-size: contain;
}
/*アコーディオンで現れるエリア*/
.accordion-area .faq_box {
  display: none;/*はじめは非表示*/
  background: #eef4f7;
  padding: 2% 3%;
  font-size: 14px;
  border-radius: 8px;
  margin-top: 30px;
}
@media all and (max-width: 1000px)  {
.faq {
  padding: 80px 0;
}
.faq .widthFix  {
  max-width: 100%;
}
.accordion-area{
  margin:50px auto 0;
}
.accordion-area li:first-child {
  padding-top: 20px;
  border-top: 1px solid #dddddd;
}
.accordion-area li{
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid #dddddd;
}
/*アイコンの＋×*/
.accordion-area .faq_title::after{    
  content: " ";
  position: absolute;
  display: block;
  width: 12px;
  height: 12px;
  right: 10px;
  top: 40%;
  background: url(../img/icon_open.png) no-repeat left top;
  background-size: contain;
}
/*　closeというクラスがついたら形状変化　*/
.accordion-area .faq_title.close::after{
  content: " ";
  position: absolute;
  display: block;
  width: 12px;
  height: 12px;
  right: 10px;
  top: 40%;
  background: url(../img/icon_close.png) no-repeat left top;
  background-size: contain;
}
/*アコーディオンタイトル*/
.accordion-area .faq_title {
  position: relative;/*+マークの位置基準とするためrelative指定*/
  cursor: pointer;
  font-size:15px;
  font-weight: normal;
  padding:0 30px 0 0;
  transition: all .5s ease;
  font-weight: 700;
  display: flex;
  align-items: center;
}
.accordion-area .faq_title span.icon {
  font-size: 24px;
  padding-right: 10px;
  width: 12%;
}
.accordion-area .faq_title span.text {
  width: 85%;
}
/*アコーディオンで現れるエリア*/
.accordion-area .faq_box {
  display: none;/*はじめは非表示*/
  padding: 20px 15px;
  border-radius: 8px;
  font-size: 13px;
  margin-top: 20px;
}
}





/* ----------------- Flow ----------------- */
.flow {
  padding: 0 0 100px;
}
.flow_desc {
  font-size: 18px;
  margin-bottom: 50px;
  text-align: center;
}
.flow_block {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.flow_block:not(:last-child) {
  margin-bottom: 40px;
}
.flow_block_step {
  max-width: 140px;
}
.flow_block:not(:last-child) .flow_block_step {
  position: relative;
}
.flow_block:not(:last-child) .flow_block_step:after {
  position: absolute;
  background:#d75e36;
  bottom: -100%;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  width: 2px;
  height: 130%;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.flow_block_content {
  background: #eef4f7;
  border-radius: 20px;
  padding: 40px;
  display: flex;
  width: 940px;
}
.flow_block_contentImg {
  width: 180px;
  margin-right: 40px;
}
.flow_block_contenDesc_ttl {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.4;
}
.flow_block_contenDesc_txt {
  font-size: 18px;
  font-weight: 500;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid #ddd;
}
.flow_block_contenDesc {
  width: calc(100% - 220px);
}
.flow_block_contenDesc_list {
  display: flex;
}
.flow_block_contenDesc_listItem {
  font-size: 15px;
  position: relative;
  padding-left: 25px;
}
.flow_block_contenDesc_listItem:before {
  position: absolute;
  background: url(../img/icon_check.png) no-repeat;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: "";
  width: 18px;
  height: 18px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.flow_block_contenDesc_listItem:not(:last-child) {
  margin-right: 20px;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.flow {
  padding: 0 0 80px;
}
.flow_desc {
  font-size: 16px;
  margin-bottom: 30px;
}
.flow_wrap {
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.flow_wrap:after {
  position: absolute;
  background:#d75e36;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  width: 2px;
  height: 130%;
  display: inline-block;
  background-size: contain;
  z-index: -1;
}
.flow_block {
  display: block;
}
.flow_block:not(:last-child) {
  margin-bottom: 30px;
}
.flow_block_step {
  max-width: 130px;
  margin: 0 auto 30px;
}
.flow_block:not(:last-child) .flow_block_step {
  position: inherit;
}
.flow_block:not(:last-child) .flow_block_step:after {
  position: inherit;
  background:#d75e36;
  bottom: inherit;
  left: inherit;
  transform: inherit;
  content: "";
  width: inherit;
  height: inherit;
  display: inherit;
  background-size: contain;
  z-index: 100;
}
.flow_block_content {
  background: #eef4f7;
  border-radius: 20px;
  padding: 30px ;
  display: block;
  width: 100%;
}
.flow_block_contentImg {
  width: 70%;
  margin-right: inherit;
  margin: 0 auto 20px;
}
.flow_block_contenDesc_ttl {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
.flow_block_contenDesc_txt {
  font-size: 16px;
  font-weight: 500;
  padding-bottom: 15px;
  margin-bottom: 15px;
  border-bottom: 1px solid #ddd;
  text-align: center;
}
.flow_block_contenDesc {
  width: 100%;
}
.flow_block_contenDesc_list {
  display: block;
}
.flow_block_contenDesc_listItem {
  font-size: 15px;
  position: relative;
  padding-left: 25px;
}
.flow_block_contenDesc_listItem:before {
  position: absolute;
  background: url(../img/icon_check.png) no-repeat;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: "";
  width: 18px;
  height: 18px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
.flow_block_contenDesc_listItem:not(:last-child) {
  margin-right: inherit;
  margin-bottom: 10px;
}
}





/* ----------------- CV2 ----------------- */
.cv2 {
  position: relative;
  padding: 30px 0;
  min-width: 1024px;
  width: 100%;
  background: url(../img/cv2_bg.png) no-repeat;
  background-size: cover;
  z-index: 4;
  background-position-x: center;
}
.cv2_copy {
  color: #fff;
  font-weight: 500;
  font-size: 20px;
  padding-left: 210px;
  position: relative;
  line-height: 1.5;
}
.cv2_copy span{
  font-size: clamp(30px, 32 / 1500 * 100vw, 32px);
}
.cv2_copy:before {
  position: absolute;
  background: url(../img/cv2_img.png) no-repeat;
  top: 40%;
  left: -35px;
  transform: translateY(-50%);
  content: "";
  width: 227px;
  height: 131px;
  display: inline-block;
  background-size: contain;
  z-index: 100;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.cv2 {
  position: relative;
  padding: 35px 0;
  min-width: 100%;
  width: 100%;
  background: url(../img/cv2_bg.png) no-repeat;
  background-size: cover;
  z-index: 4;
  background-position-x: center;
}
.cv2_img {
  width: 60%;
  margin: 0 auto 20px;
}
.cv2_copy {
  color: #fff;
  font-weight: 500;
  font-size: 16px;
  padding-left: 0;
  position: relative;
  line-height: 1.5;
  text-align: center;
}
.cv2_copy span{
  font-size: 24px;
}
.cv2_copy:before {
  position: inherit;
  background: url(../img/cv2_img.png) no-repeat;
  top: inherit;
  left: inherit;
  transform: translateY(-50%);
  content: "";
  width: 227px;
  height: 131px;
  display: none;
  background-size: contain;
  z-index: 100;
}
}





/* ----------------- Company ----------------- */
.company {
  padding: 75px 0;
}
.company_wrap {
  display: flex;
  justify-content: center;
}
.company_detail {
  padding-right: 80px;
  margin-right: 80px;
  border-right: 1px solid #ddd;
}
.company_detail_img {
  width: 310px;
  margin: 0 auto 10px;
}
.company_detail_listWrap {
  text-align: center;
  display: block;
}
.company_detail_list {
  text-align: left;
  display: inline-block;
}
.company_detail_listItem {
  font-size: 14px;
  line-height: 1.5;
  font-weight: 500;
}
.company_detail_listItem:not(:last-child) {
  margin-bottom: 8px;
}
.company_desc {
  font-weight: 500;
}
@media only screen and (max-width: 1000px) 
{ /* SP start */
.company {
  background: #F0F0F0;
  padding: 50px 0;
}
.company_wrap {
  display: block;
}
.company_detail {
  padding-right: inherit;
  margin-right: inherit;
  border-right: none;
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px solid #ddd;
}
.company_detail_img {
  width: 80%;
  margin: 0 auto 10px;
}
}





/* ----------------- 固定CVボタン ----------------- */

.followBtn {
  position: fixed;
  bottom: 0;
  width: 100%;
  background: rgba(234, 241, 250, 0.9);
  box-shadow: 0px -5px 5px rgba(0, 0, 0, 0.1);
  z-index: 1000;
}
.followBtn .container {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
}
.followBtn .followBtn-btns a img{
  transition: .3s;
}
.followBtn .followBtn-btns a img:hover{
  opacity: 0.7;
}
@media (max-width: 1000px) {
  .followBtn .container {
    flex-flow: column;
    height: 90px;
  }
}
.followBtn .followBtn-btns {
  display: flex;
  flex-flow: row;
}
.followBtn .followBtn-btns a {
  display: block;
  background: none;
  width: 236px;
}
@media (max-width: 1000px) {
  .followBtn .followBtn-btns a {
    width: calc((100% - 15px) / 2);
    max-width: 180px;
  }
  .followBtn .followBtn-btns a img {
    width: 100%;
  }
}
.followBtn .followBtn-btns a img {
  display: block;
}
.followBtn .followBtn-btns a:not(:last-of-type) {
  margin-right: 15px;
}
.followBtn .followBtn-txt1 {
  margin-right: 42px;
  font-size: 20px;
  color: #1C1C1C;
  font-weight: bold;
}
@media (max-width: 1000px) {
  .followBtn .followBtn-txt1 {
    margin-right: 0;
    margin-bottom: 8px;
    font-size: 14px;
  }
}
.followBtn .followBtn-txt1 .blue {
  color: #126FED;
}




/* ----------------- xxxxxxxxxxxxx ----------------- */


@media only screen and (max-width: 1000px) 
{ /* SP start */

}