@charset "UTF-8";
/* CSS Document */
html {
  scroll-padding-top: 120px;
  scroll-behavior: smooth;
}
.scroll-wrap {
  will-change: transform;
  /* アニメーション前にブラウザに最適化を指示 */
}

main {
  overflow: hidden;
  margin-top: 85px;
}

.section_title {
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.12em;
  text-align: center;
}

.section_title::before {
  content: '';
  display: inline-block;
  background-image: url(https://s3.ap-northeast-1.amazonaws.com/img.kireini.me/connect/web/top/sectionttl_logo.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 33px;
  height: 36px;
  margin: 0 auto 12px;
}

/* ---------

FV
------------*/
#fv {
  display: flex;
  width: 100%;
  padding: 56px 0 64px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}
#fv .fv_content {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 0;
}
#fv .content_l {
  display: flex;
  width: 663px;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  flex-shrink: 0;
}
#fv .content_l .content_l_wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 48px;
  align-self: stretch;
}
#fv .content_l .content_txt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 32px;
}
#fv .content_l .first_c {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
}
#fv .content_l .sub_c {
  display: flex;
  align-items: center;
  gap: 20px;
  color: #4F8888;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.06em;
}
#fv .content_l .sub_c span {
  width: 31px;
  height: 1px;
  background-color: #4F8888;
}
#fv .content_l .main_c {
  color: #296767;
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.08em;
  text-wrap: nowrap;
}
#fv .content_l .main_c span {
  color: #1FA6A6;
}
#fv .content_l .second_c {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
}
#fv .content_l .second_c .second_c_txt {
  color: #296767;
  font-size: 2.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
}
#fv .content_l .func_list {
  display: inline-grid;
  column-gap: 1.5em;
  row-gap: 0.8em;
  grid-template-columns: repeat(4, auto);
}
#fv .content_l .column {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
#fv .content_l .func::before {
  content: '';
  display: inline-block;
  background-image: url(https://s3.ap-northeast-1.amazonaws.com/img.kireini.me/connect/web/top/check_icon.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 14px;
  height: 14px;
}
#fv .content_l .func {
  color: #4F8888;
  font-size: 1.8rem;
  font-weight: 400;
  display: flex;
  gap: 4px;
  align-items: center;
}


#fv .content_r {
  display: flex;
  height: 462px;
  justify-content: center;
  align-items: flex-start;
  flex: 1 0 0;
  position: relative;
}
#fv .content_r .content_r_wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-end;
  flex: 1 0 0;
  align-self: stretch;
  }

.deco_1 {
  position: absolute;
  right: -765.457px;
  bottom: -285.841px;
  z-index: -1;
}
#fv .content_r .fv_img  {
  width: 630px;
  margin-bottom: -30px;
  margin-top: -32px;
}

/* ---------------strength_point------------------*/
.strength_point {
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: flex-end;
  align-items: center;
  width: fit-content;
  position: absolute;
  right: -0.335px;
  top: -32px;
}

.strength_point img {
  width: 104px;
}
/* ---------------security------------------*/

#fv .security_wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 14px;
  margin-top: -30px;
}

#fv .security_wrap .siteseal_img {
  display: flex;
  gap: 20px;
}
#fv .security_wrap .siteseal_img img{
  width: 100px;
  border: 2px solid #EAF7EC;
}
#fv .security_wrap p {
  text-align: right;
  font-size: 1rem;
  line-height: 1.5;
}
#fv .security_wrap  a{
  color:#0065B3;
  text-decoration: underline;
}

/* ---------------FVボタン------------------*/

.fv_btn_wrapper {
    position: relative;
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: 12px;
}
.fv_btn_wrapper .fv_btn_micro {
  width: 100%;
  margin-left: 167px;
}
.fv_btn_wrapper .fv_btn_micro img {
  width: 196px;
  height: 47px;
}

.interactive-button {
    display: flex;
    align-items: center;
    text-decoration: none;
    position: relative;
    width: 433px;
    height: 71px;
    border-radius: 9px;
    box-shadow: 0 4px 12px rgba(143, 110, 85, 0.40);
    z-index: 0; 
}
.interactive-button::before,
.interactive-button::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 9px;
}

/* グラデーション1 */
.interactive-button::before {
  transition: all 0.6s; /* アニメーション実行時間 */
  z-index: -1;
  background: linear-gradient(90deg, #F20066 39.06%, #F27400 85.67%, #F2DE00 128.07%);
}

/* グラデーション2 */
.interactive-button::after {
  z-index: -2;
  background: linear-gradient(90deg, #F20066 26.98%, #F27400 68.91%, #F2DE00 111.92%);
}

.fv_btn_content {
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    margin-left: 120px;
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}

.fv_btn_title {
    color: #ffffff;
    font-size: 2.4rem;
    font-weight: bold;
    letter-spacing: 0.04em;
    line-height: 1.3;
    white-space: nowrap;
}

.fv_btn_wrapper .images-stack {
    position: absolute;
    left: 17px;
    top: 5.4px;
}
.fv_btn_wrapper .doc {
    position: absolute;
    width: 68px;
    height: 46px;
    box-shadow: -2px 5px 12px rgba(0,0,0,0.25);
    background-size: cover;
    background-position: center top;
    transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
    transform-origin: bottom left; /* 左下を起点にして広がるようにする */
}

.fv_btn_wrapper .bk_2 {
    right: 130px;
    position: absolute;
    width: 535px;
    height: 123px;
    top: 232px;
    opacity: 0.5;
}

.fv_btn_wrapper .doc-4 {
    z-index: 1;
    transform: translate(0%,-3%);
}
.fv_btn_wrapper .doc-3 {
    z-index: 2;
    transform: translate(10%, 12%);
}
.fv_btn_wrapper .doc-2 {
    z-index: 3;
    transform: translate(20%, 27%);
}
.fv_btn_wrapper .doc-1 {
    z-index: 4; /* 一番手前 */
    transform: translate(30%, 44%);
}

@media (hover: hover) and (pointer: fine) {
.interactive-button:hover::before {
  opacity: 0;
  transition: all 0.4s;
}

.interactive-button:hover {
    width: 460px; 
    box-shadow: 0 4px 25px rgba(143, 110, 85, 0.40);
    opacity: 1;
    transition: all 0.3s ease;
}
/* Hover時: 文字全体が少し右にずれる */
.interactive-button:hover .fv_btn_content {
    transform: translateX(22px);
    transition: all 0.3s;
}
  /* Hover時: 扇状の広がりを少し抑えて展開する */
.interactive-button:hover .doc-4 {
    transform: translate(-12%,-22%) rotate(-20deg) scale(1.2);
}
.interactive-button:hover .doc-3 {
    transform: translate(4%, -1%) rotate(-16deg) scale(1.2);
}
.interactive-button:hover .doc-2 {
    transform: translate(20%, 21%) rotate(-10deg) scale(1.2);
}
.interactive-button:hover .doc-1 {
    transform: translate(30%, 42%) scale(1.2);
}
}
/* ---------

about

------------*/
#about {
  position: relative;
  margin: 0 auto 112px auto;
}
#about .bk {
  display: block;
  width: 1622px;
  height: 1096px;
  position: absolute;
  top: -77.488px;
  background: linear-gradient(180deg, rgba(236, 239, 227, 0.40) 0%, rgba(233, 241, 240, 0.40) 85.72%, rgba(255, 255, 255, 0.40) 102.6%);
  filter: blur(50px);
  z-index: -10;
}
.deco_2 {
  position: absolute;
  right: -160px;
  top: -116px;
  z-index: -1;
}
.about_wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 56px;
}
.concept {
  display: flex;
  width: 954px;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.concept h2 {
  color: #296767;
  text-align: center;
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.75;
  letter-spacing: 0.14em;
}
.concept h2 span {
  background: linear-gradient(90deg, #25C4B1 28%, #ADD126 75%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.concept .content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  align-self: stretch;
}
.concept .content .txt {
  display: flex;
  width: 508px;
  flex-direction: column;
  align-items: flex-start;
  gap: 32px;
}
.concept .content p {
  color: #296767;
  font-size: 2.4rem;
  line-height: 2.28;
  letter-spacing: 0.15em;
}
.solution {
  display: flex;
  width: 1148px;
  justify-content: center;
  align-items: center;
  background-image: url('https://s3.ap-northeast-1.amazonaws.com/img.kireini.me/connect/web/top/glass_bk.png');
  background-size: cover;
  background-position: center;
  padding: 60px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
  border-radius: 52px;
  background-repeat: no-repeat;
}
.solution_wrap {
  display: flex;
  width: 954px;
  flex-direction: column;
  align-items: center;
  gap: 56px;
  flex-shrink: 0;
}
.solution .ttl h2 {
  display: flex;
  align-items: center;
  gap: 18px;
  color: #296767;
  text-align: center;
  font-size: 2.6rem;
  line-height: 1.5;
  letter-spacing: 0.18em;
}
.solution .ttl figure img {
  width: 274px;
}
.solution .ttl h2 span {
  color: #1C9898;
}
.solution .content {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}
.solution .content li {
  display: flex;
  width: 258px;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  flex-shrink: 0;
}
.solution .content li .num {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 11px;
  position: relative;
}
.solution .content li .num::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  background-color: #0C6B6B;
  filter: blur(16px);
  position: absolute;
  left: 3px;
  top: -2.281px;
}
.solution .content li h3 {
  color: #296767;
  text-align: center;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.solution .content li h3 strong {
  color: #1C9898;
  font-size: 2.4rem;
  letter-spacing: 0.16em;
}


/* ---------

訴求エリア

------------*/
.appeal {
  position: relative;
}

.appeal .sokyu span {
  color: #1C9898;
}

.appeal .sokyu_txt .v-cut-border-box {
    border: none;
    border-bottom: 2px solid;
    border-image: linear-gradient(93deg, #25C3B1 36.3%, #C4D30F 102.19%);
    border-image-slice: 1;
}
.appeal .sokyu_txt .v-cut-shape::after {
  background: #4bc99f;
}
.appeal .sokyu {
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
.appeal .sokyu p {
  font-size: 2.2rem;
  line-height: 1.6;
  color: #707F86;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.scroll-wrap {
  display: flex;
  animation: scroll 26s linear infinite;
  animation-timing-function: linear;
  transform: translateX(0);
  padding: 60px 0 130px 0;
  width: 5842px;
  /*ロゴが増えたら２段になるように調整*/
  gap: 44px;
}

.appeal ul {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 50px 32px;
  align-items: stretch;
  /* 高さを揃える */
  flex-wrap: wrap;
  justify-content: space-between;
}

.appeal li {
  flex: 0 0 auto;
  /* 横幅は内容に応じて可変 */
  text-align: center;
  display: flex;
  align-items: center;
  /* 垂直中央揃え */
  justify-content: center;
  min-height: 30px;
  /* 最低の高さを設定 */
  padding: 0 10px;
}

.appeal li img {
  height: 54px;
}

.appeal_sousyoku_line {
  text-align: center;
  margin: 8px 0 8px;
}

.appeal_sousyoku_line img {
  width: 689px;
}

@keyframes scroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}
/* ---------

#feature

------------*/
#feature {
  display: flex;
  padding-bottom: 128px;
  flex-direction: column;
  align-items: center;
  gap: 56px;
  align-self: stretch;
}
.feature_wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 120px;
}
.feature_content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 120px;
}
#feature .index {
  display: flex;
  width: 953px;
  height: 268px;
  justify-content: space-between;
  align-items: flex-start;
  align-content: space-between;
  flex-wrap: wrap;
}
#feature .index_btn {
  display: flex;
  width: 280px;
  height: 118px;
  padding: 16px 16px 10px 16px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  border-radius: 11px;
  border: 1px solid #7BB6B6;
  box-shadow: 0px 2px 8px 0 #15787833;
}
.index_btn_wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-end;
  flex-shrink: 0;
  align-self: stretch;
  width: 100%;
  height: 100%;
  
}
.index_btn_wrapper .num {
  color: #4F8888;
  text-align: center;
  line-height: 1.5;
  align-self: stretch;
}
.index_btn_wrapper .index_txt {
  align-self: stretch;
  color: #384D4D;
  text-align: center;
  font-size: 1.8rem;
  line-height: 1.3;
  letter-spacing: 0.24em;
  font-weight: 500;
}
.index_btn_wrapper .index_txt span {
  color: #1C9898;
  font-weight: bold;
}
.index_btn_wrapper .readmore {
  display: flex;
  padding: 0 3px 4px 3px;
  justify-content: center;
  align-items: center;
  gap: 7px;
  position: relative;
}
.index_btn_wrapper .readmore p {
  color: #7BB6B6;
  text-align: right;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  text-wrap: nowrap;
}
.index_btn_wrapper .readmore::after {
  content: "";
  width: 29px;
  height: 29px;
  border-radius: 30px;
  position: absolute;
  right: -8.5px;
  top: -8.477px;
  background-color: #F2F8F8;
  z-index: -1;
}
#feature .index_btn:hover {
    opacity: 0.85;
    box-shadow: 0px 2px 24px 0px #15787833;
    border: 1px solid #85caca;
}
#feature .ttl_wrap {
  display: flex;
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  line-height: 1.5;
  letter-spacing: 0.24em;
}
#feature .ttl_wrap .num {
  display: flex;
  align-items: center;
  gap: 18px;
  color: #1C9898;
  font-size: 3rem;
  font-weight: 400;
}
#feature .ttl_wrap .num::after {
  content: "";
  display: inline-block;
  width: 138px;
  height: 1px;
  background-color: #1C9898;
}
#feature .ttl_wrap .ttl {
  color: #384D4D;
  font-size: 3rem;
  font-weight: 700;
}
#feature .ttl_wrap .ttl span {
  color:#1C9898;
}
.feature_content_wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 104px;
  align-items: stretch;
}
.feature_content .feature {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 60px;
}
.content_wrap {
  width: 100%;
}
/* ---------#feature_1------------*/
#feature_1 .content_wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}
#feature_1 .content_wrap .deco_3 {
  position: absolute;
  left: -410px;
  bottom: -58px;
  z-index: -1;
}
#feature_1 .content_row_1st {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 16px;
}
#feature_1 .content_row_2nd {
  display: flex;
  width: 894px;
  justify-content: space-between;
  align-items: center;
  position: relative;
}
#feature_1 .content_row_2nd .circle {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  background-color: #CAE6E4;
  border-radius: 50%;
}
#feature_1 .content_row_2nd::after {
  content: "";
  width: 100vw;
  height: 5px;
  position: absolute;
  top: 8px;
  background-color: #CAE6E4;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
#feature_1 .content_row_3rd {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 16px;
}
#feature_1 .content {
  display: flex;
  width: 275px;
  flex-direction: column;
  align-items: center;
}
#feature_1 .content::after {
  content: "";
  width: 2px;
  height: 36.5px;
  background-color: #CAE6E4;
  display: inline-block;
}
#feature_1 .content_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  align-self: stretch;
}
#feature_1 .content_txt_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
#feature_1 .content_ttl {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #296767;
  text-align: center;
  font-size: 2.2rem;
}
#feature_1 .content_ttl h4 {
  font-weight: bold;
  line-height: 1.5;
  letter-spacing:0.16em;
}
#feature_1 .content_ttl .num {
  font-weight: 400;
}
#feature_1 .content_txt_inner .txt {
  color: #384D4D;
  text-align: center;
  font-size: 1.4rem;
  line-height: 1.4;
  letter-spacing: 0.12em;
  text-wrap: nowrap;
  font-weight: 500;
}
#feature_1 .content_row_3rd .content {
  flex-direction: column-reverse;
}
#feature_1 .content_row_3rd .content_inner {
  flex-direction: column-reverse;
}
/* ---------#feature_2------------*/
#feature_2 .content_wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}
#feature_2 .content_wrap::before {
  content: "";
  width: 1148px;
  height: 139px;
  background: linear-gradient(90deg, rgba(235, 244, 244, 0.00) 0%, #EBF4F4 18.33%, #EBF4F4 81%, rgba(235, 244, 244, 0.00) 100%);
  position: absolute;
  top: 87.65px;
  z-index: -1;
}
#feature_2 .content {
  display: flex;
  width: 310px;
  flex-direction: column;
  align-items: center;
  gap: -4px;
  flex-shrink: 0;
  align-self: stretch;
}
#feature_2 .content_txt_inner {
  display: flex;
  width: 295px;
  padding: 16px 16px 24px;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  border-radius: 7px;
  border: 1px solid #387272;
  background: #FFF;
  box-shadow: 5px 6px 0 0 #387272;
}
#feature_2 .content_txt_inner h4 {
  color: #296767;
  text-align: center;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.12em;
}
#feature_2 .content_txt_inner h4 span {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.098em;
}
#feature_2 .content_txt_inner p {
  color: #384D4D;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
#feature_2 .autolink {
  display: flex;
  padding-bottom: 63px;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  position: relative;
  width: 88px;
}
#feature_2 .autolink .icon_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 33px;
}
#feature_2 .autolink .arrow_icon {
  position: absolute;
  left: 1px;
  top: 26.055px;
}
#feature_2 .autolink .icon_inner p {
  color: #387272;
text-align: center;
font-size: 2rem;
font-style: normal;
font-weight: 700;
line-height: 1.5;
letter-spacing: 0.1em;
}
/* ---------#feature_3------------*/
#feature_3 .content_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 88px;
}
#feature_3 .content_txt_inner {
  display: flex;
  width: 358px;
  flex-direction: column;
  align-items: flex-start;
  gap: 88px;
  flex-shrink: 0;
}
#feature_3 .content_txt_inner .txt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  align-self: stretch;
  line-height: 1.5;
  letter-spacing: 0.12em;
  position: relative;
}
#feature_3 .content_txt_inner .txt h4 {
  color: #296767;
  font-size: 2.2rem;
  font-weight: 700;
}
#feature_3 .content_txt_inner .txt p {
  color: #384D4D;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
#feature_3 .content_txt_inner .txt::after {
  content: "";
  display: inline-block;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  position: absolute;
  left: -36.453px;
  top: -35px;
  background: linear-gradient(191deg, rgba(37, 195, 177, 0.08) 13.37%, rgba(196, 211, 15, 0.08) 91.46%);
  opacity: 0.9;
  filter: blur(4.849999904632568px);
}
/* ---------#feature_4------------*/
#feature_4 .content_wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;

}
#feature_4 .content_wrap .content {
  display: flex;
  width: 330px;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  flex-shrink: 0;
  align-self: stretch;
}
#feature_4 .content_wrap .line {
  width: 1px;
  height: 327px;
  background-color: #CAE6E4;
}
#feature_4 .content_txt_inner h4 {
  color: #296767;
  text-align: center;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.12em;
}
#feature_4 .content_txt_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  align-self: stretch;
}
#feature_4 .content_txt_inner p {
  color: #384D4D;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
/* ---------#feature_5------------*/
#feature_5 .content_wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;

}
#feature_5 .content_wrap .content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 48px;
  width: 540px;
}
#feature_5 .content_wrap .line {
  width: 1px;
  height: 327px;
  background-color: #CAE6E4;
}
#feature_5 .content_txt_inner h4 {
  color: #296767;
  text-align: center;
  font-family: "Helvetica Neue";
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.12em;
}
#feature_5 .content_txt_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  align-self: stretch;
  padding: 0 32px;
}
#feature_5 .content_txt_inner p {
  color: #384D4D;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
/* ---------#feature_6------------*/
#feature_6 .content_wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;

}
#feature_6 .content_wrap .content {
  display: flex;
  width: 330px;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  flex-shrink: 0;
  align-self: stretch;
}
#feature_6 .content_wrap .line {
  width: 1px;
  height: 327px;
  background-color: #CAE6E4;
}
#feature_6 .content_txt_inner h4 {
  color: #296767;
  text-align: center;
  font-family: "Helvetica Neue";
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.12em;
}
#feature_6 .content_txt_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  align-self: stretch;
}
#feature_6 .content_txt_inner p {
  color: #384D4D;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
/* ---------

CTABOX1

------------*/
#cta_box_1 {
  background-color: #06A9AA;
  padding: 75px 0 56px;
}
.cta_box_1_wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  gap: 54px;
}
.cta_box_1_wrap p {
  color: #fff;
  font-size: 3.2rem;
  font-weight: bold;
  text-align: center;
}
.cta_box_1_wrap .btn_wrap {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: 48px;
  align-items: center;
}
.cta_box_1_wrap .btn_wrap a:first-child {
  background: linear-gradient(90.94deg, #F30166 0.42%, #F37401 108.72%);
}
.cta_box_1_wrap .btn_wrap a:nth-child(2) {
  background: #fff;
  padding: 26px 12px 24px 0;
}
.cta_box_1_wrap .btn_wrap a:nth-child(2) div {
    color: #1C9898;
}
.cta_box_1_wrap .btn_wrap .second-button {
  width: 345px;
}
.cta_box_1_wrap .left {
  width: fit-content;
  position: absolute;
  left: -100px;
  top: -47px;
}
.cta_box_1_wrap .right {
  width: fit-content;
  position: absolute;
  right: -70px;
  top: -37px;
}


/* ---------

機能 #FUNCTION

------------*/
#FUNCTION {
  display: flex;
  flex-direction: column;
  gap: 48px;
  padding: 80px 0 120px;
}
.function_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}
.function_inner a {
  display: block;
  width: 337px;
}
.function_wrap_1, .function_wrap_2, .function_wrap_3 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
}
.function_wrap_1, .function_wrap_2 {
  border-bottom: 1px solid;
  border-image: linear-gradient(93deg, #25C3B1 36.3%, #C4D30F 102.19%) 1;
  padding-bottom: 40px;
}
.function_content .content_inner {
  display: flex;
  width: 337px;
  height: 390px;
  flex-direction: column;
  align-items: flex-start;
  gap: 32px;
}
.function_content figure {
  width: 100%;
  overflow: hidden;
  transform: translate3d(0, 0, 0);
  border-radius: 32px;
}
.function_content figure img {
  width: 100%;
}
.function_inner a:hover {
    opacity: 1;
}
.function_content .txt_wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  align-self: stretch;
}
.function_content h3 {
  font-size: 2.2rem;
  color: #1C9898;
  font-weight: bold;
  display: flex;
  align-items: center;
}
.function_content span {
  display: inline-block;
  margin-left: 1rem;
  text-align: center;
}
.function_content .fa-arrow-right {
  font-family: "Font Awesome 5 Free";
  border: 2px solid #1C9898;
  width: 27px;
  height: 27px;
  font-size: 1.4rem;
  border-radius: 50%;
  font-style: normal;
  color: #1C9898;
  line-height: 27px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.function_content .txt_wrap p {
  font-size: 1.4rem;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
@media (hover: hover) {
  .function_content :hover .txt_wrap p {
    color: #1C9898;
    transition: color 200ms cubic-bezier(0.25, 0.25, 0.75, 0.75);
  }
  .function_content :hover figure img {
    transform: scale(1.1);
    transition: transform 1200ms cubic-bezier(0.22, 0.07, 0, 0.98);
  }
  .function_content :hover .fa-arrow-right {
    background-color: #1C9898;
    transition: color 200ms cubic-bezier(0.25, 0.25, 0.75, 0.75);
  }
  .function_content :hover .fa-arrow-right:before {
    color: #ffffff;
    transition: color 200ms cubic-bezier(0.25, 0.25, 0.75, 0.75);
  }
}

/* ---------

選ばれる理由 #REASON

------------*/
#REASON {
  background: linear-gradient(39deg, #DFF6F3 21.66%, #F3F8DF 85.11%);
  padding: 72px 0 88px 0;
}
.reason_inner {
  
}
.reason_wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 64px 0;
}
.reason_wrapper .reason_content {
  display: flex;
  width: 372px;
  height: 520px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  border-radius: 18px;
  background: #FFF;
  box-shadow: 0 0 17.235px 1.843px rgba(20, 159, 159, 0.27);
  text-align: center;
}
.reason_content .content_inner {
  position: relative;
  padding: 44px 18px 0 18px;
}
.reason_content .content_inner h3 {
  color: #1C9898;
  text-align: center;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.45;
  letter-spacing: 0.1em;
}
.reason_wrapper .num {
  width: 88px;
  height: 88px;
  margin: 0 auto;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}
.reason_wrapper .num img {
  width: 100%;
  height: 100%;
}
.reason_wrapper .txt_wrapper {
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
}

.reason_wrapper .txt_wrapper li p {
  text-indent: calc(-1.6rem - 4px);
  margin-left: calc(1.6rem + 4px);
  line-height: 1.3;
}
.reason_wrapper .txt_wrapper li i {
  font-family: "Font Awesome 5 Free";
  margin-right: 5px;
  color: #384D4D;
  font-style: normal;
  font-size: 1.4rem;
}
.reason_content .tag {
  display: flex;
  width: 372px;
  height: 74px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  border-radius: 16px;
  border: 5px solid #FFF;
  background: #EFF7F3;
  color: #384D4D;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.084em;
  text-align: left;
  padding-top: 4px;
}
.reason_content .tag p {
  text-indent: calc(-1.6rem - 4px);
  margin-left: calc(1.6rem + 4px);
}
.reason_content .tag i {
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  margin-right: 3px;
  color: #1C9898;
  font-style: normal;
}
.reason_content .underline {
  color: #1C9898;
  font-weight: bold;
  text-decoration: underline;
  text-underline-offset: 4px;
}
#REASON .second-button div {
  margin-left: -5px;
}
#REASON .second-button i {
  right: 3rem;
}
/* ---------

導入事例 #CASE

------------*/
#CASE {
  padding: 80px 0 88px;
}
/* ---------

プラン・料金 #PRICE

------------*/
#PRICE {
  background-color: #EFF7F3;
  padding: 72px 0 88px;
}
#PRICE .second_inner {
  display: flex;
  flex-direction: column;
  gap: 56px;
}
.price_detail {
  display: flex;
  height: 83px;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  margin-bottom: -16px;
}
.price_detail .txt_left {
  display: flex;
  padding: 24px 32px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 8px 0 0 8px;
  border: 4px solid #1C9898;
  background: #FFF;
  font-size: 2.6rem;
  line-height: 1.33;
  letter-spacing: 0.077em;
  color: #1C9898;
}
.price_detail .txt_right {
  display: flex;
  height: 89.78px;
  padding: 0 32px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 0 8px 8px 0;
  background: #1C9898;
  font-size: 3.2rem;
  line-height: 0.87;
  letter-spacing: 0.13em;
  color: #fff;
}
.price_detail .txt_right .circle {
  display: flex;
width: 67px;
height: 67px;
padding: 13px 7px 11px;
flex-direction: column;
justify-content: center;
align-items: center;
gap: 10px;
border-radius: 50%;
background: #FFF;
font-size: 1.8rem;
line-height: 1.1;
letter-spacing: -0.03em;
color: #1C9898;
}
.price_detail .txt_right .first_price {
  display: flex;
  align-items: flex-end;
}
.price_detail .first_price .zero {
  text-shadow: 3.2px 1.6px 0 #7CC2C9;
  font-size: 7.5rem;
  line-height: 0.78;
  margin-right: -11px;
}
.price_detail .first_price .en {
  text-shadow: 1.516px 1.516px 0 #7CC2C9;
  font-size: 2.6rem;
  line-height: 0.69;
}

.table-wrap {
  margin-bottom: 48px;
}

#PRICE .table-scroll table {
  border-collapse:separate;
  border-spacing: 0;
  width: 100%;
border-right: 1px solid #EDEDED;
    background-color: #fff;
}
#PRICE .table-scroll th{
  text-align: center;
}
#PRICE .table-scroll .sticky {
  background: #F9F9F9;
  color: #333;
  width:auto;
  vertical-align: middle;
}
#PRICE .table-scroll .sticky.kara{
    background: #fff;
    border-left: none;
}
#PRICE .table-scroll .plan_name {
  width: 255px;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1;
  padding: 0;
  position: relative;
}
#PRICE .table-scroll .plan_name strong{
  font-size: 2.4rem;
  display: block;
  margin: 10px 0 0px;;
}
#PRICE .table-scroll .plan_name .price_box {
  padding: 16px 0;
  font-weight: bold;
  font-size: 2rem;
}
#PRICE .table-scroll .plan_name.plan01 {
  background: #7EAA4D;
}
#PRICE .table-scroll .plan_name.plan02 {
  background: #C0529B;
}
#PRICE .table-scroll .plan_name.plan03 {
  background: #1B4DC3;
}
#PRICE .table-scroll .plan_name.plan04 {
  background: #BDAE24;
}


#PRICE .table-scroll .plan_name .price_box strong{
  font-size: 4rem;
  display: inline-block;
  font-weight: 500;
  margin: 0 5px;
}
#PRICE .table-scroll .plan_txt {
  text-align: left;
  margin: 6px 0 0 2px;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #4C4C4C;
}

#PRICE .table-scroll .plan_txt li{
  font-size: 1.4rem;
  list-style: none;
  text-indent: calc(-1.6rem - 2px);
  margin-left: calc(1.6rem + 1px);
}
#PRICE .table-scroll .plan_txt li i {
    font-family: "Font Awesome 5 Free";
    margin-right: 5px;
    color: #384D4D;
    font-style: normal;
    font-size: 1.4rem;
}
#PRICE .table-scroll .demo_app{
  display: inline-block;
  border-radius: 26px;
  text-align: center;
  font-weight: bold;
  font-size: 2rem;
  padding: 14px 26px 10px;;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.20);
  background-color: #FFF;
  margin-bottom: 28px;
}
#PRICE .table-scroll .plan04 .demo_app{
  color: #BDAE24;
}
#PRICE .table-scroll .plan03 .demo_app{
  color: #1B4DC3;
}
#PRICE .table-scroll .plan02 .demo_app{
  color: #C0529B;
}
#PRICE .table-scroll .plan01 .demo_app{
  color: #7EAA4D;
}
#PRICE .table-scroll td:first-of-type .demo_app{
	background: #BDAE24;
}
#PRICE .table-scroll td:nth-of-type(2) .demo_app{
	background: #1B4DC3;
}
#PRICE .table-scroll td:nth-of-type(3) .demo_app{
	background: #C0529B;
}
#PRICE .table-scroll td:nth-of-type(4) .demo_app{
	background: #7EAA4D;
}


#PRICE .table-scroll .plan_name .this_name{
  padding-top: 30px;
	border-top: 1px solid #EDEDED;
  font-weight: bold;
  font-size: 1.5rem;
}


#PRICE .table-scroll table th,
#PRICE .table-scroll table td{
    text-align: center;
    padding: 10px;
    color: #A9A9AD;
    border-bottom: 1px solid #EDEDED;
    border-left: 1px solid #EDEDED;
}
#PRICE .table-scroll td .circle{
  fill: none;
            stroke-width: 4;
}
#PRICE .table-scroll td:first-of-type .circle{
	stroke: #BDAE24;
}
#PRICE .table-scroll td:nth-of-type(2) .circle{
	stroke: #1B4DC3;
}
#PRICE .table-scroll td:nth-of-type(3) .circle{
	stroke: #C0529B;
}
#PRICE .table-scroll td:nth-of-type(4) .circle{
	stroke: #7EAA4D;
}
#PRICE .table-scroll .can_select{
  color: #1B4DC3;
  font-weight: bold;
  font-size: 1.8rem;
  background: linear-gradient(64deg, #DFF6F3 11.81%, #F3F8DF 130.66%);
}
#PRICE .table-scroll .can_select strong{
  font-size: 3.2rem;
  font-weight: 500;
}
#PRICE .add_note{
  font-size: 1.4rem;
  margin: 10px 5px;
}
#PRICE .add_note strong{
  font-size: 1.8rem;
}
#PRICE .note{
    background: none;
    margin-top: 10px;
    opacity: 0.4;
    font-size: 1.4rem;
}

#PRICE .security{
  text-align: left !important;
  color: #333333 !important;
  line-height: 1.7 !important;
  padding: 8px 14px 8px 24px !important;
}
#PRICE .security .siteseal_img{
  float:right;
  padding-top: 10px;
}
#PRICE .security .siteseal_img img{
  width: 120px;
  margin-left: 8px;
}
#PRICE .security a{
  font-weight:700;
  color:#0065B3;
  text-decoration: underline;
}

/* ---------

パートナー #PARTNER

------------*/
#PARTNER {
  padding-top: 88px;
  padding-bottom: 96px;
  position: relative;
}

#PARTNER .partnerWrap {
  width: 1040px;
  margin: 0 auto;

  margin-top: 30px;
}

#PARTNER .inner h3 {
  font-weight: bold;
  color: #1C9898;
  font-size: 2.8rem;
  margin-bottom: 8px;
  width: 100%;
  line-height: 1.6;
}

#PARTNER .inner .dr-info img {
  width: 150px;
  float: left;
  margin-right: 20px;
}

#PARTNER .inner .role {
  background: #EFF7F3;
  padding: 5px;
  line-height: 1;
  display: inline-block;
  margin-bottom: 20px;
}

#PARTNER .inner .name {
  line-height: 1.5;
}

#PARTNER .inner .name strong {
  font-size: 2.4rem;
  display: inline-block;
  margin-top: 10px;
}

#PARTNER .inner p {
  font-size: 1.8rem;
  line-height: 1.8;
}

#PARTNER .ninoDr_txt {
  width: 577px;
}


#PARTNER .inner {
  margin-top: 100px;
}

#PARTNER .inner .dr-info {
  width: 40%;
}

#PARTNER .carrer {
  border-top: 1px solid #ccc;
  padding-top: 5px;
  font-size: 1.4rem;
  margin-top: 20px;
}

#PARTNER .carrer li {
  margin-top: 5px;
  line-height: 1.5;
}


#PARTNER .in_ninoDr {
  height: 380px;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}

#PARTNER .in_ninoDr .carrer {
  width: 40%;
}

#PARTNER .nukiDr {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#PARTNER .nukiDr .carrer {
  display: flex;
  width: 100%;
  justify-content: space-between;
}

/* ---------

よくある質問

------------*/
#qa {
  background-color: #F6F9F9;
  padding: 72px 0 88px 0;
  display: flex;
  gap: 64px;
  flex-direction: column;
  align-items: center;
}
.accordion {
    max-width: 100%;
    margin-bottom: 7px;
    border-bottom: 1px solid #1c9898;
}

.accordion summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 24px 32px 24px 3px;;
    color: #384d4d;
    font-weight: 600;
    cursor: pointer;
    font-size: 2rem;
}
.accordion summary div {
  display: flex;
  gap: 24px;
}
.accordion summary div span:first-child {
  color: #128B8B;
  font-weight: bold;
}
.accordion summary::-webkit-details-marker {
    display: none;
}

.accordion summary::before,
.accordion summary::after {
    width: 3px;
    height: .9em;
    border-radius: 5px;
    background-color: #1C9898;
    content: '';
}

.accordion summary::before {
    position: absolute;
    right: 1.6em;
    rotate: 90deg;
}

.accordion summary::after {
    transition: rotate .3s;
}

.accordion[open] summary::after {
    rotate: 90deg;
}

.accordion p {
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    color: #384d4d;
    transition: transform .5s, opacity .5s;
}

.accordion[open] p {
    transform: none;
    opacity: 1;
    line-height: 1.5;
}
.open_txt {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 0 46px 24px 46px;
}
.open_txt span {
  color: #128B8B;
  font-weight: bold;
}
.open_txt p a {
  color: #0065B3;
  text-decoration-line: underline;
}

/* ---------

ニュース　#NEWS

------------*/
#NEWS {
  width: 800px;
  margin: 80px auto 104px auto;
}

#NEWS h4 {
  width: 100%;
}

#NEWS .moreLink {
  font-size: 2rem;
  line-height: 1;
  color: #1C9898;
  font-weight: 700;
  letter-spacing: 2px;
}

#NEWS .news_list {
  margin-top: 32px;
  margin-bottom: 26px;
}

#NEWS .news_list li {
  border-bottom: 1px solid #D9D9D9;
}

#NEWS .news_list a {
  padding: 24px 0;
  display: block;
}

#NEWS .day {
  color: #999;
  width: 30%;
  font-weight: bold;
  font-size: 1.4rem;
}

#NEWS .news_txt {
  line-height: 1.5;
  width: 100%;
  margin-top: 8px;
}

#NEWS .news_list a.blank {
  position: relative;
}

#NEWS .news_list a.blank::after {
  position: absolute;
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  background-image: url(https://s3.ap-northeast-1.amazonaws.com/img.kireini.me/connect/web/event/re_top/blank_ico.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  bottom: 10px;
  right: 0;
}

/* ---------

フローティングバナー

------------*/
.footer_wrap {
    position: relative;
}
.floating-banner {
  height: 72px;
  position: fixed;
  bottom: 0px;
  z-index: 10;
  left: 50%;
  transform: translateX(-50%);
  background-color: rgba(230, 240, 235, 0.85);
  color: #1C9898;
  font-weight: bold;
  font-size: 1.8rem;
  text-align: center;
  align-content: center;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 24px;
  justify-content: center;
}
.floating-banner div {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
}
.floating-banner div span {
  padding: 6px 8px 4px;
  border-radius: 5px;
  border: 1px solid #1C9898;
}
.floating-banner a {
	display: block;
  padding: 16px 23px;
  border-radius: 9px;
  border: 2px solid #1C9898;
  background: #FFF;
  color: #1C9898;
  text-align: center;
  box-shadow: 0 2px 4px 0 rgba(28, 139, 139, 0.25);
}
.close-btn {
  display: inline-block;
  width: 23px;
  height: 23px;
  border-radius: 50%;
  background-color: #A6C4B7;
  position: relative;
  top: -20px;
}
.close-btn:hover {
  opacity: 0.5;
  cursor: pointer;
}
.close-btn::before, .close-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px;
  height: 11px;
  background: #ffffff;
}
.close-btn::before {
  transform: translate(-50%,-50%) rotate(45deg);
}
.close-btn::after {
  transform: translate(-50%,-50%) rotate(-45deg);
}
.hidden {
    opacity: 0;
    visibility: hidden;
  }

/* ---------

内CVbtn

------------*/
.cv_btn_area {}

.cv_btn_area .camtpaign_txt {}

.cv_btn_area .camtpaign_txt::after {}

.cv_btn_area .btn_list {}

.cv_btn_area .btn_list .soudan_form {}

.cv_btn_area .btn_list .document_form {}

.cv_btn_area .btn_list .cv_btn {
  display: flex;
  border-radius: 35px;
  height: 66px;
  width: 320px;
  justify-content: center;
  color: #fff;
  font-size: 2rem;
  line-height: 1;
  font-weight: bold;
  place-items: center;
  text-align: center;
  transition: .3s ease;
  box-shadow: 0 2.5rem 2rem -2rem rgb(249 45 25 / 40%);
}

/* ---------

.closing_cv

------------*/
.closing_cv {
  color: #1C9898;
}

.closing_cv .closing_txt {
  font-size: 3.2rem;
  font-weight: bold;
  text-align: center;
}

.closing_cv .close_btn {
  color: #fff;
  display: flex;
  padding: 12px;
  font-weight: bold;
  font-size: 2rem;
  align-items: center;
  border-radius: 10px;
  margin-left: 10px;
  width: 100%;
  max-width: 480px;
  justify-content: center;
  height: 60px;
  margin-inline: auto;
  margin-top: 32px;
}

.closing_cv .tel_wrap {
  display: flex;
  justify-content: center;
  font-weight: bold;
  align-items: center;
  margin-top: 32px;
}

.closing_cv .tel_wrap .tel {
  font-size: 4.8rem;
  border-bottom: 2px solid;
  margin: 0 30px;
}

.closing_contact {
  padding-top: 80px;
}

footer .footer_sublink {
  padding: 64px 0;
}

footer .footer_sublink #csi_siteseal_tag {
  margin-right: 20px;
  display: inline-block;
}

footer .footer_sublink>li:nth-of-type(4) {
  margin-right: 0;
  text-align: right;
  font-size: 0;
}