@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');
@font-face {
  font-family: "icomoon";
  font-display: swap;
  src: url("../font/icomoon.woff") format("woff"), url("../font/icomoon.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}

.icon-arrow-up::before { content: "\e91a"; }
.icon-arrow-down::before { content: "\e917"; }
.icon-arrow-next::before { content: "\e918"; }
.icon-arrow-prev::before { content: "\e919"; }
.icon-arrow-up-round::before { content: "\e933"; }
.icon-arrow-down-round::before { content: "\e91d"; }
.icon-arrow-next-round::before { content: "\e931"; }
.icon-arrow-prev-round::before { content: "\e932"; }
.icon-arrow-up-circle::before { content: "\e916"; }
.icon-arrow-down-circle::before { content: "\e908"; }
.icon-arrow-next-circle::before { content: "\e914"; }
.icon-arrow-prev-circle::before { content: "\e915"; }
.icon-arrow-up-circle2::before { content: "\e92d"; }
.icon-arrow-down-circle2::before { content: "\e92a"; }
.icon-arrow-next-circle2::before { content: "\e92b"; }
.icon-arrow-prev-circle2::before { content: "\e92c"; }
.icon-angle1-up::before { content: "\e903"; }
.icon-angle1-down::before { content: "\e900"; }
.icon-angle1-next::before { content: "\e901"; }
.icon-angle1-prev::before { content: "\e902"; }
.icon-angle2-up::before { content: "\e907"; }
.icon-angle2-down::before { content: "\e906"; }
.icon-angle2-next::before { content: "\e91f"; }
.icon-angle2-prev::before { content: "\e91e"; }
.icon-angle2-double-next::before { content: "\e904"; }
.icon-angle2-double-prev::before { content: "\e905"; }
.icon-broom::before { content: "\e909"; }
.icon-car::before { content: "\e90a"; }
.icon-car-side::before { content: "\e929"; }
.icon-home::before { content: "\e91b"; }
.icon-check::before { content: "\e90b"; }
.icon-close::before { content: "\e90c"; }
.icon-freetel::before { content: "\e90e"; }
.icon-tel::before { content: "\e921"; }
.icon-fax::before { content: "\e913"; }
.icon-mail:before { content: "\e90e1"; }
.icon-mail-black::before { content: "\e90d"; }
.icon-note::before { content: "\e90f"; }
.icon-profile::before { content: "\e92e"; }
.icon-download::before { content: "\e922"; }
.icon-minus::before { content: "\e912"; }
.icon-plus::before { content: "\e911"; }
.icon-en::before { content: "\e920"; }
.icon-search::before { content: "\e91c"; }
.icon-search-global::before { content: "\e923"; }
.icon-tire::before { content: "\e924"; }
.icon-exclamation::before { content: "\e925"; }
.icon-return::before { content: "\e926"; }
.icon-bookmark::before { content: "\e927"; }
.icon-diamond::before { content: "\e928"; }
.icon-hamburger::before { content: "\e92f"; }
.icon-gear::before { content: "\e930"; }
.icon-book::before { content: "\e941"; }
.icon-member::before { content: "\e940"; }

/* top 新規追加 */
.icon-angle-next-circle::before { content: "\e910"; }
.icon-angle3-next::before { content: "\e935"; }
.icon-angle3-next-triple::before { content: "\e934"; }
.icon-close2::before { content: "\e936"; }
.icon-hamburger2::before { content: "\e937"; }
.icon-minus2::before { content: "\e938"; }
.icon-plus2::before { content: "\e939"; }
.icon-tel2::before { content: "\e93a"; }

/* icomoondefault */
.icon-menu::before { content: "\e9bd"; }
.icon-checkmark::before { content: "\ea10"; }
.icon-facebook::before { content: "\ea90"; }
.icon-facebook2::before { content: "\ea91"; }
.icon-twitter::before { content: "\ea96"; }

[class^="icon-"], [class*=" icon-"] {
  font-family: icomoon;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* reset */
*, *::before, *::after { box-sizing: border-box; }
body, div, ul, ol, li, dl, dt, dd, h1, h2, h3, h4, h5, h6, p, th, td, form, input, textarea, fieldset, pre, blockquote, figure, figcaption {
  padding: 0;
  margin: 0;
}
body {
  overscroll-behavior-y: none;
  font-feature-settings: "palt";
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", Meiryo, sans-serif;
}
header, footer, nav, menu, main, article, aside, section, details, figcaption, figure {
  display: block;
}
h1, h2, h3, h4, h5, h6, th { font-weight: normal; }
ul, ol { list-style: none; }
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption, th { text-align: left; }
img { vertical-align: bottom; }
a img { border: none; }
a:hover img { text-decoration: none; }
i { font-style: normal; }
@media only screen and (min-width: 768px), print {
  a[href^=tel]:hover {
    text-decoration: none;
  }
}
input, textarea, select, option { font-size: 16px; }

/* ***************************************** */
/* --- 初期設定 --- */
/* ***************************************** */
/* 初期設定 -------------------------------- */
html {
  font-size: 14px;
  color: #000;
}
@media only screen and (min-width: 768px), print {
  html { font-size: 16px; }
}
h1 { line-height: 1; }
h2, h3, h4 {
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  line-height: 1.5;
}
p, li, dt, dd, th, td { line-height: 1.7; }
a {
  text-decoration: none;
  color: inherit;
}
a:hover, a:hover img { text-decoration: none; }
img {
  width: 100%;
  height: auto;
}

p,li,dd {
  font-size: 16px;
}

/* reCAPTCHA非表示 */
.grecaptcha-badge { display: none; }

/* カラー変数 ------------------------------ */
:root {
  --c-red1: #E50012;
  --c-green1: #009D91;
  --c-gray1: #f4f4f4;
}
.m-red{ color: var(--c-red1); }
.m-green{ color: var(--c-green1); }
.m-orange { color: #FF3B00 }


/* ***************************************** */
/* --- メインモジュール --- */
/* ***************************************** */
@media only screen and (max-width: 767px) {
  .m-hidden-sp { display: none; }
}
@media only screen and (min-width: 768px), print {
  .m-hidden-pc { display: none; }
}

/* 見出し ---------------------------------- */
/* m-heading-a */
.m-heading-a{
  position: relative;
  padding: 0 5%;
  margin-bottom: 30px;
  text-align: center;
  font-size: 5vmin;
}
.m-heading-a::after{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -10px;
  display: block;
  content: "";
  width: 16%;
  height: 2px;
  border-radius: 1px;
  background-color: var(--c-green1);
}
.m-heading-a span{
  display: inline-block;
  line-height: 1.4;
  font-size: 0.7em;
}

@media screen and (min-width: 768px), print{
  .m-heading-a{
    padding: 0;
    margin-bottom: 60px;
    font-size: 22px;
  }
  .m-heading-a::after{
    bottom: -20px;
    width: 64px;
    height: 4px;
    border-radius: 2px;
  }
}

/* ボタン ---------------------------------- */
/* コンバージョン */
.btn-wrap{
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 90%;
  margin: auto;
}
.btn-siryo a,
.btn-inquiry a{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 48px;
  border-radius: 24px;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 15px;
  color: #fff;
}
/* .btn-siryo a::after,
.btn-inquiry a::after{
  position: absolute;
  right: 5%;
  font-family: icomoon;
  content: "\e934";
} */
.m-angle-anime{
  display: flex;
  position: absolute;
  transform: scale(0.8, 1);
  right: 5%;
  top: 50%;
  translate: 0 -50%;
  font-size: 0.8em;
}
.m-angle-anime i::before{
  font-family: icomoon;
  content: "\e91f";
}
.m-angle-anime i{
  animation-name: fade;
  animation-fill-mode: both;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  animation-duration: 0.8s;
}
.m-angle-anime i:nth-of-type(2){
  animation-delay: 0.6s
}
.m-angle-anime i:nth-of-type(1){
  animation-delay: 1.2s
}
@keyframes fade{
  0%{ opacity: 1; }
  100%{ opacity: 0; }
}
.btn-siryo a{
  background-image: linear-gradient(120deg, #0193D5, #03D9C9);
}
.btn-inquiry a{
  background-image: linear-gradient(120deg, #FF6200 60%, #FFBA00);
  margin-bottom: 20px;
}
@media screen and (min-width: 768px), print{
  .btn-wrap{
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
    padding: 0 20px;
    width: min(100%, 940px);
  }
  .btn-siryo,
  .btn-inquiry{
    width: 45%;
  }
  .btn-siryo a,
  .btn-inquiry a{
    margin-bottom: 0;
    height: 64px;
    border-radius: 32px;
    font-size: 17px;
    transition: filter 0.3s;
  }
  .btn-siryo a:hover,
  .btn-inquiry a:hover{
    filter: brightness(120%);
  }
}

/* toggleボタン */
.toggle-wrap{
  border-radius: 5px;
  background-color: #fff;
  margin: 0 5%;
  color: #000;
}
.toggle{
  display: none;
  padding: 30px 5% 40px;
}
.toggle-btn{
  position: relative;
  padding: 10px 0;
  border-radius: 5px;
  text-align: center;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 4.5vmin;
  cursor: pointer;
  background-color: var(--c-green1);
}
.toggle-btn::after{
  position: absolute;
  right: 5%;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  font-family: icomoon;
  content: "\e939";
  transition: background-color 0.3s;
}
.toggle-btn.on{ background-color:#80CEC8; }
.toggle-btn.on::after{ content: "\e938"; }
@media screen and (min-width: 768px), print{
  .toggle-wrap{
    border-radius: 10px;
    width: min(90%, 1100px);
    margin: 0 auto;
  }
  .toggle{
    display: none;
    padding: 50px 60px;
  }
  .toggle-btn{
    padding: 20px 0;
    border-radius: 10px;
    font-size: 17px;
    transition: background-color 0.3s;
  }
  .toggle-btn:hover
  { background-color: #80CEC8; }
}

/* .toggle{ display: block !important;} */
/* toggle-close */
.toggle-close{
  width: 152px;
  margin: 30px auto 0;
}
.toggle-close a{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 40px;
  border-radius: 20px;
  border: 2px solid #000;
  background-color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  text-align: center;
  font-size: 15px;
  cursor: pointer;
}
@media screen and (min-width: 768px), print{
  .toggle-close{ transition: background-color 0.3s; }
  .toggle-close:hover{ background-color: var(--c-gray1); }
}



/* ***************************************** */
/* --- ヘッダー --- */
/* ***************************************** */
@media screen and (min-width: 768px), print{
  /* 240605 PCでもheader非表示 */
  header{ display: none !important; }
  header{
    padding: 15px 20px;
  }
  header > div{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: min(100%, 1100px);
    margin: auto;
  }
  header h1{ width: 146px; }
  header .btn-wrap{
    width: auto;
    margin: 0;
    padding: 0;
  }
  header .btn-siryo li,
  header .btn-inquiry li{
    width: auto;
  }
  header .btn-siryo a,
  header .btn-inquiry a{
    gap: 50px;
    width: auto;
    height: 48px;
    padding: 0 80px;
    border-radius: 24px;
    white-space: nowrap;
    font-size: 17px;
  }
}


/* ***************************************** */
/* --- キービジュアル --- */
/* ***************************************** */
.kv{
  position: relative;
  margin-bottom: 150px;
}

/* cv */
.kv .cv{
  position: absolute;
  bottom: -110px;
  width: 90%;
  margin: 0 5%;
  padding: 5vmin 5%;
  border-radius: 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  text-align: center;
  font-weight: 700;
}
/*
.kv .cv > div{
  background: url(../img/cv-img.png) no-repeat center bottom 6.5vmin / 90% auto;
}*/
.kv .cv h2{
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  border-radius: 18px;
  margin-bottom: 0.3em;
  background-color: var(--c-green1);
  font-size: 4.5vmin;
  color: #fff;
}
.kv .cv p:first-of-type{
  font-size: 4vmin;
  line-height: 1.3;
}
@media screen and (min-width: 768px), print{
.kv{
  margin-bottom: 0;
}
  /* cv */
  .kv .cv{
    bottom: 5%;
    width: 100%;
    margin: 0;
    padding: 20px;
    border-radius: 0;
    font-weight: 700;
  }
  .kv .cv > div{
    display: flex;
    justify-content: space-between;
    width: min(100%, 900px);
    margin: auto;
    background: none;
  }
  .kv .cv > div > div{ 
    width: 100%;
    display: flex;
    justify-content: space-around;
  }
  .kv .cv h2{
    position: relative;
    display: table;
    height: auto;
    margin: 0 auto 20px;
    background-color: transparent;
    font-size: 22px;
    color: var(--c-green1);
  }
  .kv .cv h2::before,
  .kv .cv h2::after{
    content: "";
    position: absolute;
    top: 0;
    display: block;
    height: 100%;
    width: 2px;
    background-color: var(--c-green1);
  }
  .kv .cv h2::before{
    left: -18px;
    transform: rotate(-45deg);
  }
  .kv .cv h2::after{
    right: -18px;
    transform: rotate(45deg);
  }
  .kv .cv p:first-of-type{
    line-height: 1.5;
    font-size: 22px;
  }
}

/* ***************************************** */
/* 共通 */
/* ***************************************** */

/* Youtube */
.movie-wrap {
  position: relative;
  padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
  height: 0;
  overflow: hidden;
}
.movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* 背景色 */
.bg-green{
  background: #EFFAF2;
}

/* inner */
.inner{
  width: 90%;
  max-width: 1100px;
  margin: 0 auto;
}

/* 見出し */
section h2{
  overflow: hidden;
  text-align: center;
  font-weight: 700;
  font-size: 7vmin;
  line-height: 1;
}

/* h2.ttl-under */
h2.ttl-under::after{
  display: block;
  content: '';
  width: 64px;
  height: 4px;
  margin: 5vmin auto;
  border-radius: 2px;
  background: #009D91;
}
h2.ttl-under .ttl-small{
  font-size: 70%;
  line-height: 2;
}

/* h2.ttl-under.white */
h2.ttl-under.white{
  color: #fff;
}
h2.ttl-under.white::after{
  background: #fff;
}

/* h3.ttl-01 */
h3.ttl-01{
  width: 100%;
  height: 40px;
  border: 1px solid #009D91;
  border-radius: 20px;
  text-align: center;
  line-height: 38px;
  color: #009D91;
}

.small{
  font-size: 0.8em;
}
.bold {
  font-weight: 700;
}
.m-mt1em{
  margin-top: 1em;
}
.m-mb1em{
  margin-bottom: 1em;
}

/*【Google fonts】oswald-Interview */
.oswald-Interview {
  font-family: "Oswald", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  color: #BFE6E3;
  font-size: 80px;
}

@media screen and (min-width: 768px), print{
  /* 見出し */
  section h2{
    font-size: 36px;
  }
}
@media screen and (min-width: 1024px), print{
  /*【Google fonts】oswald-Interview */
  .oswald-Interview {
    font-size: 110px;
  }
}
/* ***************************************** */
/*【jQuery】要素をグラデーションで隠して開閉するコンテンツの実装
/* ***************************************** */

/*高さを制限しているボックスの要素*/
.container{
  position: relative;
  width: 100%;
  height: 200px;
  padding-bottom: 80px;
  margin: 0 auto;
  overflow: hidden;
  transition: .4s;
  box-sizing: border-box;
}
/*グラデーションで隠す擬似要素*/
.container:before{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100px;
  background: rgb(0,0,0);
  background: linear-gradient(0deg, rgba(239,250,242,1) 70%,
    rgba(255,255,255,0) 100%);
  transition: .4s;
}
/*クラス付与時のスタイル*/
.container.active:before{
  opacity: 0;
  visibility: hidden;
}
/*テキストのスタイル*/
.container p,
.text-box p{
  font-size: 16px;
  line-height: 1.8;
}
/*ボタンのスタイル*/
.container button{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 20px;
  margin: 0 auto;
  width: 150px;
  height: 40px;
  background: #EFFAF2;
  cursor: pointer;
  color: #000;
  border: none;
  font-size: 16px;
  font-weight: 700;
}
@media screen and (min-width: 1024px), print{
  /*高さを制限しているボックスの要素*/
  .container{
    height: 260px;
  }
}
/* ***************************************** */
/* --- sec1 --- */
/* ***************************************** */
.sec1{
  padding: 60px 0;
}
.sec1-text,
.sec1-case li{
  padding: 5vmin 0;
}
.sec1-case li h3{
  margin-bottom: 3vmin;
}

@media screen and (min-width: 768px), print{
  .sec1{
    padding: 120px 0;
  }
  .sec1-text{
    text-align: center;
  }
  .sec1-case{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec1-case li{
    width: 48%;
    padding: 3vmin 0;
  }
  .sec1-case li h3{
    margin-bottom: 2vmin;
  }
}


/* ***************************************** */
/* --- sec2 --- */
/* ***************************************** */
.sec2{
  padding-top: 60px;
}
/* sec2-key -------------------------------- */
.sec2-key{
  position: relative;
}

.sec2-key-text02 h4{
  font-size: 6vmin;
  margin-bottom: 2vmin;
}
.sec2-key-img,
.sec2-key-text02{
  padding: 5vmin 0;
}

.sec2-movie{
  padding: 5vmin 0;
  background: linear-gradient(transparent 50%, #EFFAF2 0%);
}
.sec2-movie .inner video{
  width: 100%;
  height: auto;
}
.sec2-detail{
  padding: 5vmin 0;
}
.sec2-detail-inner{
  margin: 5vmin 0 ;
}
.sec2-detail-inner .text-box{
  margin-top: 15px;
}
.sec2-detail h4{
  font-size: 17px;
  margin-bottom: 2vmin;
}
@media screen and (min-width: 768px), print{
  .sec2{
    padding-top: 120px;
  }
  .sec2-key{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec2-key-text01{
    display: block;
  }
  .sec2-key-text01,
  .sec2-key-img{
    width: 48%;
  }
  .sec2-key-img,
  .sec2-key-text02{
    padding: 3vmin 0;
  }
  .sec2-key-text01 h3{
    margin-bottom: -40px;
  }
  .sec2-key-text01 .text01{
    font-size: 25px;
  }
  .sec2-key-text01 h4{
    font-size: 30px;
    margin-bottom: 10px;
  }
  .sec2-key-text01 h4 span{
     font-size: 18px;
  }
  .sec2-key-text02{
    width: 100%;
  }
  .sec2-key-text02 h4{
    font-size: 24px;
    margin-bottom: 0.5em;
  }
  .sec2-detail-inner{
    margin: 4vmin 0 5vmin ;
    display: flex;
    justify-content: space-between;
  }
  .sec2-detail-inner .img-box,
  .sec2-detail-inner .text-box{
    width: 48%;
  }
}

@media screen and (min-width: 1024px), print{
  .sec2-key{
    position: relative;
  }
  .sec2-key-text01 h3{
    margin-bottom: -55px;
  }
  .sec2-key-img,
  .sec2-key-text02{
    padding: 40px 0;
  }
  .sec2-key-text02{
    position: absolute;
    left: 0;
    bottom: 0;
    width: 48%;
  }
  .sec2-detail-inner{
    margin: 4vmin 0 6vmin ;
  }
  .sec2-detail h4{
    font-size: 22px;
  }
}

/* ***************************************** */
/* --- conversion --- */
/* ***************************************** */
.conversion{
  padding-bottom: 60px;
  background-color: var(--c-gray1);
}
/* sec-conversion-heading ---------------------------- */
.sec-conversion-heading{
  background-color: var(--c-green1);
  color: #fff;
}
.sec-conversion-heading > div{
  padding: 60px 0 240px;
  background: url(../img/sec5-bg.png) no-repeat right 72% / 50% auto;
}
.sec-conversion-heading p{
  display: table;
  margin-left: 5%;
  padding-bottom: 1em;
  background: url(../img/sec5-heading-border.svg) no-repeat center bottom / contain;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 3.7vmin;
}
.sec-conversion-heading h2{
  text-align: left;
  margin-left: 5%;
  line-height: 1.5;
  font-size: 6vmin;
}
.sec-conversion-heading h2 span{ font-size: 0.8em; }
@media screen and (min-width: 768px), print{
  .conversion{
    padding-bottom: 120px;
  }
  .sec-conversion-heading{ padding: 20px 0; }
  .sec-conversion-heading > div{
    width: min(100%, 1200px);
    margin: auto;
    padding: 100px 0 230px;
    background: url(../img/sec5-bg.png) no-repeat right 40px top 70px / 300px auto;
  }
  .sec-conversion-heading p{
    display: table;
    margin: auto;
    padding-bottom: 1em;
    background: url(../img/sec5-heading-border.svg) no-repeat center bottom / contain;
    font-size: 26px;
  }
  .sec-conversion-heading h2{
    margin-left: 0;
    text-align: center;
    font-size: 45px;
  }
}
/* sessiondata ------------------------------ */
.sessiondata{
  width: 90%;
  margin: -120px auto 0;
  padding: 25px 3%;
  border-radius: 10px;
  border: 2px solid var(--c-green1);
  background-color: #fff;
}
.sessiondata h3{
  margin-bottom: 1em;
  text-align: center;
  font-size: 5vmin;
}
.sessiondata h3 span{ background: url(../img/mark.svg) no-repeat center bottom / contain; }
.sessiondata ul{
  display: table;
  margin: 0 auto;
  width: fit-content;
}
.sessiondata li img{
  width: 4vmin;
  margin-top: 0.5em;
  margin-right: 0.5em;
  vertical-align: 0vmin;
}
.sessiondata li{
  font-size: 15px;
}
@media screen and (min-width: 768px), print{
  .sessiondata{
    width: min(100%, 1000px);
    margin: -180px auto 0;
    padding: 50px 0;
    text-align: center;
  }
  .sessiondata h3{
    margin-bottom: 1em;
    text-align: center;
    font-size: 22px;
  }
  .sessiondata h3 span{ margin-left: 0.2em; }
  .sessiondata ul{
    position: relative;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 0;
    width: 730px;
    text-align: left;
  }
  .sessiondata li{
    line-height: 2.5;
    margin-top: -5px;
    border-bottom: 1px solid #D3D3D3;
    width: calc(100% / 2);
    padding: 0 1em;
  }
  .sessiondata li:nth-last-of-type(-n+2){ border-bottom: none; }
  .sessiondata li img{
    width: 17px;
    vertical-align: -1px;
  }
  .sessiondata li{
    font-size: 16px;
  }
}


/* sec-conversion-inner ------------------------------ */
.sec-conversion-inner{
  margin: -210px auto 40px;
}

/* .sec-conversion-inner{
  width: 90%;
  margin: -210px auto 40px;
  padding: 25px 5%;
  border-radius: 10px;
  border: 2px solid var(--c-green1);
  background-color: #fff;
}
.sec-conversion-inner h3{
  margin-bottom: 1em;
  text-align: center;
  font-size: 6vmin;
}
.sec-conversion-inner h3 span{ background: url(../img/mark.svg) no-repeat center bottom / contain; }


.sec-conversion-inner ul li{
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-size: 4vmin;
  padding: 2vmin;
}
.sec-conversion-inner ul li img{
  width: 5vmin;
  margin-right: 0.5em;
  vertical-align: -1vmin;
} */

@media screen and (min-width: 768px), print{
  .sec-conversion-inner{
    margin: -200px auto 80px;
  }
  /* .sec-conversion-inner{
    width: min(100%, 800px);
    margin: -200px auto 80px;
    padding: 50px 60px;
  }
  .sec-conversion-inner h3{
    margin-bottom: 1em;
    text-align: center;
    font-size: 22px;
  }
  .sec-conversion-inner h3 span{ margin-left: 0.2em; }
  
  .sec-conversion-inner ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec-conversion-inner ul li{
    font-size: 2vmin;
    width: 50%;
    border-bottom: 1px solid #d3d3d3;
  }
  .sec-conversion-inner ul li:last-of-type{
    border-bottom: none;
  }
  .sec-conversion-inner ul li img{
    width: 3vmin;
    margin-right: 0.5em;
    vertical-align: -0.5vmin;
  } */
}

/* cv -------------------------------------- */
.conversion .cv-text{
  position: relative;
  display: table;
  height: auto;
  margin: 0 auto 0.7em;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 4vmin;
  line-height: 1.2;
}
.conversion .cv-text::before,
.conversion .cv-text::after{
  content: "";
  position: absolute;
  top: 0;
  display: block;
  height: 100%;
  width: 1px;
  background-color: #000;
}
.conversion .cv-text::before{
  left: -10px;
  transform: rotate(-45deg);
}
.conversion .cv-text::after{
  right: -10px;
  transform: rotate(45deg);
}
.conversion .btn-inquiry{
  width: 70%;
  margin: auto;
}
@media screen and (min-width: 768px), print{
  .conversion .cv-text{
    margin: 0 auto 0.7em;
    font-size: 17px;
  }
  .conversion .btn-inquiry{ width: 432px; }
}


/* ***************************************** */
/* --- cta-c --- */
/* ***************************************** */
.cta-c{ padding-bottom: 60px; }
.cta-c h2{ text-align: left; }
@media screen and (min-width: 768px), print{
  .cta-c{ padding-bottom: 120px; }
}

/* cta-c-heading ---------------------------- */
.cta-c-heading{
  background: var(--c-green1);
  color: #fff;
}
.cta-c-heading > div{
  padding: 60px 0 140px;
  background: url(../img/cta-c-sp.png) no-repeat right 200%/ 40% auto;
}
.cta-c-heading p{
  display: table;
  margin-left: 5%;
  padding: 0 1.2em 1em;
  background: url(../img/cta-c-border.svg) no-repeat center bottom / contain;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 4vmin;
}
.cta-c-heading h2{
  margin-left: 5%;
  line-height: 1.5;
  font-size: 5.8vmin;
}
@media screen and (min-width: 768px), print{
  .cta-c-heading{ padding: 0 20px; }
  .cta-c-heading > div{
    width: min(100%, 1200px);
    margin: auto;
    padding: 115px 0 200px;
    background: url(../img/cta-c-pc.png) no-repeat right 40px bottom 0 / 270px auto;
  }
  .cta-c-heading p{
    display: table;
    margin: 0 auto 20px;
    padding-bottom: 1em;
    background: url(../img/cta-c-border.svg) no-repeat center bottom / contain;
    font-size: 26px;
  }
  .cta-c-heading h2{
    margin-left: 0;
    text-align: center;
    font-size: 45px;
  }
}

/* cta-c-inner ------------------------------ */
.cta-c-inner {}

/* cta-c-img ------------------------------ */
.cta-c-img {
  width: 90%;
  margin: 40px auto 48px;
}
@media screen and (min-width: 768px), print{
  .cta-c-img {
    width: min(100%, 728px);
    margin: 64px auto 72px;
  }
}

/* cta-c-step ------------------------------ */
.cta-c-step {
  display: flex;
  flex-direction: column;
  width: 90%;
  margin: 0 auto 40px;
  gap: 44px;
}
.cta-c-step li {
  background-color: #f4f4f4;
  border-radius: 10px;
  position: relative;
  padding: 32px 24px 24px;
}
.cta-c-step li:not(:last-of-type)::after {
  content: "";
  display: block;
  background-image: url(../img/icon-step-down.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translate(-50%, 100%);
  width: 20px;
  height: 12px;
}
.cta-c-step .cta-c-step-heading {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%,-50%);
  border-radius: 999px;
  background-color: var(--c-green1);
  color: #fff;
  font-weight: 700;
  text-align: center;
  font-size: 15px;
  width: 90px;
  line-height: 24px;
}
.cta-c-step .cta-c-step-flex {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 12px;
}
.cta-c-step .cta-c-step-flex span {
  display: flex;
  gap: 8px
}
.cta-c-step .cta-c-step-flex img{
  display: block;
  width: auto;
}
.cta-c-step li:nth-of-type(1) img{height: 31px;}
.cta-c-step li:nth-of-type(2) img{height: 39px;}
.cta-c-step li:nth-of-type(3) img{height: 37px;}
.cta-c-step .cta-c-step-flex p{
  font-size: 17px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  text-align: center;
}
.cta-c-step .cta-c-step-text{text-align: center;}

@media screen and (min-width: 768px), print{
  .cta-c-step {
    width: min(100%, 1040px);
    padding: 0 20px;
    justify-content: space-between;
    flex-direction: row;
    margin: 0 auto 80px;
    gap: 24px;
  
  }
  .cta-c-step li {
    width: calc((100% - (24px * 2)) / 3);
    padding: 40px 24px 24px;
  }
  .cta-c-step li:not(:last-of-type)::after {
    background-image: url(../img/icon-step-right.svg);
    top: 50%;
    right: -6px;
    left: auto;
    transform: translate(100%, -50%);
    width: 13px;
    height: 21px;
  }
  .cta-c-step .cta-c-step-heading {
    font-size: 17px;
    width: 100px;
    line-height: 29px;
  }
  .cta-c-step .cta-c-step-flex {
    display: block;
    margin-bottom: 12px;
  }
  .cta-c-step li span {
    justify-content: center;
    align-items: center;
    height: 54px;
    margin-bottom: 16px;
  }
  .cta-c-step li:nth-of-type(1) img{
    height: 43px;
  }
  .cta-c-step li:nth-of-type(2) img{
    height: 53px;
  }
  .cta-c-step li:nth-of-type(3) img{
    height: 50px;
  }
  .cta-c-step .cta-c-step-flex p{
    font-size: 22px;
    line-height: 1;
  }
}

/* cv -------------------------------------- */
.cta-c .cv .cv-text{
  position: relative;
  display: table;
  height: auto;
  margin: 0 auto 0.7em;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 4vmin;
  line-height: 1.2;
}
.cta-c .cv .cv-text::before,
.cta-c .cv .cv-text::after{
  content: "";
  position: absolute;
  top: 0;
  display: block;
  height: 100%;
  width: 1px;
  background-color: #000;
}
.cta-c .cv .cv-text::before{
  left: -10px;
  transform: rotate(-45deg);
}
.cta-c .cv .cv-text::after{
  right: -10px;
  transform: rotate(45deg);
}
.cta-c .cv .btn-inquiry{
  width: 70%;
  margin: auto;
}
.cta-c .cv .btn-inquiry a{ margin-bottom: 0; }
@media screen and (min-width: 768px), print{
  .cta-c .cv .cv-text{
    margin: 0 auto 0.7em;
    font-size: 17px;
  }
  .cta-c .cv .btn-inquiry{ width: 432px; }
}


/* ***************************************** */
/* --- sec3 --- */
/* ***************************************** */
/* sec3 ------------------------------------ */
.sec3{
  padding-bottom: 60px;
  background-color: #F4F4F4;
}
.sec3-ttl{
  background-color: var(--c-green1);
  color: #fff;
  padding: 60px 0 60vmin;
}
.sec3-ttl h2{
  font-size: 5vmin;
  line-height: 1.5em;
}
.sec3-key-area{
  position: relative;
}
.sec3-key{
  position: absolute;
  top: -50vmin;
  left: 0;
  right: 0;
  width: 80%;
  margin: 0 auto;
}
.sec3-read{
  margin: 0 5% 60px;
  padding-top: 45vmin;
}
/* sec3 toggle-wrap ------------------ */
.sec3-toggle.toggle{
  padding: 0;
}
.sec3-toggle section {
    padding: 30px 5% 40px;
}
/* sec3-toggle-sec1 */
.sec3-toggle-sec1 p{ margin-bottom: 20px; }
.sec3-toggle-sec1 p span{
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  color: var(--c-green1);
}

/* sec3-toggle-sec2 */
.sec3-toggle-sec2 div{ margin-top: 25px; }
.sec3-toggle-sec2 dt{
  display: flex;
  align-items: center;
  gap: 0.5em;
  margin-bottom: 0.3em;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  color: var(--c-green1);
  font-size: 4vmin;
  line-height: 1.3;
}
.sec3-toggle-sec2 dt span{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 20vmin;
  height: 10vmin;
  border-radius: 5px;
  border: 2px solid var(--c-green1);
  background-color: #fff;
  font-size: 0.8em;
}
@media screen and (min-width: 768px), print{
  .sec3{
    padding-bottom: 120px;
  }
  .sec3-ttl{
    padding: 120px 0 350px;
  }
  .sec3-ttl h2{
    font-size: 3vmin;
  }
  .sec3-key-area{
    width: 100%;
    background: url(../img/sec3-bg.jpg) no-repeat center top / cover;
  }
  .sec3-key{
    top: -320px;
    width: 70%;
    max-width: 570px;
  }
  .sec3-read{
    margin: 0 0 80px;
    padding-top: 340px;
    text-align: center;
  }
/* sec3 toggle-wrap ------------------ */
  .sec3 .toggle-wrap {
    width: min(90%, 1100px);
    margin: 0 auto;
  }
  .sec3-toggle{ padding: 0; }
  .sec3-toggle h4 span{
    display: inline;
    font-size: 1em;
  }
  
  /* sec3-toggle */
  .sec3-toggle section{ padding: 50px 60px; }
  /* sec3-toggle-sec1 */
  .sec3-toggle-sec1 > div{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .sec3-toggle-sec1 > div > *{ width: 48%; }
  .sec3-toggle-sec1 p{ margin-bottom: 0; }
  
  /* sec3-toggle-sec2 */
  .sec3-toggle-sec2 div{
    margin-top: 20px;
    padding-top: 26px;
    border-top: 1px solid #949494;
  }
  .sec3-toggle-sec2 div:first-of-type{
    padding-top: 0;
    border-top: none;
  }
  .sec3-toggle-sec2 dt{
    gap: 0.5em;
    margin-bottom: 0.3em;
    font-size: 17px;
    line-height: 1.3;
  }
  .sec3-toggle-sec2 dt span{
    width: 64px;
    height: 24px;
    font-size: 11px;
  }
}

/* ***************************************** */
/* --- sec4 --- */
/* ***************************************** */
/* sec4 ------------------------------ */
.sec4{ padding: 60px 0; }

.sec4 .case-box{ margin-top: 30px; }

.sec4 .case-box h3 img{
  width: 14%;
  margin-right: 0.3em;
}
.sec4 .case-box h3{
  font-weight: normal;
}
.sec4 .case-box h3 span{
  margin-right: 0.3em;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 5vmin;
  color: var(--c-green1);
}
.sec4 .case-box > img{
  display: block;
  margin-top: 0.3em;
}
.sec4 .case-box-inner{
  margin-top: 25px;
  padding: 25px 4%;
}
.sec4 .case-box-inner h4{
  text-align: center;
  font-size: 4.5vmin;
}
.sec4 .case-box-inner li{
  margin: 15px 0;
  padding-left: 10px;
  border-left: 3px solid var(--c-green1);
}
.sec4 .case-box-inner li .bold{
  font-size: 110%;
}
@media screen and (min-width: 768px), print{
  .sec4{ padding: 120px 0; }
  .sec4 h4{
    padding: 8px 0;
    font-size: 17px;
  }
  .sec4 .case{
    display: flex;
    justify-content: space-between;
  }
  .sec4 .case-box{
    width: 48%;
  }
  .sec4 .case-box h3 span{
    margin-right: 0.3em;
    font-size: 18px;
  }
  .sec4 .case-box > img{
    margin-top: 0.5em;
  }
  .sec4 .case-box-inner{
    margin-top: 25px;
    padding: 10%;
  }
  .sec4 .case-box-inner h4{
    font-size: 19px;
  }
  .sec4 .case-box-inner li{
    margin: 15px 0;
    padding-left: 10px;
    border-left: 3px solid var(--c-green1);
  }
  .sec4 .case-box-inner li .bold{
    font-size: 110%;
  }
}


/* ***************************************** */
/* --- sec5 --- */
/* ***************************************** */
/* sec5 ------------------------------------ */
.sec5{
  padding: 60px 5%;
  background-color: var(--c-gray1);
}
.sec5 .small{ font-size: 0.8em; }
.sec5-sub-img{ margin-top: -20px; }
.sec5 .item{
  margin-bottom: 20px;
  background-color: #fff;
}
.sec5 .item:last-of-type{ margin-bottom: 10px; }
.sec5 .item > dt{
  padding: 20px 0;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  font-size: 5vmin;
}
.sec5 .item > dt img{ width: 20%; }
.sec5 .toggle{
  padding: 20px 5%;
}
.sec5 .toggle-btn{
  border-radius: 0;
}
@media screen and (min-width: 768px), print{
  .sec5{ padding: 120px 20px; }
  .sec5 .small{
    width: min(100%, 1000px);
    margin: auto;
  }
  .sec5-sub-img{
    width: min(100%, 1100px);
    margin: auto;
    margin-top: -160px;
  }
  .sec5-sub-img picture{
    position: relative;
    right: 0;
    display: block;
    margin-left: auto;
    width: 376px;
  }
  .sec5 .item{
    width: min(90%, 1100px);
    margin: 0 auto 50px;
  }
  .sec5 .item > dt{
    padding: 40px 0;
    font-size: 22px;
  }
  .sec5 .item > dt img{ width: 64px; }

  .sec5 .toggle{ padding: 60px; }
}

/* data1 ----------------------------------- */
.toggle.data1 p{ margin: 16px 0; }
.toggle.data1 figcaption{ margin-top: -10px; }
@media screen and (min-width: 768px), print{
  .toggle.data1 > div{
    display: flex;
    justify-content: space-between;
  }
  .toggle.data1 > div > div{ width: 48%; }
  .toggle.data1 p{ margin: -0.5em 0 30px; }
  .toggle.data1 figure{ padding: 0 5%; }
  .toggle.data1 figcaption{ margin-top: -18px; }
}

/* data2 ----------------------------------- */
.toggle.data2 img{ border: 1px solid #D3D3D3; }
.toggle.data2 div p{ margin: 16px 0; }
.toggle.data2 div p span{
  display: block;
  margin-top: 0.3em;
  font-size: 0.8em;
  line-height: 1.5;
}
.toggle.data2 ul{ margin-top: 16px; }
.toggle.data2 li{ margin-top: 10px; }
.toggle.data2 li figcaption{
  margin-top: 0.3em;
  font-size: 0.8em;
}
@media screen and (min-width: 768px), print{
  .toggle.data2 div,
  .toggle.data2 ul{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .toggle.data2 div > *,
  .toggle.data2 ul li{ width: 48%; }
  .toggle.data2 div p{ margin: 0; }
  .toggle.data2 div p span{
    display: block;
    margin-top: 0.3em;
    font-size: 0.8em;
    line-height: 1.5;
  }
  .toggle.data2 ul{ margin-top: 40px; }
}

/* data3 ----------------------------------- */
.toggle.data3 img{ border: 1px solid #D3D3D3; }
.toggle.data3 div p{ margin: 16px 0; }
.toggle.data3 ul{ margin-top: 16px; }
.toggle.data3 li{
  display: flex;
  gap: 5%;
  align-items: flex-start;
  margin-top: 20px;
}
.toggle.data3 li picture{ width: 30%; }
.toggle.data3 li dl{ width: 65%; }
.toggle.data3 li dt{
  height: 20px;
  line-height: 20px;
  margin-bottom: 0.3em;
  border-radius: 10px;
  background-color: var(--c-green1);
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  text-align: center;
  font-size: 14px;
  color: #fff;
}
.toggle.data3 li dd:first-of-type{
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
}
.toggle.data3 .small{
  margin-top: 0.6em;
  font-size: 0.8em;
}
@media screen and (min-width: 768px), print{
  .toggle.data3 div,
  .toggle.data3 ul{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .toggle.data3 div > *,
  .toggle.data3 ul li{ width: 48%; }
  .toggle.data3 div p{ margin: 0; }
  .toggle.data3 div p span{
    display: block;
    margin-top: 0.3em;
    font-size: 0.8em;
    line-height: 1.5;
  }
  .toggle.data3 ul{ margin-top: 40px; }
  .toggle.data3 li picture{ width: 35%; }
  .toggle.data3 li dl{ width: 60%; }
  .toggle.data3 li dt{
    height: 32px;
    line-height: 32px;
    margin-bottom: 0.3em;
    border-radius: 16px;
    font-size: 17px;
  }
  .toggle.data3 .small{ margin-top: 1em; }
}





/* ***************************************** */
/* --- sec6 --- */
/* ***************************************** */
.sec6{ padding: 60px 0; }

/* sec6-key -------------------------------- */
.sec6-key{
  position: relative;
}

.sec6-key-text02 h4{
  font-size: 6vmin;
  margin-bottom: 2vmin;
}
.sec6-key-img,
.sec6-key-text02{
  padding: 5vmin 0;
}


@media screen and (min-width: 768px), print{
  .sec6{  padding: 120px 0; }
  
/* sec6-key -------------------------------- */
  .sec6-key{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec6-key-text01{
    display: block;
  }
  .sec6-key-text01,
  .sec6-key-img{
    width: 48%;
  }
  .sec6-key-img,
  .sec6-key-text02{
    padding: 3vmin 0;
  }
  .sec6-key-text01 h3{
    margin-bottom: -40px;
  }
  .sec6-key-text01 .text01{
    font-size: 25px;
  }
  .sec6-key-text01 h4{
    font-size: 30px;
    margin-bottom: 10px;
  }
  .sec6-key-text01 h4 span{
     font-size: 18px;
  }
  .sec6-key-text02{
    width: 100%;
  }
  .sec6-key-text02 h4{
    font-size: 24px;
    margin-bottom: 0.5em;
  }
}

@media screen and (min-width: 1024px), print{
  .sec6-key{
    position: relative;
  }
  .sec6-key-text01 h3{
    margin-bottom: -55px;
  }
  .sec6-key-img,
  .sec6-key-text02{
    padding: 40px 0;
  }
  .sec6-key-text02{
    position: absolute;
    left: 0;
    bottom: 0;
    width: 48%;
  }
}


/* sec6-toggle ----------------------------- */
.sec6-toggle{
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.sec6-toggle section p:first-of-type{
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  margin-bottom: 0.5em;
}
.sec6-toggle h4{
  padding-left: 5.5vmin;
  text-indent: -5.5vmin;
  padding-bottom: 8px;
  margin-bottom: 1em;
  border-bottom: 2px solid var(--c-green1);
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 5vmin;
  color: var(--c-green1);
}
.toggle6-img{ margin-top: 30px; }
@media screen and (min-width: 768px), print{
  .sec6-toggle{
    flex-direction: row;
    flex-wrap: wrap;
    gap: 50px 4%;
  }
  .sec6-toggle section:first-of-type{ margin-top: 0; }
  .sec6-toggle-box{ width: 48%; }
  
  .sec6-toggle section p:first-of-type{
    font-size: 22px;
  }
  .sec6-toggle h4{
    padding-left: 24px;
    text-indent: -24px;
    padding-bottom: 8px;
    margin-bottom: 1em;
    font-size: 22px;
  }
}


/* ***************************************** */
/* --- sec7 --- */
/* ***************************************** */
.sec7{
  padding-top: 60px;
  background-color: var(--c-gray1);
  text-align: center;
}
.sec7 p{ margin-bottom: 20px; }
@media screen and (min-width: 768px), print{
  .sec7{
    padding-top: 120px;
    background: url(../img/sec7-bg.png) no-repeat center center / cover;
  }
  .sec7 img{ width: min(100%, 743px); }
}


/* ***************************************** */
/* --- sec8 --- */
/* --- sec9 --- */
/* ***************************************** */

/* sec8-inner1 ----------------------------- */
/* sec9-inner1 ----------------------------- */
.sec8-inner1,
.sec9-inner1{
  padding: 60px 10% 140px;
  background-color: var(--c-green1);
}
.sec8-inner1 .m-heading-a,
.sec9-inner1 .m-heading-a{
  color: #fff;
}
.sec8-inner1 > p,
.sec9-inner1 > p{
  margin-bottom: 20px;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 4vmin;
  color: #fff;
}
.sec8-inner1 .m-heading-a::after,
.sec9-inner1 .m-heading-a::after{
  background-color: #fff;
}
.sec8-inner1 section,
.sec9-inner1 section{
  position: relative;
  padding: 20px 5%;
  border-radius: 5px;
  background: #EFFAF2;
}
.sec8-inner1 section::after,
.sec9-inner1 section::after{
  position: absolute;
  bottom: -25px;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 17px solid transparent;
  border-left: 17px solid transparent;
  border-top: 25px solid #EFFAF2;
  border-bottom: 0;
}
.sec8-inner1 section h3,
.sec9-inner1 section h3{
  margin-bottom: 10px;
  font-size: 4vmin;
  color: var(--c-green1);
}
.sec8-inner1 section h3 span,
.sec9-inner1 section h3 span{
  display: block;
  height: 28px;
  line-height: 28px;
  margin-bottom: 14px;
  border-radius: 14px;
  background-color: var(--c-green1);
  text-align: center;
  font-weight: 700;
  font-size: 15px;
  color: #fff;
}
.sec8-inner1 section .name,
.sec9-inner1 section .name{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sec8-inner1 section .name img,
.sec9-inner1 section .name img{
  width: 30%;
}
.sec8-inner1 section .name i,
.sec9-inner1 section .name i{
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
}

/* sec9-inner1 */
.sec9-inner1{ background-color: #45C1C1; }
.sec9-inner1 section h3{ color: #45C1C1; }
.sec9-inner1 section h3 span{ background-color: #45C1C1; }
.sec9-inner1 section{ background-color: #F0FFFF; }
.sec9-inner1 section::after{ border-top-color: #F0FFFF;}
@media screen and (min-width: 768px), print{
  .sec8-inner1,
  .sec9-inner1{
    padding: 120px 20px 300px;
  }
  .sec8-inner1 > p,
  .sec9-inner1 > p{
    margin: 60px 0 30px;
    padding: 0 20px;
    font-size: 22px;
  }
  .sec8-inner1 section,
  .sec9-inner1 section{
    width: min(100%, 856px);
    margin: auto;
    padding: 40px;
    background: #EFFAF2 url(../img/sec8-face-pc.png) no-repeat right bottom;
  }
  .sec8-inner1 section::after,
  .sec9-inner1 section::after{
    bottom: -40px;
    border-right-width: 27px;
    border-left-width: 27px;
    border-top-width: 40px;
  }
  .sec8-inner1 section h3,
  .sec9-inner1 section h3{
    margin-bottom: 10px;
    font-size: 22px;
  }
  .sec8-inner1 section h3 span,
  .sec9-inner1 section h3 span{
    display: table;
    height: 40px;
    line-height: 40px;
    margin-bottom: 14px;
    padding: 0 1.5em;
    border-radius: 20px;
    font-size: 22px;
  }
  .sec8-inner1 section .name,
  .sec9-inner1 section .name{
    margin-top: 0.4em;
  }
  .sec8-inner1 section .name i,
  .sec9-inner1 section .name i{
    display: inline;
  }

  /* .sec9-inner1 */
  .sec9-inner1 section{
    background: #F0FFFF url(../img/sec9-face-pc.png) no-repeat right bottom;
  }
}

/* sec8-inner2 ----------------------------- */
/* sec9-inner2 ----------------------------- */
.sec8-inner2,
.sec9-inner2{
  margin-top: -100px;
  padding: 0 10% 60px;
}
.sec8-inner2 > ul,
.sec9-inner2 > ul{
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.sec8-inner2 > ul > li,
.sec9-inner2 > ul > li{
  padding: 20px 4%;
  border-radius: 10px;
  border: 2px solid var(--c-green1);
  background-color: #fff;
}
.sec8-inner2 h2,
.sec9-inner2 h2{
  padding: 0 0 25px;
  text-align: center;
  font-size: 6.5vmin;
  line-height: 1.1;
}
.sec8-inner2 h2 span span,
.sec9-inner2 h2 span span{
  display: block;
  margin-bottom: 0.3em;
  line-height: 1.4;
  font-size: 5vmin;
}
.sec8-inner2 h2 i,
.sec9-inner2 h2 i{
  color: var(--c-green1);
}

/* sec9-inner2 */
.sec9-inner2 > ul > li{ border-color: #45C1C1; }
.sec9-inner2 h2 i{ color: #45C1C1; }
.sec9-inner2 dl{ margin-top: 0.8em; }
.sec9-inner2 dt{
  margin-top: 0.3em;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  color: #45C1C1;
}
.sec9-inner2 dd ul{
  display: flex;
  flex-wrap: wrap;
}
.sec9-inner2 dd li{ width: 54%; }
.sec9-inner2 dd li:nth-child(2n){ width: 45%; }

.sec9-inner2 dd span{ font-size: 0.8em; }
@media screen and (min-width: 768px), print{
  .sec8-inner2,
  .sec9-inner2{
    margin-top: -210px;
    padding: 0 20px 120px;
  }
  .sec8-inner2 > ul,
  .sec9-inner2 > ul{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
    width: min(100%, 1200px);
    margin: auto;
  }
  .sec8-inner2 > ul > li,
  .sec9-inner2 > ul > li{
    width: 32%;
    padding: 30px;
    padding-top: 0;
  }
  .sec9-inner2 > ul > li:nth-of-type(3) img{
    width: 112%;
    margin-left: -6%;
  }
  .sec8-inner2 h2,
  .sec9-inner2 h2{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 210px;
    padding: 0;
    font-size: 32px;
    line-height: 42px;
  }
  .sec8-inner2 h2 span span,
  .sec9-inner2 h2 span span{
    margin-bottom: 0.2em;
    line-height: 1.4;
    font-size: 20px;
  }
  .sec8-inner2 h2 i i,
  .sec9-inner2 h2 i i{
    font-size: 1.4em;
  }
}
/* sec8-inner3 ----------------------------- */
/* sec9-inner3 ----------------------------- */
.sec8-inner3-box1{
  background: #EFFAF2;
  padding: 60px 0 80px;
}
.sec9-inner3-box1{
  background: #F0FFFF;
  padding: 60px 0 80px;
}
.sec8-inner3-box1 h3,
.sec9-inner3-box1 h3{
  margin-bottom:1.5em;
  padding: 0.5em 0;
  border-radius: 30px;
  background-color: var(--c-green1);
  text-align: center;
  color: #fff;
}
.sec9-inner3-box1 h3{
  background-color: #45C1C1;
}
.sec8-inner3-box1 h4,
.sec9-inner3-box1 h4{
  font-size: 6vmin;
  text-align: center;
}
.sec8-inner3-box2,
.sec9-inner3-box2{
  margin-top: -60px;
  padding-bottom: 60px;
}
.sec8-inner3-box2 .inner,
.sec9-inner3-box2 .inner{
  position: relative;
}
.sec8-inner3-box2 img,
.sec9-inner3-box2 img{
  display: block;
  width: 120px;
  margin: 0 auto 20px;
}
.sec8-inner3-box2 .bold,
.sec9-inner3-box2 .bold{
  text-align: center;
  font-size: 5vmin;
}
@media screen and (min-width: 768px), print{
  .sec8-inner3{
    background: #EFFAF2;
  }
  .sec9-inner3{
    background: #F0FFFF;
  }
  .sec8-inner3-box1,
  .sec9-inner3-box1{
    padding: 120px 0 0;
  }
  .sec8-inner3-box1 h3,
  .sec9-inner3-box1 h3{
    font-size: 25px;
  }
  .sec8-inner3-box1 h4,
  .sec9-inner3-box1 h4{
    padding-left: 200px;
    font-size: 25px;
    text-align: left;
  }
  .sec8-inner3-box2,
  .sec9-inner3-box2{
    margin: 0;
    padding-bottom: 120px;
  }
  .sec8-inner3-box2 .inner,
  .sec9-inner3-box2 .inner{
    position: relative;
    padding-left: 200px;
  }
  .sec8-inner3-box2 img,
  .sec9-inner3-box2 img{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 20px;
    width: 160px;
    margin: auto 0;
  }
  .sec8-inner3-box2 .bold,
  .sec9-inner3-box2 .bold{
    text-align: left;
    font-size: 25px;;
  }
}


/* ***************************************** */
/* --- sec12 --- */
/* ***************************************** */
.sec12{
  padding: 60px 5%;
  background-color: var(--c-gray1);
}
.sec12 > p{ text-align: center; }
@media screen and (min-width: 768px), print{
  .sec12{ padding: 120px 20px; }
}

/* sec12-inner ----------------------------- */
.sec12-inner:first-of-type{ margin: 20px 0 40px; }
.sec12-inner > h3{
  height: 28px;
  line-height: 28px;
  border-radius: 14px;
  background-color: var(--c-green1);
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  text-align: center;
  font-size: 15px;
  color: #fff;
}
@media screen and (min-width: 768px), print{
  .sec12-inner{
    width: min(100%, 1000px);
    margin: auto;
  }
  .sec12-inner:first-of-type{ margin: 80px auto; }
  .sec12-inner > h3{
    height: 40px;
    line-height: 40px;
    border-radius: 20px;
    font-size: 17px;
  }
}

/* sec12-service ----------------------------- */
.sec12-service{ margin-top: 20px; }
.sec12-service h4{
  margin-bottom: 0.3em;
  font-size: 1.2em;
}
.sec12-service h4::before{
  content: "■";
  color: var(--c-green1);
}
.sec12-service p{ margin-bottom: 1em; }
@media screen and (min-width: 768px), print{
  .sec12-service{ margin-top: 80px; }
  .sec12-service h4{ font-size: 22px; }
  .sec12-service h4::before{ display: none; }
}

/* sec12 flex -------------------------------- */
@media screen and (min-width: 768px), print{
  .sec12 .flex{
    display: flex;
    justify-content: space-between;
  }
  .sec12 .flex > *{ width: 48%; }

  .sec12 .flex2{
    display: flex;
    flex-direction: column;
  }
  .sec12 .flex2 > .mt-auto{ margin-top: auto; }
  .sec12 .m-hidden-sp li:first-of-type{ margin-bottom: 30px; }
}


/* ***************************************** */
/* --- sec13 --- */
/* ***************************************** */
/* .sec13{
  padding: 60px 0 0;
  background-color: var(--c-gray1);
}
.sec13-inner h3{
  margin-bottom: 0.5em;
  font-size: 4.5vmin;
  text-align: center;
}
.sec13-inner div:first-of-type{ padding: 0 5% 60px; }
.sec13-inner p:last-of-type{
  margin-top: 0.2em;
  font-size: 0.8em;
}
@media screen and (min-width: 768px), print{
  .sec13{ padding: 120px 20px; }
  .sec13 .m-heading-a{ margin-bottom: 100px; }
  .sec13-inner{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: min(100%, 1000px);
    margin: auto;
  }
  .sec13-inner h3{
    font-size: 22px;
    text-align: left;
  }
  .sec13-inner div{ width: 48%; }
  .sec13-inner div:first-of-type{ padding: 0; }
} */


/* ***************************************** */
/* --- sec14 --- */
/* ***************************************** */
/* sec14-wrap ------------------------------ */
.sec14-wrap{
  padding: 0 5% 60px;
}
@media screen and (min-width: 768px), print{
  .sec14-wrap{
    padding: 120px 20px;
    background: url(../img/sec14-bg-pc.jpg) no-repeat center top;
  }
}

/* sec14-inner ------------------------------ */
.sec14-inner{ margin-bottom: 20px; }
.sec14-inner h2 span{
  display: block;
  text-align: center;
}
.sec14-inner h2 span:first-of-type{
  position: relative;
  z-index: -1;
  margin-top: -3vmin;
  font-family: "Roboto", sans-serif;
  font-size: 23vmin;
  text-indent: -3vmin;
  color: var(--c-gray1);
  line-height: 1;
}
.sec14-inner h2 span:last-of-type{
  margin-bottom: 1em;
  font-size: 6vmin;
  line-height: 1.3;
}
@media screen and (min-width: 768px), print{
  .sec14-inner{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: min(100%, 1000px);
    margin: 0 auto 30px;
  }
  .sec14-inner > div{ width: 48%; }
  .sec14-inner h2 span{ text-align: left; }
  .sec14-inner h2 span:first-of-type{
    position: static;
    margin-top: 0;
    font-size: 111px;
    text-indent: 0;
    line-height: 1;
  }
  .sec14-inner h2 span:last-of-type{
    margin: -35px 0 1em;
    font-size: 34px;
  }
}

/* sec14 toggle ----------------------------- */
.sec14 .toggle-wrap{ margin: 0; }
.sec14 .toggle-btn{
  border: 1px solid #000;
  color: #000;
  background-color: #fff;
}
.sec14 .toggle-btn.on{ background-color: var(--c-gray1); }
.sec14-toggle{ margin-bottom: 20px; }
.sec14-toggle div{
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #D3D3D3;
}
.sec14-toggle div:first-of-type{
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.sec14-toggle dt{
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
}
.sec14 .toggle img{
  margin-left: -11%;
  width: 122%;
}
@media screen and (min-width: 768px), print{
  .sec14 .toggle-wrap{ margin: 0 auto; }
  .sec14 .toggle-btn:hover{ background-color: var(--c-gray1); }
  .sec14-toggle{ margin-bottom: 40px; }
  .sec14-toggle div{
    display: flex;
    align-items: center;
    margin-top: 20px;
    padding: 20px 1em 0;
    border-top: 1px solid #D3D3D3;
  }
  .sec14-toggle div:first-of-type{ padding-top: 0; }
  .sec14-toggle dt{ margin-right: 2em; }
  .sec14 .toggle img{
    margin-left: 0;
    width: 100%;
  }
}


/* ***************************************** */
/* --- sec15 --- */
/* ***************************************** */
.sec15{
  padding: 60px 5%;
  background-color: var(--c-gray1);
}
.sec15-inner ul{
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.sec15 .toggle-wrap{ 
  margin: 0;
  width: 100%;
}
.sec15 .toggle-btn{
  display: flex;
  align-items: center;
  height: 14vmin;
  padding: 0 13%;
  text-align: left;
  font-size: 4vmin;
  color: #000;
  background-color: #fff;
}
.sec15 .toggle-btn.on{ background-color: #fff; }
.sec15 .toggle-btn::before{
  position: absolute;
  left: 5%;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  content: "Q";
  font-size: 4.2vmin;
}
.sec15 .toggle-btn::before,
.sec15 .toggle-btn::after{
  color: var(--c-green1);
}

.sec15 .toggle{ padding: 0 5% 20px; }
.sec15 .toggle p{
  display: flex;
  gap: 3.5vmin;
}
.sec15 .toggle p::before{
  margin-top: -1.3vmin;
  padding-left: 0.4vmin;
  content: "A";
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.01em;
  font-weight: 700;
  color: var(--c-green1);
  font-size: 4.2vmin;
}
@media screen and (min-width: 768px), print{
  .sec15{ padding: 120px 20px; }
  .sec15-inner ul{
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
    width: min(100%, 1200px);
    margin: 80px auto 0;
  }
  .sec15-inner li{
    width: 32%;
    padding: 30px 40px;
    border-radius: 10px;
    background-color: #fff;
  }
  .sec15 .toggle-btn{
    height: 70px;
    margin-bottom: 16px;
    padding: 0;
    padding-left: 37px;
    border-radius: 10px 10px 0 0;
    border-bottom: 1px solid #B8B8B8;
    font-size: 17px;
    cursor: default;
  }
  .sec15 .toggle-btn:hover{ background-color: #fff; }
  .sec15 .toggle-btn::before{
    left: 0;
    font-size: 19px;
  }
  .sec15 .toggle-btn::after{ display: none; }

  .sec15 .toggle{
    display: block !important;
    padding: 0;
  }
  .sec15 .toggle p{
    display: flex;
    gap: 1em;
  }
  .sec15 .toggle p::before{
    margin-top: -3px;
    padding-left: 3px;
    font-size: 19px;
  }
}


/* ***************************************** */
/* --- sec16 --- */
/* ***************************************** */
.sec16{ padding: 60px 0 140px; }
.sec16 h2{
  margin-bottom: 0.5em;
  text-align: center;
  font-size: 5vmin;
  line-height: 1.3;
}
.sec16 p{ padding: 0 5%; }
.sec16 picture{
  display: block;
  margin: 12px 0 40px;
}
@media screen and (min-width: 768px), print{
  .sec16{ padding: 120px 20px 200px; }
  .sec16-inner > div{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: min(100%, 1000px);
    margin: 0 auto 80px;
  }
  .sec16-inner > div div{ width: 48%; }
  .sec16 h2{
    margin-bottom: 0.5em;
    text-align: left;
    font-size: 22px;
  }
  .sec16 p{ padding: 0; }
  .sec16 picture{ margin: 0; }
}


/* ***************************************** */
/* --- footer --- */
/* ***************************************** */
footer{
  padding: 30px 5%;
  padding-bottom: 45vmin;
  background-color: #000;
  color: #fff;
}
footer ul{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 1em;
}
footer li:first-of-type{
  margin-right: 1.5em;
  padding-right: 1.5em;
  border-right: 1px solid #fff;
  line-height: 1;
}
footer p{
  text-align: center;
  font-size: 3.5vmin;
}
@media screen and (min-width: 768px), print{
  footer { padding-bottom: 140px; }
  footer p{ font-size: 12px; }
}


/* ***************************************** */
/* --- conversion-footer --- */
/* ***************************************** */
  .conversion-footer{
    position: fixed;
    z-index: 10;
    width: 100%;
  }

/* フェード表示の場合 */
  /* .conversion-footer{
    opacity: 0;
    transition: opacity 0.5s;
  }
  .conversion-footer.on{
    opacity: 1;
  } */

  /* 拡大フェードの場合 */
  .conversion-footer{
    transform: scale(.8);
    opacity: 0;  
  }
  .conversion-footer.on{
    animation: bigfade .5s ease 1 forwards;
  }
  @keyframes bigfade {
    0% {
      transform: scale(.8);
      opacity: 0;
    }
    100% {
      transform: scale(1);
      opacity: 1;
    }
  }

@media screen and (max-width: 767px){
  .conversion-footer{
    bottom: 0;
  }
  .conversion-footer.on{ opacity: 1; }
  .conversion-footer .tel-btn{
    position: absolute;
    right: 3%;
    bottom: 23vmin;
    /* width: 20vmin; */
  }
  .conversion-footer .tel-btn a{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 16vmin;
    width: 16vmin;
    padding: 2vmin 0;
    background-color: #fff;
    border-radius: 50%;
    box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.59);
  }
  .conversion-footer .tel-btn img{ width: 52%; }
  .conversion-footer .btn-wrap{
    padding: 0 3% 5vmin;
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
    width: 100%;
  }
  .conversion-footer .btn-wrap li{
    width: 48%;
    border-radius: 0;
  }
  .conversion-footer .btn-wrap li a{
    height: auto;
    margin-bottom: 0;
    padding: 0.6em 0.5em;
    border-radius: 5px;
    box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.59);
    text-align: center;
    line-height: 1.3;
    font-size: 4vmin;
  }
}
@media screen and (min-width: 768px), print{
  .conversion-footer{
    bottom: 30px;
    padding: 0 20px;
  }
  .conversion-footer-inner {
    position: relative;
    width: min(100%, 1000px);
    margin: auto;
  }
  .conversion-footer .tel-btn{
    position: absolute;
    right: 0;
    bottom: 90px;
    width: 90px;
  }
  .conversion-footer .tel-btn a{
    display: block;
    height: 90px;
    padding-top: 20px;
    background-color: #fff;
    border-radius: 45px;
    text-align: center;
    box-shadow: 0 3px 6px rgba(78, 70, 70, 0.37);
    transition: background-color 0.3s;
  }
  .conversion-footer .tel-btn a:hover{ background-color: var(--c-gray1); }
  .conversion-footer .tel-btn img{ width: 40px; }
  .conversion-footer li a{
    box-shadow: 0 3px 6px rgba(78, 70, 70, 0.37);
  }
}
