@charset "UTF-8";
*,
::after,
::before {
  box-sizing: border-box;
}
:root {
  --font-sans: "Yu Gothic Medium", "Yu Gothic", "游ゴシック体", sans-serif;
  --font-serif: "Yu Mincho", "YuMincho", "游明朝体", "Hiragino Mincho ProN", "ヒラギノ明朝 ProN W3", "MS Mincho", serif;
  --font-en: "Yellowtail", cursive;
  --main-color: #38B25D;
  --key-color: #FF9D02;
}
html {
  font-size: 62.5%;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  color: #333;
  letter-spacing: 1.5px;
}
article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
  display: block;
}
body {
  margin: 0 auto;
  line-height: 1.5;
  text-align: left;
  background-color: #fff;
  max-width: 768px;
}
[tabindex="-1"]:focus:not(:focus-visible) {
  outline: 0 !important;
}
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
li {
  margin: 0;
  padding: 0;
  line-height: 1.5;
}
abbr[data-original-title],
abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  cursor: help;
  border-bottom: 0;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none;
}
address {
  font-style: normal;
  line-height: inherit;
}
dl,
ol,
ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
dd {
  margin-left: 0;
}
blockquote {
  margin: 0 0 1rem;
}
b,
strong {
  font-weight: bolder;
}
small {
  font-size: 80%;
}
sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

a {
  color: #000000;
  text-decoration: none;
  background-color: transparent;
}
a:hover {
  color: #000000;
  text-decoration: none;
  opacity: 0.5;
  cursor: pointer;
}
a:not([href]):not([class]) {
  color: inherit;
  text-decoration: none;
}
a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}
*:focus {
  outline: none;
}
code,
kbd,
pre,
samp {
  font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 1em;
}
pre {
  margin-top: 0;
  overflow: auto;
  -ms-overflow-style: scrollbar;
}
figure {
  margin: 0 0 1rem;
}
img {
  vertical-align: middle;
  border-style: none;
}
svg {
  overflow: hidden;
  vertical-align: middle;
}
table {
  border-collapse: collapse;
}
caption {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  color: #6c757d;
  text-align: left;
  caption-side: bottom;
}
th {
  text-align: inherit;
}
label {
  display: inline-block;
}
button {
  border-radius: 0;
}
button:focus {
  outline: 1px dotted;
  outline: 5px auto -webkit-focus-ring-color;
}
button,
input,
optgroup,
select,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
button,
input {
  overflow: visible;
}
button,
select {
  text-transform: none;
}
[role=button] {
  cursor: pointer;
}
select {
  word-wrap: normal;
}
[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button;
}
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled),
button:not(:disabled) {
  cursor: pointer;
}
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  padding: 0;
  border-style: none;
}
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box;
  padding: 0;
}
input[type="checkbox"] {
  appearance: checkbox;
  -webkit-appearance: checkbox;
  width: 16px;
  height: 16px;
  margin: 0 4px 0 0;
  vertical-align: middle;
}
textarea {
  overflow: auto;
  resize: vertical;
}
fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}
legend {
  display: block;
  width: 100%;
  max-width: 100%;
  padding: 0;
  margin-bottom: 0.5rem;
  font-size: 1.5rem;
  line-height: inherit;
  color: inherit;
  white-space: normal;
}
progress {
  vertical-align: baseline;
}
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}
[type=search] {
  outline-offset: -2px;
  -webkit-appearance: none;
}
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
}
output {
  display: inline-block;
}
summary {
  display: list-item;
  cursor: pointer;
}
template {
  display: none;
}
[hidden] {
  display: none !important;
}
img, video {
  height: auto;
  width: 100%;
  max-width: 100%;
  line-height: 0;
}
input {
  -webkit-appearance: none;
}
input[type=text] {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
  background: #ccc;
  color: #fff;
  transition: background 0.2s;
}
input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}
input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}
.pc {
  display: none;
}
@media screen and (min-width: 769px) {

  a[href*="tel:"] {
    /* pointer-events: none;
    cursor: default;
    text-decoration: none; */
  }
  a:hover {
    cursor: pointer !important;
  }
}
/* header {
  height: 100vh;
} */
header div.menu {
  position: fixed;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0 auto;
  z-index: 3;
  max-width: 768px;
  background: #fff;
}

header div.menu .ttl_area {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: auto;
  margin: 0;
  padding: 8px 2vw;
}
header div.menu .logo{
  width: 30vw;
}
@media screen and (min-width: 769px) {
  header div.menu .logo{
    width: 180px;
  }
}
header div.menu .btn_area{
  display: flex;
}
header div.menu .btn_area a{
  margin-right: 8px;
  height: 40px;
  border-radius: 29px;
  background-image: linear-gradient(#FF9A03, #E42A00);
  width: 30vw;
  text-align: center;
  color: #fff;
  font-size: 1.2rem;
  padding-left: 4vw;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: left;
  line-height: 1.3;
  position: relative;
  font-family: var(--font-serif);
}
header div.menu .btn_area a:before{
  content: "";
  position: absolute;
  background: url(../../images/lp/icon_web.svg) no-repeat 0 0;
  background-size: 16px 13px;
  width: 16px;
  height: 13px;
  left: 10px;
  top: 12px;
}
header div.menu .btn_area a:last-of-type{
  background-image: linear-gradient(#3BE14F, #199E29);
  margin-right: 0;
}
header div.menu .btn_area a:last-of-type:before{
  background: url(../../images/lp/icon_line.svg) no-repeat 0 0;
  background-size: 16px;
  width: 16px;
  height: 16px;
  left: 10px;
  top: 12px;
}
@media screen and (min-width: 769px) {
  header div.menu .btn_area a{
    width: 160px;
    padding-left: 10px;
  }
  header div.menu .btn_area a:before{
    left: 18px;
    top: 12px;
    background-size: 20px 17px;
    width: 20px;
    height: 17px;
  }
  header div.menu .btn_area a:last-of-type:before{
    left: 18px;
    top: 10px;
    background-size: 20px;
    width: 20px;
    height: 20px;
  }
}
header nav {
  display: none;
  background-color: #fff;
  position: absolute;
  padding: 20px 0 100px;
  text-align: center;
  z-index: 10;
  width: 80%;
  max-width: 768px;
  right: 0;
}
@media screen and (min-width: 769px) {
  header nav {
    padding: 20px 0 140px;
  }
}
header nav ul.menu_area {
  position: relative;
  margin: 0 auto 20px;
}
header nav ul.menu_area li a {
  display: block;
  font-size: 1.6rem;
  white-space: nowrap;
  text-align: center;
  display: block;
  height: 50px;
  line-height: 50px;
  position: relative;
}
header nav ul.menu_area li a:after {
  /* content: '';
  width: 10px;
  height: 10px;
  border: 0;
  border-top: solid 2px #4B4A4A;
  border-right: solid 2px #4B4A4A;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto; */
}

header nav .btn_area{
  height: 85px;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}
header nav .btn_area .btn a{
  display: block;
  width: 80%;
  text-align: center;
  font-weight: 500;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  border-radius: 48px;
  margin:  0 auto 10px;
  color: #fff;
  font-size: 1.8rem;
}
@media screen and (min-width: 769px) {
  header nav .btn_area .btn a{
    width: 50%;
  }
}

/* ハンバーガー */
  .btn_hum {
    display: block;
    position: absolute;
    right: 10px;
    z-index: 10000; /*追記：いつも一番上*/
    /* background: rgba(255, 255, 255, .8); */
    width: 50px;
    height: 50px;
    top: 10px;
  }
  .btn_hum:after{
    content: "";
    display: block;
    position: absolute;
    background: #C79C27;
    width: 100%;
    height: 100%;
    border-radius: 50px;
  }
  .bar {
    width: 22px;
    height: 1px;
    display: block;
    position: absolute;
    left: 25px;
    transform: translateX(-50%);
    background-color: #fff;
    z-index: 2;
  }
  .bar-top {
    top: 18px;
  }
  .bar-middle {
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .bar-bottom {
    bottom: 18px;
  }
  .btn_hum.close .bar-top {
    transform: translate(-50%, 5px) rotate(45deg);
    transition: transform 0.3s;
    background-color: #fff;
    top: 19px;
    left: 25px;
  }
  .btn_hum.close .bar-middle {
    opacity: 0;
    transition: opacity 0.3s;
  }
  .btn_hum.close .bar-bottom {
    transform: translate(-50%, -5px) rotate(-45deg);
    transition: transform 0.3s;
    background-color: #fff;
    bottom: 19px;
    left: 25px;
  }
/* ハンバーガー */
/* ヘッダー固定 */
.is-animation {
  background-color: rgba(255, 255, 255, 1) !important;
  /* height: 70px; */
  margin-top: 0 !important;
  padding-top: 10px;
  /* transition-duration:.5s; */
  border-radius: 0 !important;
  height: 108px !important;
}

/* ヘッダー固定 */
.pagetop {
  position: fixed;
  right: 5vw;
  bottom: 45px;
  z-index: 1000;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #2C2C2C;
}
.pagetop span {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.pagetop span:after {
  content: "";
  background: #ffffff;
  height: 8.6602540378px;
  width: 10px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: 20px;
}

.sp{
  display: block;
}
@media screen and (min-width: 769px) {
  .sp{
    display: none;
  }
}
main{
  padding-top: 56px;
}
.common{
  position: relative;
  padding: 38vw 0 40px;
  background: url(../../images/lp/common_bg.png) no-repeat 0 8px;
  background-size: cover;
  width: 100%;
  height: 100%;
  z-index: 1;
  margin-top: -6vw;
}
.common_btn a{
  text-align: center;
  display: block;
  width: 80%;
  margin: 0 auto 15px;
  height: 70px;
  line-height: 64px;
  border-radius: 8px;
  color: #fff;
  font-size: 2.2rem;
  background-image: linear-gradient(#FF9A03, #E42A00);
  text-shadow: 2px 3px 8px rgba(0, 0, 0, 0.4);
  position: relative;
  border: 2px solid #fff;
  box-shadow: 0px 10px 0px -2px #383838;
  border-radius: 20px;
  position: relative;
  font-family: var(--font-serif);
}
.common_btn a:before {
  content: "";
  position: absolute;
  background: url(../../images/lp/icon_web.svg) no-repeat 0 0;
  background-size: 31px 28px;
  width: 31px;
  height: 28px;
  left: 15px;
  top: 18px;
}
.common_btn a:after {
    content: "";
    position: absolute;
    top: 50%;   /* 縦軸をセンタリングする */ 
    right: 15px;
    transform: translateY(-50%);   /* 縦軸をセンタリングする */  
    border: 8px solid transparent;
    border-left: 12px solid #fff;   /* 好みで色を変えてください */ 
}
.common_btn a:last-child{
  background-image: linear-gradient(#3BE14F, #199E29);
  margin: 0 auto;
}
.common_btn a:last-child:before {
    content: "";
    position: absolute;
    background: url(../../images/lp/icon_line.svg) no-repeat 0 0;
    background-size: 30px 30px;
    width: 30px;
    height: 30px;
    left: 15px;
    top: 18px;
}
.common_btn a img{
  width: 26px;
  position: absolute;
  left: 10%;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 769px) {
  .common{
    padding: 285px 0 50px;
    margin-top: -35px;
  }
  .common_btn a{
    font-size: 2.6rem;
    width: 60%;
  }
}

#worries{
  padding: 0 0 0 5%;
  margin: auto;
  text-align: center;
  background: #383838;
  background-size: cover;
  position: relative;
}
#worries img{
  width: 90%;
  margin: auto;
}
#worries ul{
  background: #FFf;
  width: 100%;
  margin: auto;
  text-align: left;
  padding: 10px 0 15px 5%;
}
#worries ul li{
  font-size: 1.5rem;
  background: url(../../images/lp/worries_check.svg) no-repeat 0 8px;
  background-size: 35px 26px;
  padding: 12px 0 12px 45px;
  border-bottom: 1px solid #DEDEDE;
  margin-right: 5%;
}
#worries ul li:last-child{
  border-bottom: none;
}
#worries ul li span{
  color: var(--main-color);
}
@media screen and (min-width: 769px) {
  #worries ul li{
    font-size: 2rem;
    background: url(../../images/lp/worries_check.svg) no-repeat 0 12px;
  }
}


#reason{
  padding: 80px 0 5%;
  background:rgba(56, 178, 93, 0.1);
  margin: auto;
  text-align: center;
}
#reason .en{
  font-family: var(--font-en);
  font-size: 6.5rem;
  color: rgba(255, 157, 2, 0.15);
  font-style: italic;
  line-height: .7;
}
#reason h2{
  font-size: 2.2rem;
  margin: -3.8em auto 50px;
  font-weight: 300;
  width: 80%;
  position: relative;
}
#reason h2:before,#menu h2:before{
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -10px;
  margin: auto;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: var(--key-color); /* 線の色 */
  /* 線の両端をぼかす */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
}
#reason h2 span{
  color: var(--main-color);
  font-size: 3.5rem;
  display: block;
}
#reason .box{
  position: relative;
  width: 92%;
  margin: 0 0 50px 8%;
  background: #fff;
  padding: 5% 0;
  border-radius: 10px 0 0 10px;
  box-shadow: 8px 8px 16px 0 rgba(113,169,132,.2);
}
#reason .box:nth-of-type(2n){
  margin: 0 5% 50px 0;
  border-radius: 0 10px 10px 0;
}
#reason .box .nu{
  position: absolute;
  top: -30px;
  left: -15px;
  width: 50px;
}
#reason .box:nth-of-type(2n) .nu{
  left: auto;
  right: -20px;
}
#reason .box h3{
  font-size: 2rem;
  margin-bottom: 15px;
  font-weight: 400;
  text-align: left;
  padding: 0 6%;
}
#reason .box .text{
  font-size: 1.4rem;
  margin: 0 auto;
  padding: 6% 6% 0 6%;
  font-weight: 300;
  line-height: 1.7;
  text-align: left;
  font-family: var(--font-sans);
}
#reason .box .note{
  font-size: 1.2rem;
  margin: 10px 5% 0 5%;
  color: rgba(51, 51, 51, 0.7);
  font-weight: 300;
  line-height: 1.7;
  text-align: left;
  font-family: var(--font-sans);
}
#reason .box dl{
  display: flex;
  background: #FFFEF5;
  width: 80%;
  margin: auto;
  align-items: center;
}
#reason .box dl:first-of-type{
  margin-top: 20px;
}
#reason .box dl:nth-of-type(2n){
  flex-direction: row-reverse;
  background: #fff;
}
#reason .box dl dt{
  width: 45%;
}
#reason .box dl dd{
  font-size: 1.2rem;
  width: 55%;
  text-align: left;
  padding-left: 5%;
}
#reason .box dl dd span{
  color: var(--main-color);
  font-size: 1.6rem;
  display: block;
}
@media screen and (min-width: 769px) {
  #reason .en{
    font-size: 7rem;
  }
  #reason h2{
    font-size: 2.7rem;
    margin: -3.6em auto 50px;
  }
  #reason h2 span{
    font-size: 4rem;
  }
  #reason .box .nu{
    position: absolute;
    top: -40px;
    left: -15px;
    width: 70px;
  }
  #reason .box h3{
    font-size: 2.5rem;
  }
  #reason .box .text{
    font-size: 1.9rem;
  }
  #reason .box dl dt{
    font-size: 1.7em;
  }
  #reason .box dl dd span{
    font-size: 2.1rem;
  }
}

#greeting{
  background: url(../../images/lp/greeting_bg.png) no-repeat 0 0;
  background-size: cover;
  width: 100%;
  height: 100%;
  margin: auto;
  text-align: center;
  padding: 25px 0 40px;
}
#greeting .en{
  font-family: var(--font-en);
  font-size: 6.5rem;
  color: rgba(255, 157, 2, 0.15);
  font-style: italic;
  line-height: .7;
}
#greeting h2{
  font-size: 2.2rem;
  margin: -1.8em auto 30px;
  font-weight: 300;
}
#greeting > div{
  margin: 0 0 25vw 8%;
  text-align: left;
}
#greeting > div .clinic{
  color: rgba(51, 51, 51, 0.7);
  font-size: 1.1rem;
}
#greeting > div .kana{
  color: var(--main-color);
  font-size: 1rem;
  margin: 18px auto 0;
}
#greeting > div .name{
  color: var(--main-color);
  font-size: 2rem;
  margin: -3px auto 5px;
}
#greeting > div .possision{
  font-size: 1.3rem;
}
#greeting .text{
  margin: 0 8%;
  text-align: left;
  font-size: 1.4rem;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #greeting .en{
    font-size: 7rem;
  }
  #greeting h2{
    font-size: 2.7rem;
  }
  #greeting > div{
    margin: 50px 0 380px 8%;
  }
  #greeting > div .clinic{
    font-size: 1.6rem;
  }
  #greeting > div .kana{
    font-size: 1.5rem;
  }
  #greeting > div .name{
    font-size: 2.5rem;
  }
  #greeting > div .possision{
    font-size: 1.8rem;
  }
  #greeting .text{
    font-size: 1.9rem;
  }
}

#menu{
  padding: 80px 0 10px;
  margin: auto;
  text-align: center;
}
#menu .en{
  font-family: var(--font-en);
  font-size: 6.5rem;
  color: rgba(255, 157, 2, 0.15);
  font-style: italic;
  line-height: .7;
}
#menu h2{
  font-size: 2.2rem;
  margin: -3.8em auto 50px;
  font-weight: 300;
  width: 80%;
  position: relative;
}
#menu h2 span{
  color: var(--main-color);
  font-size: 3.5rem;
  display: block;
}
@media screen and (min-width: 769px) {
  #menu .en{
    font-size: 7rem;
  }
  #menu h2{
    font-size: 2.7rem;
    margin: -1.6em auto 50px;
  }
  #menu h2 span{
    font-size: 4rem;
  }
}
#menu .wrap{
  width: 90%;
  margin: auto;
  border-radius: 10px;
  position: relative;
}
#menu .wrap .see{
  background: var(--main-color);
  padding-bottom: 50px;
}
#menu .wrap .catch{
  background: var(--key-color);
  width: 35%;
  margin: auto;
  color: #fff;
  height: 36px;
  line-height: 36px;
  font-size: 1.8rem;
  position: absolute;
  top: -18px;
  left: 0;
  right: 0;
}
#menu .wrap .en2{
  font-family: var(--font-en);
  color: rgba(255, 255, 255, .1);
  font-size: 7rem;
  padding-top: 15px;
}
#menu .wrap h3{
  font-size: 2.8rem;
  font-weight: 300;
  color: #fff;
  margin: -2.7em auto 0;
}
#menu .wrap h3 span{
  display: block;
  font-size: 1.6rem;
}
#menu h4{
  font-size: 1.8rem;
  color: #fff;
  font-weight: 300;
  text-align: center;
  margin: 20px auto;
}
#menu ul.big{
  padding-bottom: 20px;
}
#menu ul.big li{
  font-size: 1.4rem;
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  color: #Fff;
  padding: 10px 0 10px 30px;
  width: 80%;
  margin: auto;
  text-align: left;
  font-family: var(--font-sans);
  font-weight: 300;
  background: url(../../images/lp/menu_check.svg) no-repeat 0 10px;
  background-size: 24px 18px;

}
@media screen and (min-width: 769px) {
  #menu .wrap .catch{
    font-size: 2.3rem;
  }
  #menu .wrap h3{
    font-size: 3.5rem;
  }
  #menu .wrap h3 span{
    font-size: 2.1rem;
  }
  #menu h4{
    font-size: 2.3rem;
  }
  #menu ul.big li{
    font-size: 2.3rem;
    background: url(../../images/lp/menu_check.svg) no-repeat 0 14px;
    background-size: 28px 22px;
    padding: 10px 0 10px 36px;
  }
}
#menu .box {
  margin-bottom: 35px;
  background: var(--main-color);
}
#menu .box h4{
  margin-bottom: 20px;
}
#menu .box img{
  width: 90%;
  display: block;
  margin: auto;
}
#menu .inner{
  padding: 8% 10%;
  border-left: 1px solid var(--main-color);
  border-right: 1px solid var(--main-color);
}
#menu .inner h5{
  background: var(--key-color);
  font-size: 1.6rem;
  color: #fff;
  border-bottom: 1px solid var(--key-color);
  border-radius: 6px 6px 0 0;
  position: relative;
  font-weight: 300;
  padding: 3px 0;
}
#menu .inner h5:after{
  content: "";
  position: absolute;
  bottom: -5px;
  width: 100%;
  height: 2px;
  left: 0;
  right: 0;
  margin: auto;
  background: var(--key-color);
}
#menu .inner.color{
  background: #EBF7EF;
}
#menu .inner.w{
  background: #fff;
}
#menu .inner ul.small{
  padding-top: 15px;
}
#menu .inner ul.small.pl{
  padding-left: 4%;
}
#menu .inner ul.small li{
  font-size: 1.2rem;
  text-align: left;
  line-height: 1.7;
}
#menu .inner p{
  padding-top: 15px;
  font-size: 1.4rem;
  line-height: 1.7;
}
#menu .inner .flex{
  display: flex;
  justify-content: space-between;

}
#menu .inner .flex dl{
  width: 70%;
  text-align: left;
}
#menu .inner .flex dl dt{
  font-size: 1.5rem;
  margin-bottom: 10px;
}
#menu .inner .flex dl dd{
  font-size: 1.1rem;
  font-family: var(--font-sans);
}
#menu .inner .flex img{
  width: 28%;
}
#menu .inner .other{
  background: #FFDFEC;
  border-radius: 4px;
  margin-top: 20px;
  padding-bottom: 4%;
}
#menu .inner .other .ttl{
  background: #F95C9B;
  font-size: 1.4rem;
  font-weight: 300;
  padding: 5px 0;
  color: #fff;
  border-radius: 4px 4px 0 0;
  margin-bottom: 15px;
}
#menu .inner .other .text1{
  padding: 0 4%;
  font-size: 1.2rem;
  text-align: left;
}
#menu .inner .other .text1 span{
  color: #F95C9B;
  margin-top: 5px;
}
#menu .inner .other .text2{
  text-align: left;
  font-size: 1.2rem;
  padding: 0 4%;
}
#menu .inner .other ul{
  padding: 0 4%;
}
#menu .text_area{
  background: #7DA188;
  padding: 8% 10% 15%;
  text-align: center;
}
#menu .text_area h6{
  color: #fff;
  font-size: 1.8rem;
  font-weight: 300;
}
#menu .text_area .ttl{
  color: #fff;
  font-size: 1.4rem;
  font-family: var(--font-sans);
  text-align: left;
  margin: 15px auto 5px;
  line-height: 1.7;
}
#menu .text_area li{
  color: rgba(255, 255, 255, 0.7);
  font-size: 1.2rem;
  font-family: var(--font-sans);
  text-align: left;
}
@media screen and (min-width: 769px) {
  #menu .inner h5{
    font-size: 2.1rem;
  }
  #menu .inner ul.small li{
    font-size: 1.7rem;
  }
  #menu .inner p{
    font-size: 1.9rem;
  }
  #menu .inner .flex dl dt{
    font-size: 2rem;
  }
  #menu .inner .flex dl dd{
    font-size: 1.7rem;
  }
  #menu .inner .other .ttl{
    font-size: 1.8rem;
  }
  #menu .text_area h6{
    font-size: 2.3rem;
  }
  #menu .text_area li{
    font-size: 1.7rem;
  }
}

#menu .wrap.color_pur .see,#menu .wrap.color_pur .box{
  background: #616FE9;
}
#menu .wrap.color_pur .inner {
    border-left: 1px solid #616FE9;
    border-right: 1px solid #616FE9;
}
#menu .wrap.color_pur .inner.color{
  background: #DDE0F9;
}
#menu .wrap.color_pur .text_area{
  background: #8A8EB7;
}

#menu .wrap.color_pink .see,#menu .wrap.color_pink .box{
  background: #F95C9B;
}
#menu .wrap.color_pink .inner {
    border-left: 1px solid #F95C9B;
    border-right: 1px solid #F95C9B;
}
#menu .wrap.color_pink .inner.color{
  background: #FFF2F7;
}
#menu .wrap.color_pink .text_area{
  background: #A07587;
}

#menu .wrap.color_green .see,#menu .wrap.color_green .box{
  background: #03C292;
}
#menu .wrap.color_green .inner {
    border-left: 1px solid #03C292;
    border-right: 1px solid #03C292;
}
#menu .wrap.color_green .inner.color{
  background: #E6F9F5;
}
#menu .wrap.color_green .text_area{
  background: #84A49C;
}
#menu .wrap.color_green  .inner .other{
  background: #C3F1E6;
}
#menu .wrap.color_green  .inner .other .ttl{
  background: #03C292;
}
/* #menu .text{
  font-size: 1.4rem;
  color: var(--ilp-txt02);
  line-height: 1.7;
  text-align: center;
  margin: 10px auto 0;
}
@media screen and (min-width: 769px) {
  #menu .text{
    font-size: 2.7rem;
  }
}
#menu .box .text{
  margin: 20px auto 0;
}
#menu .box .text span.b{
  font-weight: 500;
  font-size: 1.4rem;
}
#menu .box .text span.s{
  font-size: 1.3rem;
} */

/* ボタン */
.accordion-btn {
  /* background-color: #fff; */
  bottom: 10px;
  color: #04141C;
  cursor: pointer;
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 500;
  left: 0;
  margin: auto;
  /* position: absolute;
  position: relative; */
  right: 0;
  text-align: center;
  transition: all .2s;
  width: auto;
  /* width: fit-content; */
  z-index: 1;
  position: absolute;
}
/* 続きを読むボタンの表記 */
.accordion-btn::after {
  display: block;
  /* transform: scale(.4); */
  margin: auto;
  text-align: center;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto 0;
  content: "";
  width: 323px;
  height: 64px;
}
.accordion-btn1::after {
  background: url(../../images/lp/btn1.png);
  background-size: 323px 64px;
}
.accordion-btn2::after {
  background: url(../../images/lp/btn2.png);
  background-size: 323px 64px;
}
.accordion-btn3::after {
  background: url(../../images/lp/btn3.png);
  background-size: 323px 64px;
}
.accordion-btn4::after {
  background: url(../../images/lp/btn4.png);
  background-size: 323px 64px;
}
.accordion-btn.is-show ::after {
	display: none;
}
/* ボタンhover時のスタイル */
/* .accordion-btn:hover {
  background-color: #fff;
  color: #6495ed;
} */
.accordion-text {
  overflow: hidden; /* テキストを隠す */
  position: relative;
}
/* 最初に見えてるテキストエリアの高さ */
.accordion-text.is-hide {
  /* height: 100px; */
  height: 0;
}
/* テキストをグラデーションで隠す */
.accordion-text::before {
  /* background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,.9) 50%, rgba(255,255,255,.9) 50%, #fff 100%);
  background:         linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,.9) 50%, rgba(255,255,255,.9) 50%, #fff 100%);
  bottom: 0;
  content: ""; */
  height: 60px; /* グラデーションで隠す高さ */
  position: absolute;
  width: 100%;
  left: 0;
  right: 0;
  margin: auto;
}
/* 閉じるボタンの位置 */
.accordion-btn.is-show {
  bottom: -3em;
}
/* 閉じるボタンの表記 */
.accordion-btn.is-show::after {
  content:"";
  width: 323px;
  height: 64px;
  left: 0;
  margin: auto;
  text-align: center;
  position: absolute;
  /* top: -40px; */
  bottom: 60px;
  margin: auto;
}
.accordion-btn1.is-show::after {
  background: url(../../images/lp/btn1cl.png);
  background-size: 323px 64px;
}
.accordion-btn2.is-show::after {
  background: url(../../images/lp/btn2cl.png);
  background-size: 323px 64px;
}
.accordion-btn3.is-show::after {
  background: url(../../images/lp/btn3cl.png);
  background-size: 323px 64px;
}
.accordion-btn4.is-show::after {
  background: url(../../images/lp/btn4cl.png);
  background-size: 323px 64px;
}
/* 続きを見るボタンをクリックしたらテキストを隠しているグラデーションを消す */
.accordion-btn.is-show + .accordion-text::before {
  display: none;
}
/* レイアウトの為のスタイル */
.accordion {
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
  width: 100%;
  position: relative;
}
.accordion:not(:first-of-type) {
  margin-bottom: 100px;
  margin-top: -25px;
}
.accordion.mt {
  margin-top: 10px;
}
.accordion-text p {
  line-height: 1.3;
}

#treatment{
  background: url(../../images/lp/treatment_bg.png) no-repeat 0 0;
  background-size: cover;
  width: 100%;
  margin: auto;
  /* height: 2780px; */
  text-align: center;
  padding: 100px 0 50px;
}
#treatment .en{
  font-family: var(--font-en);
  font-size: 6.5rem;
  color: rgba(255, 157, 2, 0.15);
  font-style: italic;
  line-height: .7;
}
#treatment h2{
  font-size: 2.2rem;
  margin: -3.8em auto 50px;
  font-weight: 300;
  width: 80%;
  position: relative;
}
#treatment h2:before,#menu h2:before{
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -10px;
  margin: auto;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: var(--key-color); /* 線の色 */
  /* 線の両端をぼかす */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
}
#treatment h2 span{
  color: var(--main-color);
  font-size: 3.5rem;
  display: block;
}
@media screen and (min-width: 769px) {
  #treatment .en{
    font-size: 7rem;
  }
  #treatment h2{
    font-size: 2.7rem;
    margin: -3.6em auto 50px;
  }
  #treatment h2 span{
    font-size: 4rem;
  }
}

#treatment .inner{
  width: 95%;
  margin-left: 5%;
}
@media screen and (min-width:769px){
  #treatment .inner{
    width: 90%;
    max-width: 1200px;
    padding: 100px 3% 0px;
  }
}
#treatment .slide3 {
  /* max-width: 450px; */
  margin: 0 0;
  padding: 0;
}
#treatment .box_section3 {
  /* max-width: 1024px; */
  margin: 0 auto;
}
#treatment .box_area3 {
  overflow-x: auto;
  position: relative;
}
#treatment .box_area3 .scroll {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: 10px;
  margin: 0 auto;
  background-color: rgba(0,0,0,0.5);
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  z-index: 2;
  width: 100%;
  height: 100%;
}
#treatment .box_area3 .scroll .scrollbox{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-40%);
  width: 80%;
}
@media screen and (min-width:769px){
  #treatment .box_area3 .scroll {
    display: none;
  }
}
#treatment .box_area3 .scroll img{
	width: 80px;
	margin: 0 auto 20px;
}
#treatment .box_area3 .scroll p{
  font-size: 1.8rem;
  font-family: "Noto Sans JP", sans-serif;
  color: #fff;
  font-weight: 400;
}
#treatment .box_area3 .slideinner {
  display: flex;
  justify-content: space-between;
  width: 175vw;
  /* height: 500px; */
}
@media screen and (min-width:769px){
  #treatment .box_area3 .slideinner {
    width: 100%;
  }
}
#treatment .box_area3 .slidebox3 {
  width: 35vw;
  box-sizing: border-box;
}
@media screen and (min-width:769px){
  #treatment .box_area3 .slidebox3{
    width: 20%;
  }
    #treatment .box_area3 .slidebox3:nth-of-type(3),#treatment .box_area3 .slidebox3:nth-of-type(4) {
      width: 20%;
  }
}
#treatment .box_area3 .slidebox3 h3 {
  color: #fff;
  text-align: center;
  margin: 0 0 20px
}
#treatment .inner .slide3{
  display: block;
}
#treatment .inner .slide3 dl{
  display: block !important;
  border-right: 2px solid rgba(255,255,255,.5);
}
#treatment .box_area3 .slidebox3:nth-of-type(5) dl{
  border-right:none;

}
#treatment .inner .slide3 dt{
  color: #fff;
  text-align: center;
  background: #666666;
  color: #fff;
  font-size: 1.4rem;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#treatment .box_area3 .slidebox3:nth-of-type(2)  dt{
  background: #38B25D;
}
#treatment .box_area3 .slidebox3:nth-of-type(3)  dt{
  background: #616FE9;
}
#treatment .box_area3 .slidebox3:nth-of-type(4) dt{
  background: #F95C9B;
}
#treatment .box_area3 .slidebox3:nth-of-type(5) dt{
  background: #03C292;
}
@media screen and (min-width:769px){
  #treatment .inner .slide3 dt{
    font-size: 1.6rem;
    height: 55px;
  }
  /* #treatment .box_area3 .slidebox3:nth-of-type(4) dl{
    height: 55px;
  } */
}
#treatment .inner .slide3 dd{
  border-right: 2px solid rgba(255,255,255,.5);
  border-bottom: 2px solid rgba(255,255,255,.5);
  background: rgba(102,102,102,.1);
  color: #333;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  font-family: var(--font-sans);
}
#treatment .inner .slide3 dd span{
  display: contents;
}
#treatment .inner .slide3 dd:nth-of-type(2){
  height: 130px;
}
#treatment .inner .slide3 dd:nth-of-type(3){
  height: 110px;
}
#treatment .inner .slide3 dd:nth-of-type(6){
  height: 180px;
}
#treatment .box_area3 .slidebox3:nth-of-type(2) dd{
  background: rgba(56,178,93,.1);
}
#treatment .box_area3 .slidebox3:nth-of-type(3) dd{
  background: rgba(97,111,233,.1);
}
#treatment .box_area3 .slidebox3:nth-of-type(4) dd{
  background: rgba(240,92,155,.1);
}
#treatment .box_area3 .slidebox3:nth-of-type(5) dd{
  background: rgba(10,200,152,.1);
}
#treatment .box_area3 .slidebox3:nth-of-type(2) dd span{
  color: var(--main-color);
}
#treatment .box_area3 .slidebox3:nth-of-type(3) dd span{
  color: #616FE9;
}
#treatment .box_area3 .slidebox3:nth-of-type(4) dd span{
  color: #F95C9B;
}
#treatment .box_area3 .slidebox3:nth-of-type(5) dd span{
  color: #03C292;
}
@media screen and (min-width:769px){
  #treatment .inner .slide3 dd{
    font-size: 1.5rem;
  }
}
#treatment .inner .slide3 dd.flex{
  display: flex;
  justify-content: space-between;
  padding: 0 4% 0 10%;
}
#treatment .inner .slide3 dd.flex img{
  width: 30%;
}
#treatment .inner .slide3 .slideinner:last-of-type dd{
  border-right: none;
}
#treatment .inner .slide3 .slideinner dd:last-child{
  border-bottom: none;
}
#treatment .inner .slide3 .slidebox3:first-child dd{
  color: #333;
  font-weight: 600;
}
#treatment .note_area{
  margin: auto;
  text-align: left;
  padding-left: 5%;
}
#treatment .note1{
  font-size: 1.4rem;
  font-family: var(--font-sans);
  text-align: left;
  margin: 15px auto 5px;
}
#treatment .note2{
  font-size: 1.4rem;
  display: inline-block;
  font-family: var(--font-sans);
  color: #FF9D02;
  text-align: left;
  text-align: left;
  font-weight: 600;
  border-bottom: 1px solid #FF9D02;
}
@media screen and (min-width:769px){
  #treatment .note_area{
    padding-left: 8%;
  }
  #treatment .note1,#treatment .note2{
    font-size: 1.9rem;
  }
}

#kind{
  margin: auto;
  text-align: center;
  background: rgba(56,178,93,.1);
  padding-bottom: 60px;
}
#kind h2{
  font-size: 2.5rem;
  font-weight: 300;
  background: url(../../images/lp/kind_bg.png) no-repeat;
  background-size: 100% 100%;
  width: 100%;
  height: 77px;
  line-height: 60px;
  color: #fff;
}
#kind .text{
  font-size: 1.4rem;
  line-height: 1.7;
  margin: 20px auto;
}
#kind .box{
  width: 90%;
  background: #fff;
  margin: 0 auto 20px;
  padding: 20px 5%;
  position: relative;
  z-index: 2;
  box-shadow: 8px 8px 16px rgba(113,169,132,.2);
}
#kind .box h3{
  font-size: 2.4rem;
  color: var(--main-color);
  background: #fff;
  padding: 0 10px;
  display: inline-block;
  z-index: 20;
  font-weight: 300;
}
#kind .box h3 span{
  z-index: -1;
}
#kind .box h3 span:first-of-type:before{
  content: "";
  position: absolute;
  left: 0;
  top: 35px;
  width: 28vw;
  height: 3px;
  background-color: var(--main-color);
  -webkit-mask-image: linear-gradient(to right, transparent, black 20%, black 100%, transparent);
  mask-image: linear-gradient(to right, transparent, black 20%, black 100%, transparent);
  z-index: -1;
}
#kind .box h3 span:first-of-type:after{
  content: "";
  position: absolute;
  left: 0;
  top: 40px;
  width: 28vw;
  height: 3px;
  background-color: var(--main-color);
  -webkit-mask-image: linear-gradient(to right, transparent, black 20%, black 100%, transparent);
  mask-image: linear-gradient(to right, transparent, black 20%, black 100%, transparent);
  z-index: -1;
}
#kind .box h3 span:last-of-type:before{
  content: "";
  position: absolute;
  right: 0;
  top: 35px;
  width: 28vw;
  height: 3px;
  background-color: var(--main-color);
  -webkit-mask-image: linear-gradient(to right, transparent, black 0%, black 80%, transparent);
  mask-image: linear-gradient(to right, transparent, black 0%, black 80%, transparent);
  z-index: -1;
}
#kind .box h3 span:last-of-type:after{
  content: "";
  position: absolute;
  right: 0;
  top: 40px;
  width: 28vw;
  height: 3px;
  background-color: var(--main-color);
  -webkit-mask-image: linear-gradient(to right, transparent, black 0%, black 80%, transparent);
  mask-image: linear-gradient(to right, transparent, black 0%, black 80%, transparent);
  z-index: -1;
}
#kind .box h3.line2 span:first-of-type:before,#kind .box h3.line2 span:last-of-type:before{
  top: 55px;
}
#kind .box h3.line2 span:first-of-type:after,#kind .box h3.line2 span:last-of-type:after{
  top: 60px;
}
#kind .box h4{
  font-size: 1.6rem;
  font-weight: 300;
  margin: 3px auto 0
}
#kind .box dl{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 18px;
}
#kind .box dl dt{
  width: 32%;
}
#kind .box dl dd{
  width: 63%;
  text-align: left;
  font-size: 1.4rem;
  line-height: 1.7;
}
#kind .box h5{
  padding: 10px 0;
  font-size: 1.5rem;
  font-family: var(--font-sans);
  text-align: center;
  background: #FFF5E6;
  margin-top: 15px;
  font-weight: 400;
  border-radius: 6px;
}
#kind .box h5 span{
  color: #FF9D02;
}
#kind .box2{
  background: #FFF5E6;
  width: 90%;
  margin: auto;
  border-radius: 10px;
  padding: 0 0 20px;
  box-shadow: 8px 8px 16px rgba(113,169,132,.2);
}
#kind .box2 h6{
  height: 45px;
  line-height: 45px;
  color: #fff;
  font-weight: 300;
  font-size: 2.4rem;
  background: #FF9D02;
  border-radius: 10px 10px 0 0;
}
#kind .box2 .text{
  font-size: 1.4rem;
  line-height: 1.7;
  margin-bottom: 10px;
}
#kind .box2 .inner{
  background: #fff;
  margin: auto;
  width: 90%;
  border-radius: 4px;
  padding: 10px 0;
  font-size: 1.5rem;
  font-weight: 300;
}
#kind .box2 .inner span{
  color: #FF9D02;
  font-weight: 400;
}
@media screen and (min-width:769px){
  #kind h2{
    font-size: 3rem;
  }
  #kind .text{
    font-size: 1.9rem;
  }
  #kind .box h4{
    font-size: 2.1rem;
  }
  #kind .box dl dd{
    font-size: 1.9rem;
  }
  #kind .box h5{
    font-size: 2rem;
  }
  #kind .box2 h6{
    font-size: 2.9rem;
  }
  #kind .box2 .inner{
    font-size: 2rem;
  }
}

#flow{
  padding: 50px 0 50px;
  margin: auto;
  text-align: center;
  background: rgba(255,247,152,.1);
}
#flow h2{
  font-size: 2.6rem;
  font-weight: 300;
  width: 80%;
  position: relative;
  margin: 0 auto 40px;
}
#flow h2{
  font-size: 2rem;
}
#flow h2:before,#menu h2:before{
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -10px;
  margin: auto;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: var(--key-color); /* 線の色 */
  /* 線の両端をぼかす */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
}
@media screen and (min-width: 769px) {
  #flow h2{
    font-size: 2.7rem;
    margin: 0 auto 70px;
  }
}
#flow .box{
  width: 90%;
  margin: 0 auto 30px;
  display: flex;
}
#flow .box:last-of-type{
  margin-bottom: 20px;
}
#flow .box .nu{
  width: 42px;
  color: #fff;
  position: relative;
  z-index: 1;
}
#flow .box .nu img{
  width: 42px;
  height: 46px;
}
#flow .box .nu:after{
  content: '';
  width: 2px;
  height: 26vw;
  background: #38B25D;
  position: absolute;
  bottom: -36px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
}
#flow .box:first-of-type .nu:after,#flow .box:nth-of-type(5) .nu:after{
  /* bottom: -25px; */
}
#flow .box:last-of-type .nu:after{
  content: none;
}
#flow .box dl{
  text-align: left;
  margin-left: 10px;
  width: calc(100% - 46px);
}
#flow .box dl dt{
  font-size: 2.2rem;
  color: var(--main-color);
}
#flow .box dl dd{
  font-size: 1.4rem;
  font-family: var(--font-sans);
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #flow h2{
    font-size: 3.1rem;
  }
  #flow h2 span{
    font-size: 2.5rem;
  }
  #flow .box{
    width: 70%;
    margin: 0 auto 40px;
  }
  #flow .box:last-of-type{
    margin-bottom: 20px;
  }
  #flow .box .nu {
    width: 62px;
    height: 66px;
    margin: -12px 15px 0 0;
  }
  #flow .box .nu img{
    width: 62px;
    height: 66px;
    margin: -12px 15px 0 0;
  }
  #flow .box .nu:after{
    height: 130px;
    bottom: -100px;
  }
  /* #flow .box:first-of-type .nu:after,#flow .box:nth-of-type(5) .nu:after{
    bottom: -30px;
  } */
  #flow .box dl{
    margin-top: -10px;
  }
  #flow .box dl{
    margin-top: -10px;
    width: calc(100% - 62px);
  }
  #flow .box dl dt{
    font-size: 2.7rem;
  }
  #flow .box dl dd{
    font-size: 1.9rem;
  }
  #flow .box .note{
    font-size: 1.9rem;
  }
}

#faq{
  text-align: center;
  padding: 50px 0 40px;
}
#faq h2{
  font-size: 2.6rem;
  font-weight: 300;
  width: 80%;
  position: relative;
  margin: 0 auto 40px;
}
#faq h2{
  font-size: 2rem;
}
#faq h2:before,#menu h2:before{
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -10px;
  margin: auto;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: var(--key-color); /* 線の色 */
  /* 線の両端をぼかす */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
}
@media screen and (min-width: 769px) {
  #faq h2{
    font-size: 3.1rem;
    margin: 0 auto 70px;
  }
}

.accordion_faq{
  margin:0 auto;
  width: 90%;
}
.accordion_faq li{
  margin: 0 0 15px;
  background: rgba(56,178,93,.1);
  color: #fff;
  font-size: 1.6rem;

}
.accordion_faq .accordion_title {
  position: relative;
  cursor: pointer;
  font-size:1.8rem;
  transition: all .5s ease;
  text-align: left;
  padding:10px 25px 10px 60px;
  background: var(--main-color);
  border-radius: 10px 10px 0 0;
}
.accordion_faq .accordion_title span{
  color: var(--main-color);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.8rem;
}
.accordion_faq .accordion_title::before,
.accordion_faq .accordion_title::after{
  position: absolute;
  content:'';
  width: 25px;
  height: 25px;
}
.accordion_faq .accordion_title::before{
  top:50%;
  transform: translateY(-50%);
  right: 8px;
  background: url(../../images/lp/icon_minus.svg) no-repeat center;
}
.accordion_faq .accordion_title.close::before{
  background: url(../../images/lp/icon_plus.svg) no-repeat center;
  top:50%;
  transform: translateY(-50%);
}
.accordion_faq .accordion_box {
  display: none;
  padding: 20px 5% 20px;
  /* position: relative; */
  border-left: 1px solid var(--main-color);
  border-right: 1px solid var(--main-color);
  border-bottom: 1px solid var(--main-color);
  border-radius: 0 0 10px 10px;
  color: #333;
  font-family: var(--font-sans);
  font-size: 1.4rem;
  text-align: left;
}
.accordion_faq .accordion_box .text1{
  font-size: 1.4rem;
  line-height: 1.7;
  font-weight: 300;
}
.accordion_faq .accordion_box .text1 span{
  color: var(--main-color);
  font-weight: bold;
}
.accordion_faq .accordion_box dt{
  font-size: 1.4rem;
  margin-top: 10px;
  font-weight: bold;
}
.accordion_faq .accordion_box dd{
  font-size: 1.4rem;
  font-weight: 300;
}
.accordion_faq .accordion_box .green{
  font-size: 1.4rem;
  line-height: 1.7;
  font-weight: 300;
  color: var(--main-color);
  margin: 10px auto;
}
.accordion_faq .accordion_box li{
  background: none;
  color: #333;
  font-size: 1.4rem;
  margin: 0;
}
.accordion_faq .accordion_box li span{
  font-weight: bold;
}
.accordion_faq .accordion_box hr{
  background-color: rgba(56, 178, 93, 0.3);
  height: 1px;
  border: none;
  margin: 20px auto;
}
@media screen and (min-width: 769px) {
  .accordion_faq li{
    font-size: 2.1rem;
  }
  .accordion_faq .accordion_title {
    font-size:2.2rem;
  }
  .accordion_faq .accordion_title span{
    font-size: 2.3rem;
  }
  .accordion_faq .accordion_box .text1,.accordion_faq .accordion_box dt,.accordion_faq .accordion_box dd,.accordion_faq .accordion_box .green,.accordion_faq .accordion_box li{
    font-size: 1.9rem;
  }
}

#plan{
  text-align: center;
  padding: 50px 0 50px;
  background: url(../../images/lp/plan_bg.png) no-repeat;
  background-size: cover;
}
#plan h2{
  font-size: 2.6rem;
  font-weight: 300;
  width: 80%;
  position: relative;
  margin: 0 auto 30px;
}
#plan h2{
  font-size: 2rem;
}
#plan h2:before,#menu h2:before{
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -10px;
  margin: auto;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: var(--key-color); /* 線の色 */
  /* 線の両端をぼかす */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
}
@media screen and (min-width: 769px) {
  #plan h2{
    font-size: 3.1rem;
    margin: 0 auto 30px;
  }
}
#plan ul{
  padding: 0 5%;
  margin-bottom: 15px;
}
#plan li{
    font-size: 1.1rem;
    font-family: var(--font-sans);
    line-height: 1.7;
    color: rgba(51,51,51,.7);
    text-align: left;
}
#plan .box{
  border-radius: 10px;
  background: #EBF7EF;
  width: 90%;
  margin: 0 auto 25px;
  padding-bottom: 5%;
}
#plan .box h3{
  color: #fff;
  border-radius: 10px 10px 0 0;
  background-image: linear-gradient(90deg, #38b25d, #38b25da6 70%, transparent);
  font-size: 1.8rem;
  padding: 8px 0;
  margin-bottom: 5%;
}
#plan .box h3 span{
  font-size: 1.4rem;
}
#plan .box hr{
  background-color: rgba(56, 178, 93, 0.3);
  height: 1px;
  border: none;
  margin: 15px auto;
  width: 90%;
}
#plan .box dl{
  display: flex;
  padding: 0 5%;
}
#plan .box dl dt{
  font-size: 1.7rem;
  width: 52%;
  background: var(--main-color);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
}
#plan .box dl dd{
  font-size: 2.8rem;
  width: 48%;
  text-align: left;
  padding-left: 5%;
}
#plan .box dl dd span{
  font-size: 1.8rem;
}
#plan .box .ttl{
  font-size: 1.4rem;
  margin-bottom: 10px;
  display: block;
  position: relative;
  z-index: 2;
}
#plan .box .ttl span{
  background: #EDEFFC;
  padding: 0 5px;
  display: inline-block;
}
#plan .box .ttl span:before{
  content: "";
  position: absolute;
  left: 5%;
  top: 48%;
  width: 50%;
  background: #333;
  height: 1px;
  z-index: -1;
}
#plan .box .ttl span:after{
  content: "";
  position: absolute;
  right: 5%;
  top: 48%;
  width: 50%;
  background: #333;
  height: 1px;
  z-index: -1;
}
#plan .box .ttl.mt{
  margin: 25px auto 10px;
}
#plan .box .note{
  font-family: var(--font-sans);
  font-size: 1.1rem;
  color: rgba(51, 51, 51, 0.7);
  margin-top: 10px;
}
#plan .box2{
  width: 90%;
  margin: auto;
  background: #fff;
  border-radius: 10px;
  padding: 5%;
  text-align: left;
}
#plan .box2 li{
  line-height: 1.7;
  font-family: var(--font-sans);
  font-size: 1.1rem;
}
@media screen and (min-width: 769px) {
  #plan li{
    font-size: 1.6rem;
  }
  #plan .box h3{
    font-size: 2.3rem;
  }
  #plan .box h3 span{
    font-size: 1.9rem;
  }
  #plan .box dl dt{
    font-size: 2.3rem;
  }
  #plan .box dl dd{
    font-size: 3.3rem;
  }
  #plan .box dl dd span{
    font-size: 2.3rem;
  }
  #plan .box .ttl{
    font-size: 1.9rem;
  }
  #plan .box .note{
    font-size: 1.6rem;
  }
  #plan .box2 li{
    font-size: 1.6rem;
  }
}


#plan .box.color_pur{
  background: #EDEFFC;
}
#plan .box.color_pur h3{
  background-image: linear-gradient(90deg, #616FE9, #616FE9a6 70%, transparent);
}
#plan .box.color_pur hr{
  background-color: rgba(97, 111, 233, 0.3);
}
#plan .box.color_pur dl dt{
  background:#616FE9;
}

#plan .box.color_pink{
  background: #FFF2F7;
}
#plan .box.color_pink h3{
  background-image: linear-gradient(90deg, #F95C9B, #F95C9Ba6 70%, transparent);
}
#plan .box.color_pink hr{
  background-color: rgba(249, 92, 155, 0.3);
}
#plan .box.color_pink dl dt{
  background:#F95C9B;
}

#plan .box.color_green{
  background: #E6F9F5;
}
#plan .box.color_green h3{
  background-image: linear-gradient(90deg, #03C292, #03C292a6 70%, transparent);
}
#plan .box.color_green hr{
  background-color: rgba(3, 194, 146, 0.3);
}
#plan .box.color_green dl dt{
  background:#03C292;
}


#access{
  text-align: center;
  padding: 50px 0 40px;
}
#access h2{
  font-size: 2.6rem;
  font-weight: 300;
  width: 80%;
  position: relative;
  margin: 0 auto 40px;
}
#access h2{
  font-size: 2rem;
}
#access h2:before,#menu h2:before{
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -10px;
  margin: auto;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: var(--key-color); /* 線の色 */
  /* 線の両端をぼかす */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    black 20%,
    black 80%,
    transparent
  );
}
#access .inner{
  width: 90%;
  margin: auto;
}
#access .inner h3{
  font-weight: 400;
  text-align: left;
  margin: 18px auto 10px;
  font-size: 1.8rem;
}
#access .inner iframe{
  width: 100%;
  height: 250px;
}
#access .inner dl{
  border-bottom: 1px solid #E0E0E0;
  display: flex;
  align-items: center;
  padding: 15px 0;
}
#access .inner dl:first-of-type{
  border-top: 1px solid #E0E0E0;
  margin-top: 15px;
}
#access .inner dl:last-of-type{
  margin-bottom: 15px;
}
#access .inner dl dt{
  width: 23%;
  font-size: 1.4rem;
  text-align: left;
}
#access .inner dl dd{
  width: 77%;
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.7;
}
#access .inner dl dd p{
  text-indent: -1em;
  padding-left: 1em;
}
#access .inner dl dd p:first-child{
  margin-bottom: 5px;
}
@media screen and (min-width: 769px) {
  #access h2{
    font-size: 2.7rem;
    margin: 0 auto 50px;
  }
  #access .inner h3{
    font-size: 2.3rem;
  }
  #access .inner iframe{
    width: 100%;
    height: 400px;
  }
  #access .inner dl dt{
    font-size: 1.9rem;
  }
  #access .inner dl dd{
    font-size: 1.9rem;
  }
}

.common_bottom{
  background: url(../../images/lp/common_bottom_bg.png) no-repeat;
  background-size: cover;
  padding: 50px 0;
  text-align: center;
}
.common_bottom h2{
  font-size: 2.2rem;
  line-height: 1.4;
  font-weight: 300;
  margin-bottom: 20px;
}
.common_bottom h2 span{
  font-size: 3.2rem;
  color: var(--main-color);
  display: block;
}
.common_bottom p{
  font-size: 1.3rem;
  margin: 25px auto 25px;
}
.common_bottom ul{
  background: rgba(255, 255, 255, 0.8);
  width: 90%;
  margin: auto;
  border-radius: 10px;
  padding: 20px;
}
.common_bottom ul li{
  font-size: 1.1rem;
  text-align: left;
}
@media screen and (min-width: 769px) {
  .common_bottom h2{
    font-size: 2.7rem;
  }
  .common_bottom h2 span{
    font-size: 3.7rem;
  }
  .common_bottom p{
    font-size: 1.8rem;
  }
  .common_bottom ul li{
    font-size: 1.6rem;
  }
}
footer small{
  font-size: 1rem;
  text-align: center;
  padding: 18px 0;
  margin: auto;
  display: block;
}
@media screen and (min-width: 769px) {
  footer small{
    font-size: 1.5rem;
  }
}


#bottom_fix{
  display: flex;
  margin-top: 1px;
  position: fixed;
  bottom: -10px;
  z-index: 3;
  width: 100%;
  max-width: 768px;
}
#bottom_fix a{
  width: 50%;
  display: block;
  height: 60px;
  line-height: 58px;
  text-align: center;
  font-weight: 500;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  margin: 0 auto 10px;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 1px;
}
#bottom_fix a.or{
  background-image: linear-gradient(90deg, rgba(249, 230, 88, 1), rgba(253, 34, 27, 1));
}
#bottom_fix a.bl{
  background-image: linear-gradient(90deg, rgba(31, 203, 226, 1), rgba(24, 125, 205, 1));
}




/* お問い合せフォーム用スタイル */
.contact-form {
  margin: 0 auto;
  padding: 30px 2vw;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
@media screen and (min-width: 769px) {
  .contact-form {
    padding: 50px 0;
  }
}
.contact-form .logo{
  display: block;
  width: 90vw;
  margin: auto;
}
@media screen and (min-width: 769px) {
  .contact-form .logo{
    width: 18%;
  }
}
.contact-form h2 {
  font-size: 3.6rem;
  text-align: center;
  margin: 10px auto 20px;
}
@media screen and (min-width: 769px) {
  .contact-form h2 {
    font-size: 4.5rem;
  }
}
.contact-form .roadmap_circle{
  width: 15vw;
  display: block;
  margin: auto;
}
@media screen and (min-width:1200px){
  .contact-form .roadmap_circle{
    width: 60px;
  }
}
.contact-form .box{
  border: 1px solid #F29805;
  border-radius: 20px;
  margin: 25px auto 25px;
  width: 92vw;
  text-align: center;
  padding: 20px 10px;
}

@media screen and (min-width:1200px){
  .contact-form .box{
    max-width: 980px;
    padding: 20px;
    width: auto;
    margin: 40px auto 40px;
  }
}
.contact-form .box h3{
  color: #F29805;
  font-size: 2.5rem;
  margin-bottom: 5px;
}
@media screen and (min-width:1200px){
  .contact-form .box h3{
    font-size: 3.6rem;
  }
}
.contact-form .box h4{
  font-size: 1.6rem;
  font-weight: 400;
}
@media screen and (min-width:1200px){
  .contact-form .box h4{
    font-size: 2rem;
  }
}
.contact-form .cap{
  font-size: 1.4rem;
  width: 92vw;
  margin: 0 auto 30px;
  text-align: center;
  line-height: 1.7;
}
@media screen and (min-width:1200px){
  .contact-form .cap{
    max-width: 980px;
    width: auto;
    font-size: 1.8rem;
  }
}
.contact-form .cap span{
  color: #F29805;
  font-size: 1.8rem;
}
@media screen and (min-width:1200px){
  .contact-form .cap span{
    font-size: 2.2rem;
  }
}
.contact-form form{
  width: 92vw;
  margin: auto;
  background: #fff;
  box-shadow: 0 6px 16px rgba(10,54,85,0.2);
  border-radius: 20px;
  padding: 5vw 4vw;
}
@media screen and (min-width: 769px) {
  .contact-form form{
    max-width: 85%;
    padding: 40px;
  }
}
.contact-form .form-group {
  padding-top: 15px;
  padding-bottom: 10px;
  margin: 0 auto 10px;
}
@media screen and (min-width: 769px) {
  .contact-form .form-group {
    margin: 30px auto;
    padding: 0;
  }
}
.contact-form .form-group.no {
  border-top: none;
  padding-top: 0;
}
.contact-form .ttl,.contact-form .form-group p,.contact-form .form-group .ttl{
  font-size: 1.5rem;
  font-weight: 500;
  margin-bottom: 10px;
}
@media screen and (min-width: 769px) {
  .contact-form .ttl,.contact-form .form-group p,.contact-form .form-group .ttl{
    font-size: 1.7rem;
  }
}
.contact-form .ttl span{
  background: #FA6868;
  color: #fff;
  font-size: 1.1rem;
  display: inline-block;
  padding: 2px 5px;
  vertical-align: 1px;
  margin-left: 8px;
}
@media screen and (min-width: 769px) {
  .contact-form .ttl span{
    font-size: 1.2rem;
  }
}
.contact-form .text{
  font-size: 1.4rem;
  text-align: left;
  margin-bottom: 15px;
}
@media screen and (min-width: 769px) {
  .contact-form .text{
    font-size: 1.6rem;
  }
}
.contact-form .form-group label {
  font-size: 1.4rem;
  text-align: left;
  margin-bottom: 8px;
  margin-right: 16px;
  display: inline-block;
}

@media screen and (min-width: 769px) {
  .contact-form .form-group label {
    font-size: 1.6rem;
  }
}
.contact-form .form-group label input[type="radio"] {
  display: inline-block;
  margin-right: 8px;
}
.contact-form .form-group .text_s{
  font-size: 1.4rem;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .contact-form .form-group .text_s{
    font-size: 1.6rem;
  }
}
.contact-form .text_s span{
  font-size: 1.3rem;
  display: block;
  margin: 2px auto 10px;
}
@media screen and (min-width: 769px) {
  .contact-form .text_s span{
    font-size: 1.5rem;
    margin: 5px auto 10px;
  }
}
.contact-form input[type="text"],
.contact-form input[type="tel"],
.contact-form input[type="date"],
.contact-form input[type="email"],
.contact-form select {
  width: 100%;
  padding: 10px 12px;
  font-size: 1.4rem;
  border: 1px solid #CFCFCF;
  border-radius: 6px;
  background: #F5F5F5;
  margin-top: 4px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  display: block;
}
.contact-form input[type="radio"] {
  margin-right: 8px;
}
.contact-form input[type="radio"] {
  appearance: auto !important;
  -webkit-appearance: radio !important;
  -moz-appearance: radio !important;
}
.contact-form button[type="submit"] {
  width: 100%;
  background-image: linear-gradient(90deg, rgba(249, 230, 81, 1), rgba(253, 34, 27, 1));
  color: #fff;
  font-size: 1.8rem;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.2s;
  margin: auto;
  display: block;
  height: 60px;
  line-height: 60px;
}
@media screen and (min-width: 769px) {
  .contact-form button[type="submit"] {
    width: 60%;
    height: 80px;
    line-height: 80px;
    font-size: 1.8rem;
  }
}
.contact-form button[type="submit"]:hover {
  /* background: #1761a0; */
}
.contact-form ::placeholder{
    font-size: 1.3rem;
    color: rgba(51,51,51,0.5);
}
@media screen and (min-width: 769px) {
  .contact-form ::placeholder{
    font-size: 1.5rem;
  }
}
.contact-form textarea {
  width: 100%;
  padding: 10px 12px;
  font-size: 1.4rem;
  border: 1px solid #CFCFCF;
  border-radius: 6px;
  background: #F5F5F5;
  margin: 0 auto;
  resize: vertical;
  box-sizing: border-box;
  height: 120px;
}
@media screen and (min-width: 769px) {
  .contact-form textarea {
    height: 150px;
    margin: 0 auto 5px;
  }
}
.contact-form select {
  background-image: url('data:image/svg+xml;utf8,<svg fill="%23999" height="20" viewBox="0 0 20 20" width="20" xmlns="http://www.w3.org/2000/svg"><path d="M7.293 8.293a1 1 0 011.414 0L10 9.586l1.293-1.293a1 1 0 111.414 1.414l-2 2a1 1 0 01-1.414 0l-2-2a1 1 0 010-1.414z"/></svg>') !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  background-size: 20px 20px !important;
  padding-right: 36px !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
}
/* IE用: デフォルトの矢印を消す */
.contact-form select::-ms-expand {
  display: none;
}
@media screen and (min-width: 769px) {
  .contact-form input[type="date"],#company,#zipcode,#email,#tel{
    width: 45%;
  }
}
#prefecture,#position{
  width: 40%;
}
@media screen and (min-width: 769px) {
  #prefecture,#employees,#position{
    width: 20%;
  }
}
.contact-form .name-row {
  display: flex;
  gap: 12px;
}
@media screen and (min-width: 769px) {
  .contact-form .name-row {
  
  }
}
@media screen and (min-width: 769px) {
  .contact-form .name-col {
    min-width: 100px;
  }
}
.contact-form .form-group .privacy{
  text-align: center;
  margin: auto;
  display: block;
  font-size: 1.3rem;
}
@media screen and (min-width: 769px) {
  .contact-form .form-group .privacy{
    font-size: 1.4rem;
  }
}
