@charset "UTF-8";
/* --------------------------------

Site Name: [ 汎用scssテンプレート ]
Site URI: [ 汎用scssテンプレート ]
Description: [ 汎用scssテンプレート ]
Version: [ 1.0 ]
Author: gramglan
Author URI: gramglan.work

-------------------------------- */
/* SITE COLOR */
/*
mixin
*/
/* --------------------------------
MIXIN
- gramglan
-------------------------------- */
/* SETTING */
/* mixin */
/* --------------------------------
汎用MIXIN
-------------------------------- */
/* margin padding 0指定 */
/* BOX-SIZING */
/* 透過 */
/* hover処理 */
/* 画像のhover処理 */
/* 吹き出し
@include arrow(#ccc, 10, 30%);
*/
/* SNS COLOR */
/* alpha base color */
/*
gradient
@include gradient(#ff00ff, #ff00cc, vertical);
*/
/* --------------------------------
サポートブラウザの設定
-------------------------------- */
/* ベンダープレフィックス */
/* --------------------------------
clearfix
-------------------------------- */
/* --------------------------------
FONT STYLE
-------------------------------- */
/* font-family
@include font__noto;
*/
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");
/* width設定 */
/*
	base padding
*/
/*
	base margin
*/
/*
	flexbox
*/
/*
	absolute
	@include absolute(0,0,0,0);
	@include absolute($t:0,$r:0, $b:0,$l:0);
*/
/* --------------------------------
MEDIA QUERY

@include mq(){}

'xsmall': 320px,
'small' : 600px,
'medium': 768px,
'large' : 1024px,
'xlarge': 1280px,

@include or(){};

'p': 'portrait',
'l': 'landscape',

-------------------------------- */
/* --------------------------------
角丸設定
-------------------------------- */
/* 基本設定 */
/* --------------------------------
MIXIN
- gramglan


MEDIA QUERY

@include mq(){}

'xsmall': 320px,
'small' : 600px,
'medium': 768px,
'large' : 1024px,
'xlarge': 1280px,

@include or(){};

'p': 'portrait',
'l': 'landscape',

-------------------------------- */
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  margin: 0;
  padding: 0;
  font-family: "Noto Sans Japanese", sans-serif;
  font-size: 16px;
  font-size: 5vw;
}
@media screen and (min-width: 768px) {
  body {
    font-size: 16px;
    font-size: 1rem;
  }
}
body {
  color: #333;
}

a {
  text-decoration: none;
}
a:hover {
  outline: none;
  border: none;
}

img {
  vertical-align: bottom;
  max-width: 100%;
}

ul, li, dl, dt, dd, ol, p, h1, h2, h3, h4, h5, h6, p, figure, figcaption, input, textarea {
  margin: 0;
  padding: 0;
  list-style: none;
}

ul:after, ol:after {
  *zoom: 1;
}
ul:after:after, ol:after:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

/* --------------------------------
MIXIN
- gramglan


MEDIA QUERY

@include mq(){}

'xsmall': 320px,
'small' : 600px,
'medium': 768px,
'large' : 1024px,
'xlarge': 1280px,

@include or(){};

'p': 'portrait',
'l': 'landscape',

-------------------------------- */
/* 横幅指定 */
.mod__wrap {
  width: 100%;
  position: relative;
}
@media screen and (min-width: 768px) {
  .mod__wrap {
    margin: 0 auto;
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (min-width: 0px) {
  .mod__wrap {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (min-width: 600px) {
  .mod__wrap {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .mod__wrap {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (min-width: 1024px) {
  .mod__wrap {
    max-width: 1000px;
  }
}
@media screen and (min-width: 768px) and (min-width: 1280px) {
  .mod__wrap {
    max-width: 1000px;
  }
}

.mod__flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
}
.mod__flex .mod__flex__item {
  width: 100%;
}
.mod__flex .mod__flex__item.-w20 {
  width: 50%;
}
@media screen and (min-width: 768px) {
  .mod__flex .mod__flex__item.-w10 {
    width: 10%;
  }
  .mod__flex .mod__flex__item.-w20 {
    width: 20%;
  }
  .mod__flex .mod__flex__item.-w25 {
    width: 24%;
  }
  .mod__flex .mod__flex__item.-w30 {
    width: 30%;
  }
  .mod__flex .mod__flex__item.-w40 {
    width: 40%;
  }
  .mod__flex .mod__flex__item.-w50 {
    width: 50%;
  }
  .mod__flex .mod__flex__item.-w60 {
    width: 60%;
  }
  .mod__flex .mod__flex__item.-w70 {
    width: 70%;
  }
  .mod__flex .mod__flex__item.-w80 {
    width: 80%;
  }
  .mod__flex .mod__flex__item.-w90 {
    width: 90%;
  }
  .mod__flex .mod__flex__item.-w100 {
    width: 100%;
  }
}
@media screen and (min-width: 1024px) {
  .mod__flex .mod__flex__item {
    padding: 0 0 0 0;
  }
}
@media screen and (min-width: 1024px) and (min-width: 768px) {
  .mod__flex .mod__flex__item {
    padding: 0 0 0 0;
  }
}
@media screen and (min-width: 1024px) {
  .mod__flex .mod__flex__item.-flex {
    -ms-flex: 1; /*IE10*/
    -webkit-box-flex: 1; /* Android4.3以下、Safari3.1〜6.0 */
    -webkit-flex: 1; /* Safari6.1以降 */
  }
  .mod__flex .mod__flex__item.-w10 {
    width: 10%;
  }
  .mod__flex .mod__flex__item.-w20 {
    width: 20%;
  }
  .mod__flex .mod__flex__item.-w25 {
    width: 24%;
  }
  .mod__flex .mod__flex__item.-w30 {
    width: 30%;
  }
  .mod__flex .mod__flex__item.-w40 {
    width: 40%;
  }
  .mod__flex .mod__flex__item.-w50 {
    width: 50%;
  }
  .mod__flex .mod__flex__item.-w60 {
    width: 60%;
  }
  .mod__flex .mod__flex__item.-w70 {
    width: 70%;
  }
  .mod__flex .mod__flex__item.-w80 {
    width: 80%;
  }
  .mod__flex .mod__flex__item.-w90 {
    width: 90%;
  }
  .mod__flex .mod__flex__item.-w100 {
    width: 100%;
  }
}
.mod__flex .mod__flex__item.-full {
  width: 100%;
}
.mod__flex.-just_around {
  -ms-flex-pack: justify; /*IE10*/
  -webkit-box-pack: justify; /* Android4.3以下、Safari3.1〜6.0 */
  -webkit-justify-content: space-around; /* Safari6.1以降 */
  justify-content: space-around;
}
.mod__flex.-just_center {
  -ms-flex-pack: justify; /*IE10*/
  -webkit-box-pack: justify; /* Android4.3以下、Safari3.1〜6.0 */
  -webkit-justify-content: center; /* Safari6.1以降 */
  justify-content: center;
}
.mod__flex.-just_between {
  -ms-flex-pack: justify; /*IE10*/
  -webkit-box-pack: justify; /* Android4.3以下、Safari3.1〜6.0 */
  -webkit-justify-content: space-between; /* Safari6.1以降 */
  justify-content: space-between;
}
.mod__flex {
  /* reverse setting */
}
.mod__flex.-rev_all {
  flex-flow: row-reverse wrap;
  -ms-flex-flow: row-reverse wrap;
  -webkit-flow: row-reverse wrap;
}
@media screen and (min-width: 768px) {
  .mod__flex.-rev {
    flex-flow: row-reverse wrap;
    -ms-flex-flow: row-reverse wrap;
    -webkit-flow: row-reverse wrap;
  }
}

/* JS用 */
/* 各ページ */
/* --------------------------------
HEADER
- gramglan

MEDIA QUERY

@include mq(){}

'xsmall': 320px,
'small' : 600px,
'medium': 768px,
'large' : 1024px,
'xlarge': 1280px,

@include or(){};

'p': 'portrait',
'l': 'landscape',

-------------------------------- */
/* body add class*/
.__sp {
  display: block;
}
@media screen and (min-width: 768px) {
  .__sp {
    display: none;
  }
}

.__pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .__pc {
    display: block;
  }
}

/* lp_header */
.lp_header {
  position: fixed;
  z-index: 1000;
  top: 0em;
  left: 1em;
  border-radius: 0 0 16px 16px;
  padding: 0.5em 1em;
  background: #FFFFFF;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}
@media screen and (min-width: 768px) {
  .lp_header {
    padding: 1em 3em;
  }
}
.lp_header a {
  display: block;
  line-height: 1;
}
.lp_header a img {
  width: 80px;
  height: auto;
}
@media screen and (min-width: 768px) {
  .lp_header a img {
    width: 100px;
  }
}

/* main_cv */
.main_cv {
  text-align: center;
}
.main_cv a {
  position: relative;
  top: -54px;
}

/* sp acc */
.block {
  padding: 0 16px 16px;
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .block {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

.displayNone {
  display: none;
}

.accordion a {
  display: block;
}

.contentWrap {
  background: #fff;
  border-radius: 8px;
  margin-bottom: 8px;
  text-align: left;
}
.contentWrap p {
  padding: 16px;
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .contentWrap p {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.contentWrap p {
  margin-bottom: 12px;
}
.contentWrap .min {
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .contentWrap .min {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.contentWrap h4 {
  padding: 24px 0 8px;
}
.contentWrap .plan_detail_case {
  border: 1px solid #ddd;
  padding: 8px;
  border-radius: 4px;
  margin-bottom: 8px;
}

.switch {
  cursor: pointer;
  font-weight: bold;
  padding: 16px 40px 10px 16px;
  font-size: 14px;
  position: relative;
  background: #fff;
  border-radius: 8px;
  margin-bottom: 8px;
  text-align: left;
}
.switch img {
  margin-right: 16px;
  float: left;
  width: 50px;
  height: auto;
}
.switch h3 {
  padding-bottom: 8px;
  color: #1D9EA4;
  font-size: 16px;
  font-size: 5vw;
}
@media screen and (min-width: 768px) {
  .switch h3 {
    font-size: 16px;
    font-size: 1rem;
  }
}

.switch:after {
  position: absolute;
  top: 60%;
  right: 20px;
  margin-top: -18px;
  content: ">";
  font-size: 18px;
  font-weight: bold;
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -moz-transition: all, 0.25s, linear;
  -o-transition: all, 0.25s, linear;
  -webkit-transition: all, 0.25s, linear;
  transition: all, 0.25s, linear;
  font-family: sans-serif;
  color: #1D9EA4;
}

.switch.open:after {
  -moz-transform: translate(0, 50%);
  -ms-transform: translate(0, 50%);
  -webkit-transform: translate(0, 50%);
  transform: translate(0, 50%);
  -moz-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
  font-family: sans-serif;
}

/* price */
.price {
  background: rgba(245, 35, 111, 0.03);
  padding: 24px 24px;
}
@media screen and (min-width: 768px) {
  .price {
    padding: 48px 0;
  }
}
.price_title {
  color: #F5236F;
  text-align: center;
  padding-bottom: 32px;
}
.price_title strong {
  font-size: 32px;
  font-size: 10vw;
}
@media screen and (min-width: 768px) {
  .price_title strong {
    font-size: 32px;
    font-size: 2rem;
  }
}
.price_title h2 {
  font-weight: normal;
  font-size: 14px;
  font-size: 4.375vw;
}
@media screen and (min-width: 768px) {
  .price_title h2 {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
@media screen and (min-width: 768px) {
  .price_title strong {
    font-size: 48px;
    font-size: 15vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price_title strong {
    font-size: 48px;
    font-size: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .price_title h2 {
    font-weight: normal;
    font-size: 15px;
    font-size: 4.6875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price_title h2 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .price_basic {
  border-top: 10px solid #F5236F;
  max-width: 720px;
  margin: 0 auto 0px;
  background: #FFFFFF;
  box-sizing: border-box;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price .price_basic {
    padding: 0;
  }
}
@media screen and (min-width: 1024px) {
  .price .price_basic {
    max-width: 980px;
  }
}
.price .price_basic .mod__flex__item {
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price .price_basic .mod__flex__item {
    padding: 24px;
  }
}
.price .price_basic .txt-right {
  text-align: right;
}
.price .price_basic .line-right {
  border-bottom: 1px solid #eee;
}
@media screen and (min-width: 768px) {
  .price .price_basic .line-right {
    border-right: 1px solid #eee;
    border-bottom: none;
  }
}
.price .price_basic h3 {
  font-size: 24px;
  font-size: 7.5vw;
}
@media screen and (min-width: 768px) {
  .price .price_basic h3 {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
.price .price_basic h3 span {
  font-size: 24px;
  font-size: 7.5vw;
}
@media screen and (min-width: 768px) {
  .price .price_basic h3 span {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
.price .price_basic h3.big {
  font-size: 40px;
  font-size: 12.5vw;
}
@media screen and (min-width: 768px) {
  .price .price_basic h3.big {
    font-size: 40px;
    font-size: 2.5rem;
  }
}
.price .price_basic h3.big {
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .price .price_basic h3 {
    font-size: 38px;
    font-size: 11.875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .price_basic h3 {
    font-size: 38px;
    font-size: 2.375rem;
  }
}
@media screen and (min-width: 768px) {
  .price .price_basic h3 span {
    font-size: 38px;
    font-size: 11.875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .price_basic h3 span {
    font-size: 38px;
    font-size: 2.375rem;
  }
}
@media screen and (min-width: 768px) {
  .price .price_basic h3.big {
    font-size: 60px;
    font-size: 18.75vw;
    line-height: 1;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .price_basic h3.big {
    font-size: 60px;
    font-size: 3.75rem;
  }
}
.price .price_basic .price_caps {
  color: #F5236F;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .price_basic .price_caps {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .price_basic .price_info {
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .price .price_basic .price_info {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.price .price_option {
  max-width: 720px;
  margin: 0 auto 24px;
}
@media screen and (min-width: 1024px) {
  .price .price_option {
    max-width: 980px;
  }
}
.price .price_option .mod__flex__item.-w20 {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .price .price_option .mod__flex__item.-w20 {
    width: 20%;
  }
}
.price .price_option_wrap {
  height: 200px;
  padding: 16px;
  overflow: hidden;
  position: relative;
}
.price .price_option_wrap.open {
  height: auto;
  overflow: visible;
}
.price .price_option_wrap.open:after {
  display: none;
}
.price .price_option_wrap:after {
  display: block;
  width: 100%;
  height: 80px;
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(360deg, #FFF8FB 0%, rgba(255, 248, 251, 0) 100%);
}
.price .price_option_wrap .more_read {
  position: absolute;
  text-align: center;
  bottom: 20px;
  left: 0;
  width: 100%;
  z-index: 100;
}
.price .price_option_wrap .more_read span {
  background: #F5236F;
  color: #fff;
  line-height: 1;
  padding: 8px 32px;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .price_option_wrap .more_read span {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .price_option_wrap .more_read span {
  border-radius: 60px;
  margin: 0 auto;
  cursor: pointer;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -ms-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.price .price_option_wrap .more_read span:hover {
  opacity: 0.5;
  filter: alpha(opacity=50);
}
.price .price_option_wrap .more_read.close {
  bottom: -20px;
}
.price .price_option_wrap .more_read.close span {
  background: #999;
}
.price .price_plus {
  color: #F5236F;
  text-align: center;
  padding: 12px;
  padding-bottom: 32px;
  margin: 0 auto 0px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .price .price_plus {
    padding: 12px;
  }
}
.price .price_plus strong {
  display: block;
  font-size: 60px;
  font-size: 18.75vw;
}
@media screen and (min-width: 768px) {
  .price .price_plus strong {
    font-size: 60px;
    font-size: 3.75rem;
  }
}
.price .price_plus strong {
  line-height: 1;
}
.price .price_plus span {
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .price_plus span {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .option1 {
  background: #FFFFFF;
  box-sizing: border-box;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  padding: 24px;
  margin-bottom: 16px;
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price .option1 {
    padding: 0;
  }
}
.price .option1 .mod__flex__item {
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price .option1 .mod__flex__item {
    padding: 24px;
  }
}
.price .option1 .txt-right {
  text-align: right;
}
.price .option1 .line-right {
  border-bottom: 1px solid #eee;
}
@media screen and (min-width: 768px) {
  .price .option1 .line-right {
    border-bottom: none;
  }
}
.price .option1 h4 {
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .option1 h4 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .option1 h4 span {
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .price .option1 h4 span {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.price .option1 h4.big {
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .option1 h4.big {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .option1 h4.big {
  line-height: 1;
  font-weight: normal;
}
@media screen and (min-width: 768px) {
  .price .option1 h4 {
    font-size: 18px;
    font-size: 5.625vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .option1 h4 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (min-width: 768px) {
  .price .option1 h4 span {
    font-size: 16px;
    font-size: 5vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .option1 h4 span {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .price .option1 h4.big {
    font-size: 18px;
    font-size: 5.625vw;
    line-height: 1;
    font-weight: normal;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .option1 h4.big {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.price .option1 .price_caps {
  color: #F5236F;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .option1 .price_caps {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .option1 .price_caps {
  display: none;
}
.price .option1 .price_info {
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .price .option1 .price_info {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.price .option2 {
  background: #FFFFFF;
  box-sizing: border-box;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  margin-bottom: 16px;
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price .option2 {
    padding: 24px;
  }
}
.price .option2 {
  *zoom: 1;
}
.price .option2:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
.price .option2 h4 {
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .option2 h4 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .option2 h4 {
  padding: 12px;
  border-bottom: 1px solid #eee;
}
.price .option2 h4 span {
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .price .option2 h4 span {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.price .option2 h4 span {
  font-weight: normal;
}
.price .option2 p {
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .price .option2 p {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.price .option2 p {
  text-align: right;
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price .option2 h4 {
    font-size: 18px;
    font-size: 5.625vw;
    float: left;
    padding: 0;
    border-bottom: none;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .option2 h4 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (min-width: 768px) {
  .price .option2 h4 span {
    font-size: 13px;
    font-size: 4.0625vw;
    font-weight: normal;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .option2 h4 span {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
@media screen and (min-width: 768px) {
  .price .option2 p {
    font-size: 18px;
    font-size: 5.625vw;
    float: right;
    padding: 0;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .price .option2 p {
    font-size: 18px;
    font-size: 1.125rem;
  }
}

/* price_att */
.price_att {
  color: #666;
  padding: 12px;
}
@media screen and (min-width: 768px) {
  .price_att {
    padding: 24px 0;
  }
}
.price_att .price_att_item {
  padding: 16px;
}
.price_att h3 {
  font-family: Hiragino Kaku Gothic Pro;
  font-style: normal;
  font-weight: normal;
  font-size: 14px;
  line-height: 21px;
  border-bottom: 1px solid #ddd;
  padding: 8px 0;
}
.price_att p {
  font-family: Hiragino Kaku Gothic Pro;
  font-style: normal;
  font-weight: normal;
  font-size: 11px;
  line-height: 16px;
  white-space: pre-line;
}

/* qa */
.qa {
  padding: 48px 0;
  margin: 0 0px;
}
@media screen and (min-width: 768px) {
  .qa {
    max-width: 600px;
    margin: 0 auto;
  }
}
@media screen and (min-width: 1024px) {
  .qa {
    max-width: 1140px;
  }
}
.qa_title {
  text-align: center;
  color: #1D9EA4;
  padding-bottom: 32px;
}
.qa_title strong {
  font-size: 48px;
  font-size: 15vw;
}
@media screen and (min-width: 768px) {
  .qa_title strong {
    font-size: 48px;
    font-size: 3rem;
  }
}
.qa_title h2 {
  font-weight: normal;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .qa_title h2 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.qa .qa_wrap {
  height: 280px;
  padding: 16px;
  overflow-y: hidden;
  overflow-x: visible;
  position: relative;
}
.qa .qa_wrap.open {
  height: auto;
  overflow: visible;
}
.qa .qa_wrap.open:after {
  display: none;
}
.qa .qa_wrap:after {
  display: block;
  width: 100%;
  height: 80px;
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(360deg, #fff 0%, rgba(255, 248, 251, 0) 100%);
}
.qa .qa_wrap .more_read {
  position: absolute;
  text-align: center;
  bottom: 20px;
  left: 0;
  width: 100%;
  z-index: 100;
}
.qa .qa_wrap .more_read span {
  background: #1D9EA4;
  color: #fff;
  line-height: 1;
  padding: 8px 32px;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .qa .qa_wrap .more_read span {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.qa .qa_wrap .more_read span {
  border-radius: 60px;
  margin: 0 auto;
  cursor: pointer;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -ms-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.qa .qa_wrap .more_read span:hover {
  opacity: 0.5;
  filter: alpha(opacity=50);
}
.qa .qa_wrap .more_read.close {
  bottom: -20px;
}
.qa .qa_wrap .more_read.close span {
  background: #999;
}
.qa .q_title {
  max-width: 720px;
  margin: 0 50px 16px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .qa .q_title {
    margin: 0 auto 16px;
  }
}
.qa .q_title img {
  border-radius: 50%;
  height: auto;
  position: absolute;
  width: 32px;
  left: -40px;
}
@media screen and (min-width: 768px) {
  .qa .q_title img {
    width: 48px;
    left: -64px;
  }
}
.qa .q_title p {
  padding: 16px;
  background: #ddd;
  display: inline-block;
  border-radius: 4px;
  max-width: 600px;
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .qa .q_title p {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
@media screen and (min-width: 768px) {
  .qa .q_title p {
    font-size: 15px;
    font-size: 4.6875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .qa .q_title p {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.qa .a_title {
  max-width: 720px;
  margin: 0 50px 16px;
  position: relative;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .qa .a_title {
    margin: 0 auto 16px;
  }
}
.qa .a_title img {
  border-radius: 50%;
  height: auto;
  position: absolute;
  border: 1px solid #eee;
  width: 32px;
  right: -40px;
}
@media screen and (min-width: 768px) {
  .qa .a_title img {
    width: 48px;
    right: -64px;
  }
}
.qa .a_title p {
  padding: 16px;
  background: rgba(196, 230, 242, 0.3);
  display: inline-block;
  border-radius: 4px;
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .qa .a_title p {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.qa .a_title p {
  max-width: 600px;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .qa .a_title p {
    font-size: 15px;
    font-size: 4.6875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .qa .a_title p {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.qa .qa_contact {
  max-width: 720px;
  margin: 16px auto 16px;
  border: 1px solid #ccc;
  padding: 24px;
  border-radius: 4px;
  text-align: center;
}
.qa .qa_contact p {
  margin-bottom: 24px;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .qa .qa_contact p {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}

.contact {
  background: #f7f7f7;
  padding: 24px;
}
.contact_title {
  text-align: center;
  color: #1D9EA4;
  padding-bottom: 32px;
}
.contact_title strong {
  font-size: 48px;
  font-size: 15vw;
}
@media screen and (min-width: 768px) {
  .contact_title strong {
    font-size: 48px;
    font-size: 3rem;
  }
}
.contact_title h2 {
  font-weight: normal;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .contact_title h2 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.contact_detail {
  font-size: 14px;
  font-size: 4.375vw;
}
@media screen and (min-width: 768px) {
  .contact_detail {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
.contact_detail {
  padding: 16px 0;
}
@media screen and (min-width: 768px) {
  .contact_detail {
    padding: 32px;
    font-size: 15px;
    font-size: 4.6875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .contact_detail {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.contact_detail input, .contact_detail select, .contact_detail textarea {
  padding: 12px;
  border: 1px solid #ddd;
  box-sizing: border-box;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .contact_detail input, .contact_detail select, .contact_detail textarea {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.contact_detail input, .contact_detail select, .contact_detail textarea {
  outline: none;
  width: 100%;
  border-radius: 4px;
}
.contact_detail input[type=submit] {
  border: none;
  border-radius: 46px;
  max-width: 300px;
  margin: 0 auto;
  display: block;
  font-size: 20px;
  font-size: 6.25vw;
}
@media screen and (min-width: 768px) {
  .contact_detail input[type=submit] {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.contact_detail input[type=checkbox] {
  width: auto;
}
.contact_detail label {
  padding: 8px;
  display: block;
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .contact_detail label {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
@media screen and (min-width: 768px) {
  .contact_detail label {
    font-size: 15px;
    font-size: 4.6875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .contact_detail label {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.contact_detail dt {
  display: block;
  padding-bottom: 8px;
}
.contact_detail dt small {
  color: red;
}
.contact_detail dd {
  padding-bottom: 24px;
}
.contact .m-0 {
  padding-bottom: 8px;
  color: #333;
  text-align: center;
}
.contact .privacy_box {
  font-size: 11px;
  border: 1px solid #ddd;
  background: #f7f7f7;
  color: #333;
  padding: 12px;
  height: 180px;
  overflow: auto;
}
@media screen and (min-width: 768px) {
  .contact .privacy_box {
    height: 350px;
    padding: 24px;
    overflow: auto;
  }
}
.contact .contactbg {
  background: #fff;
  border-radius: 16px;
  padding: 24px;
}
@media screen and (min-width: 768px) {
  .contact .contactbg {
    width: 700px;
    margin: 0 auto;
  }
}

.footer {
  text-align: center;
  padding: 16px;
}
.footer a {
  color: #1D9EA4;
  font-size: 12px;
  text-decoration: underline;
  display: inline-block;
  padding: 4px;
}

/* btn_cv */
.btn_cv {
  background: linear-gradient(270deg, #DE1F86 0%, rgba(222, 31, 134, 0) 100%), #F5236F;
  border-radius: 80px;
  padding: 12px 24px;
  color: #fff;
  display: inline-block;
  font-size: 15px;
  font-size: 4.6875vw;
}
@media screen and (min-width: 768px) {
  .btn_cv {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
@media screen and (min-width: 768px) {
  .btn_cv {
    padding: 12px 48px;
    font-size: 18px;
    font-size: 5.625vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .btn_cv {
    font-size: 18px;
    font-size: 1.125rem;
  }
}

.lp_title {
  line-height: 1;
  display: flex;
  flex-flow: column;
  max-width: 1000px;
  margin: 0 auto;
  padding: 1.5em;
  margin-bottom: 0em;
}
@media screen and (min-width: 768px) {
  .lp_title {
    padding: 0em;
    margin-bottom: 2em;
  }
}
.lp_title strong {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  color: #D9D9D9;
  font-size: 80px;
  padding-left: 0.75em;
}
.lp_title strong.-price {
  color: rgba(222, 31, 134, 0.11);
}
.lp_title strong.-plan {
  color: rgba(29, 158, 164, 0.25);
}
.lp_title h2 {
  position: relative;
  top: -0.6em;
  font-size: 28px;
}
.lp_title p {
  font-size: 13px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .lp_title p {
    font-size: 16px;
  }
}

.lp_catch {
  padding-bottom: 0em;
}
.lp_catch h2 {
  display: flex;
  flex-wrap: wrap;
  font-size: 20px;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
}
.lp_catch h2 img {
  width: 200px;
  height: auto;
}
.lp_catch h2 strong {
  width: 100%;
  text-align: center;
  font-size: 32px;
  color: #F5236F;
}

/* strong_point */
.strong_point {
  text-align: center;
  margin-bottom: 2em;
}
.strong_point_read {
  margin-bottom: 48px;
}
.strong_point_read img {
  width: 300px;
  height: auto;
}
.strong_point h2 {
  position: relative;
  font-size: 28px;
  font-size: 8.75vw;
}
@media screen and (min-width: 768px) {
  .strong_point h2 {
    font-size: 28px;
    font-size: 1.75rem;
  }
}
.strong_point h2 {
  color: #1D9EA4;
  line-height: 1.2;
}
.strong_point h2 strong {
  font-size: 40px;
  font-size: 12.5vw;
}
@media screen and (min-width: 768px) {
  .strong_point h2 strong {
    font-size: 40px;
    font-size: 2.5rem;
  }
}
.strong_point h2 strong {
  color: #F5236F;
}
@media screen and (min-width: 768px) {
  .strong_point h2 {
    line-height: 1.5;
    position: relative;
    font-size: 48px;
    font-size: 15vw;
    color: #1D9EA4;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .strong_point h2 {
    font-size: 48px;
    font-size: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .strong_point h2 strong {
    font-size: 64px;
    font-size: 20vw;
    color: #F5236F;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .strong_point h2 strong {
    font-size: 64px;
    font-size: 4rem;
  }
}
.strong_point .mod__flex__item.strong_item {
  width: 90%;
}
.strong_point .mod__flex {
  flex-flow: column;
  align-items: center;
  gap: 1em;
}
@media screen and (min-width: 768px) {
  .strong_point .mod__flex {
    gap: 1em;
    flex-flow: row;
  }
}
.strong_point .strong_item {
  background: #fff;
  box-sizing: border-box;
  line-height: 1;
  flex: 1;
  border-radius: 8px;
  display: flex;
  flex-flow: row;
  gap: 0.5em;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item {
    background: #fff;
    box-sizing: border-box;
    line-height: 1;
    flex: 1;
    border-radius: 8px;
    display: flex;
    flex-flow: column;
    overflow: hidden;
    gap: 0.5em;
    padding-bottom: 1em;
  }
}
.strong_point .strong_item img {
  width: 30%;
  height: auto;
  object-fit: cover;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item img {
    width: 100%;
  }
}
.strong_point .strong_item div {
  padding: 0.5em;
  width: 70%;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item div {
    width: 100%;
    text-align: center;
  }
}
.strong_point .strong_item p {
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item p {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.strong_point .strong_item p {
  padding-top: 4px;
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item p {
    padding-top: 1em;
    font-size: 15px;
    font-size: 4.6875vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .strong_point .strong_item p {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.strong_point .strong_item h3 {
  color: #1D9EA4;
  font-size: 16px;
  font-size: 5vw;
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item h3 {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .strong_point .strong_item h3 {
    font-size: 24px;
    font-size: 7.5vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .strong_point .strong_item h3 {
    font-size: 24px;
    font-size: 1.5rem;
  }
}

/* news */
.news {
  background-color: #F7F7F7;
  padding: 4em 0;
}

.news_list {
  display: flex;
  gap: 2em;
  max-width: 1000px;
  margin: 0 auto;
  padding: 2em 0;
  flex-flow: column;
  padding: 1.5em;
}
@media screen and (min-width: 768px) {
  .news_list {
    flex-flow: row;
    padding: 0;
  }
}
.news_list img {
  border-radius: 8px;
}
.news_list .news_list_first {
  flex: 1;
}
.news_list .news_list_first a {
  display: flex;
  flex-flow: column;
  gap: 0.5em;
  color: #000;
}
.news_list .news_list_first a span {
  font-size: 16px;
  opacity: 0.7;
}
.news_list .news_list_first a p {
  font-weight: bold;
  font-size: 18px;
}
.news_list .news_list_first a img {
  width: 100%;
  object-fit: cover;
}
.news_list .news_list_common {
  flex: 1;
  display: flex;
  flex-flow: column;
  gap: 1em;
  justify-content: space-between;
}
.news_list .news_list_common a {
  display: flex;
  gap: 1em;
  align-items: flex-start;
}
.news_list .news_list_common a img {
  width: 40%;
  object-fit: cover;
}
.news_list .news_list_common a {
  color: #000;
}
.news_list .news_list_common a span {
  font-size: 16px;
  opacity: 0.7;
}
.news_list .news_list_common a p {
  font-weight: bold;
  font-size: 18px;
}

/* support */
.support {
  max-width: 1000px;
  margin: 0 auto;
  padding: 4em 0;
}
@media screen and (min-width: 1024px) {
  .support {
    max-width: 1140px;
  }
}
.support .support_item {
  margin-bottom: 0px;
  box-sizing: border-box;
  padding: 4px;
}
.support .support_item img {
  border: 1px solid #eee;
}

.support_list {
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  gap: 1em; /* 間隔を 1em */
  grid-template-columns: repeat(2, 1fr); /* 3列均等 */
  padding: 0 1em;
}
@media screen and (min-width: 768px) {
  .support_list {
    padding: 2em 0;
    grid-template-columns: repeat(3, 1fr); /* 3列均等 */
  }
}
.support_list li a img {
  border-radius: 8px;
}

/* contact_area */
.contact_area {
  background: #f7f7f7;
  background-size: cover;
  padding: 30px;
  margin: 4em 0;
}
@media screen and (min-width: 768px) {
  .contact_area {
    padding: 120px 0;
    background: #ccc url(contact_bg.png) no-repeat center;
    background-size: cover;
  }
}
.contact_area .contact_item {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .contact_area .contact_item {
    padding-right: 30%;
  }
}
.contact_area .contact_item p {
  margin-bottom: 24px;
  font-size: 14px;
  font-size: 4.375vw;
}
@media screen and (min-width: 768px) {
  .contact_area .contact_item p {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
@media screen and (min-width: 768px) {
  .contact_area .contact_item p {
    font-size: 16px;
    font-size: 5vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .contact_area .contact_item p {
    font-size: 16px;
    font-size: 1rem;
  }
}

/* plan */
.plan {
  padding: 0;
}
.plan .plan_wrap {
  padding: 0 24px 48px;
}
.plan .block {
  padding: 0;
}
.plan .block .contentWrap {
  padding: 16px;
}
.plan .block .contentWrap p {
  padding: 0 0 8px 0;
}
.plan_title {
  text-align: center;
  padding-bottom: 32px;
}
.plan_title strong {
  font-size: 48px;
  font-size: 15vw;
}
@media screen and (min-width: 768px) {
  .plan_title strong {
    font-size: 48px;
    font-size: 3rem;
  }
}
.plan_title strong {
  color: #1D9EA4;
}
.plan_title h2 {
  font-weight: bold;
  color: #333;
  font-size: 24px;
  font-size: 7.5vw;
}
@media screen and (min-width: 768px) {
  .plan_title h2 {
    font-size: 24px;
    font-size: 1.5rem;
  }
}

.plan_case {
  background: #FFFFFF;
  border: 1px solid #EEEEEE;
  box-sizing: border-box;
  border-radius: 8px;
  margin: 0 auto 5%;
}
@media screen and (min-width: 768px) {
  .plan_case {
    max-width: 700px;
  }
}
@media screen and (min-width: 1024px) {
  .plan_case {
    max-width: 760px;
  }
}
.plan_case .case_title {
  justify-content: center;
  align-items: center;
  border-right: 1px solid #eee;
  padding-top: 24px;
}
@media screen and (min-width: 768px) {
  .plan_case .case_title {
    padding-top: 0px;
  }
}
.plan_case .case_detail {
  padding: 24px;
  font-size: 13px;
  font-size: 4.0625vw;
}
@media screen and (min-width: 768px) {
  .plan_case .case_detail {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

.planbox .mod__flex {
  flex-flow: column;
  gap: 1em;
}
@media screen and (min-width: 768px) {
  .planbox .mod__flex {
    flex-flow: row;
  }
}

.mod__flex__item.plan_item {
  width: 100%;
  gap: 1em;
  background-color: #fff;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}
@media screen and (min-width: 768px) {
  .mod__flex__item.plan_item {
    width: 30%;
    gap: 0em;
  }
}

.plan_item {
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  text-align: center;
  cursor: pointer;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -ms-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.plan_item:hover {
  opacity: 0.5;
  filter: alpha(opacity=50);
}
.plan_item {
  position: relative;
  display: flex;
  flex-flow: row;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .plan_item {
    width: 33%;
    flex-flow: column;
  }
}
.plan_item .plan_img {
  display: none;
}
@media screen and (min-width: 768px) {
  .plan_item .plan_img {
    display: block;
  }
}
.plan_item .plan_icon {
  display: block;
  width: 32px;
  height: 32px;
  object-fit: contain;
  position: relative;
  left: 1em;
}
@media screen and (min-width: 768px) {
  .plan_item .plan_icon {
    display: none;
  }
}
.plan_item div {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-flow: column;
  padding: 0.5em 1em;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .plan_item div {
    align-items: center;
    padding: 1em 1em;
  }
}
.plan_item h3 {
  color: #1D9EA4;
  font-size: 14px;
  font-size: 4.375vw;
}
@media screen and (min-width: 768px) {
  .plan_item h3 {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
@media screen and (min-width: 768px) {
  .plan_item h3 {
    font-size: 20px;
    font-size: 6.25vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .plan_item h3 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.plan_item p {
  font-size: 11px;
  font-size: 3.4375vw;
}
@media screen and (min-width: 768px) {
  .plan_item p {
    font-size: 11px;
    font-size: 0.6875rem;
  }
}
@media screen and (min-width: 768px) {
  .plan_item p {
    font-size: 13px;
    font-size: 4.0625vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .plan_item p {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
.plan_item i {
  position: absolute;
  bottom: 16px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 13.9px 8px 0 8px;
  border-color: #fff transparent transparent transparent;
}
.plan_item .more {
  background: #666;
  color: #fff;
  padding: 0.5em 1em;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 11px;
  font-size: 3.4375vw;
}
@media screen and (min-width: 768px) {
  .plan_item .more {
    font-size: 11px;
    font-size: 0.6875rem;
  }
}
.plan_item .more {
  width: 110px;
  height: 80px;
}
@media screen and (min-width: 768px) {
  .plan_item .more {
    width: 100%;
    height: auto;
    padding: 1.7em 9px;
    font-size: 16px;
    font-size: 5vw;
    background: #666;
    color: #fff;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .plan_item .more {
    font-size: 16px;
    font-size: 1rem;
  }
}

/* plan_detail */
.plan_line {
  border: 1px solid #eee;
  border-collapse: collapse;
  margin: 12px 0;
}
@media screen and (min-width: 768px) {
  .plan_line {
    margin: 32px 0;
  }
}

.plan_detail {
  padding: 24px 0;
  display: flex;
  flex-flow: column;
  align-items: center;
  border: 1px solid #ddd;
  border-radius: 16px;
  margin-bottom: 4em;
}
.plan_detail .plan_detail_title {
  color: #1D9EA4;
  font-weight: bold;
  text-align: left;
  padding: 24px;
  padding-bottom: 24px;
}
@media screen and (min-width: 768px) {
  .plan_detail .plan_detail_title {
    padding: 0;
    text-align: center;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-size: 6.25vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .plan_detail .plan_detail_title {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 1024px) {
  .plan_detail .plan_detail_title {
    font-size: 24px;
    font-size: 7.5vw;
  }
}
@media screen and (min-width: 1024px) and (min-width: 768px) {
  .plan_detail .plan_detail_title {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
.plan_detail .plan_detail_title h3 {
  padding-bottom: 0px;
}
.plan_detail .plan_detail_text {
  padding: 24px;
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .plan_detail .plan_detail_text {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (min-width: 768px) {
  .plan_detail .plan_detail_text {
    font-size: 14px;
    font-size: 4.375vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .plan_detail .plan_detail_text {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
.plan_detail .plan_detail_text p {
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .plan_detail .plan_detail_text p {
    padding-right: 1em;
  }
}
@media screen and (min-width: 1024px) {
  .plan_detail .plan_detail_text p {
    padding-right: 0em;
  }
}
.plan_detail .plan_detail_text .min {
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .plan_detail .plan_detail_text .min {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.plan_detail .plan_detail_text h4 {
  padding: 24px 0 8px;
  margin-bottom: 24px;
}
.plan_detail .plan_detail_text .plan_detail_case {
  border: 1px solid #ddd;
  padding: 8px;
  border-radius: 4px;
  margin-bottom: 8px;
  margin-right: 24px;
}

.plan_details {
  padding: 0 2em;
}

/* adviser */
.adviser {
  margin: 0 auto 5em;
  border: 1px solid #1D9EA4;
  max-width: 90%;
}
@media screen and (min-width: 768px) {
  .adviser {
    max-width: 1000px;
  }
}
.adviser_obi {
  background: #1D9EA4;
  color: #fff;
  text-align: center;
  padding: 24px;
  margin-bottom: 16px;
  font-size: 14px;
  font-size: 4.375vw;
}
@media screen and (min-width: 768px) {
  .adviser_obi {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
@media screen and (min-width: 768px) {
  .adviser_obi {
    font-size: 18px;
    font-size: 5.625vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .adviser_obi {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (min-width: 1024px) {
  .adviser_obi {
    font-size: 24px;
    font-size: 7.5vw;
  }
}
@media screen and (min-width: 1024px) and (min-width: 768px) {
  .adviser_obi {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
.adviser_title {
  text-align: center;
  padding: 24px;
}
.adviser_item {
  margin-bottom: 32px;
  padding: 16px;
  *zoom: 1;
}
.adviser_item:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
@media screen and (min-width: 768px) {
  .adviser_item {
    padding: 32px;
  }
}
@media screen and (min-width: 1024px) {
  .adviser_item {
    padding: 16px;
  }
}
.adviser_item h3 {
  color: #1D9EA4;
  font-size: 16px;
  font-size: 5vw;
}
@media screen and (min-width: 768px) {
  .adviser_item h3 {
    font-size: 16px;
    font-size: 1rem;
  }
}
.adviser_item h3 {
  margin-bottom: 12px;
  border-bottom: 1px solid #ddd;
  padding-bottom: 4px;
}
@media screen and (min-width: 768px) {
  .adviser_item h3 {
    background: url(../img/face_logo.png) no-repeat 160px 4px;
    background-size: 24px;
    margin-right: 16px;
    text-indent: 24px;
    font-size: 18px;
    font-size: 5.625vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .adviser_item h3 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.adviser_item h3 span {
  font-weight: normal;
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .adviser_item h3 span {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.adviser_item p {
  padding-right: 16px;
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .adviser_item p {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.adviser_item p {
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .adviser_item p {
    font-size: 14px;
    font-size: 4.375vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .adviser_item p {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
.adviser_face {
  margin-right: 16px;
  margin-bottom: 4px;
  float: left;
  width: 100px;
  border-radius: 8px;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .adviser_face {
    width: 150px;
  }
}
.adviser .mod__wrap {
  padding: 0 1em;
}
@media screen and (min-width: 768px) {
  .adviser .mod__wrap {
    padding: 0 2em;
  }
}

.main_visual img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) {
  .main_visual img {
    width: 100%;
    height: auto;
    object-fit: cover;
  }
}

/* whats */
.arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  top: -2em;
  margin-bottom: 1em;
}

.whats {
  background: linear-gradient(180deg, rgba(29, 158, 164, 0) 0%, rgba(29, 158, 164, 0.1) 100%);
  padding-bottom: 3em;
}
@media screen and (min-width: 768px) {
  .whats {
    padding: 2em;
  }
}
.whats h2 {
  color: #1D9EA4;
  text-align: center;
  padding: 0.5em 0;
  font-size: 20px;
  font-size: 6.25vw;
}
@media screen and (min-width: 768px) {
  .whats h2 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 768px) {
  .whats h2 {
    margin-bottom: 32px;
    padding: 32px;
    font-size: 32px;
    font-size: 10vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .whats h2 {
    font-size: 32px;
    font-size: 2rem;
  }
}

.whats_list {
  display: flex;
  gap: 1em;
  width: 90%;
  margin: 0 auto;
  flex-flow: column;
}
@media screen and (min-width: 768px) {
  .whats_list {
    max-width: 1000px;
    flex-flow: row;
  }
}

.whats_list_item {
  padding: 0.5em 0.5em;
  border-radius: 4px;
  background: #FFF;
  box-shadow: 0px 1px 4px 0px rgba(0, 0, 0, 0.25);
  display: flex;
  align-items: center;
  flex: 1;
  gap: 0.5em;
}
@media screen and (min-width: 768px) {
  .whats_list_item {
    padding: 0.5em 1em;
    gap: 0;
    flex-flow: column;
  }
}
.whats_list_item .faceicon {
  width: 32px;
  height: 32px;
  object-fit: cover;
  border-radius: 50%;
}
@media screen and (min-width: 768px) {
  .whats_list_item .faceicon {
    position: relative;
    top: -20px;
    width: 80px;
    height: 80px;
    object-fit: cover;
  }
}
.whats_list_item .-whats_item_cont {
  display: flex;
  flex-flow: column;
}
@media screen and (min-width: 768px) {
  .whats_list_item .-whats_item_cont {
    flex-flow: column;
    align-items: center;
    gap: 1em;
    font-size: 15px;
  }
}
.whats_list_item .-whats_item_cont .role {
  opacity: 0.5;
  font-size: 12px;
}
.whats_list_item .-whats_item_cont p {
  font-size: 12px;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  .whats_list_item .-whats_item_cont p {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (min-width: 768px) {
  .whats_list_item .-whats_item_cont p {
    font-size: 14px;
    font-size: 4.375vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .whats_list_item .-whats_item_cont p {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.float_banner {
  display: none;
  position: fixed;
  bottom: 0.5em;
  right: 0.5em;
  z-index: 1000;
}
.float_banner img {
  width: 250px;
  height: auto;
  box-shadow: 0px 1px 4px 0px rgba(0, 0, 0, 0.25);
  border-radius: 8px;
}/*# sourceMappingURL=style.css.map */