.ta-c {
  text-align: center;
}

.yellow {
  color: #fff728;
}

.red {
  color: #e71a28;
}

/*===============================================================================
header
===============================================================================*/
.header__bg {
  padding: 20px 0;
}

.header__inner {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 1200px;
}

.header__ttl01 {
  width: 200px;
}

.header__txt01 {
  width: 275px;
}

.header__bg02 {
  padding: 7px 0;
  background-color: #d8d8d8;
}

.header__list {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}

.header__item {
  margin: 0 15px;
}

.header__item .link {
  display: block;
  font-size: 15px;
  font-weight: bold;
  letter-spacing: 0;
}

.header__item:nth-child(1) {
  margin-left: 0;
}

.header__btn01 {
  width: 180px;
}

/*===============================================================================
fv
===============================================================================*/
.fv__bg {
  padding: 85px 0 120px;
  background: url(../img/fv_bg01.png) top center/2000px no-repeat, #fff9eb;
}

.fv__inner {
  width: 1200px;
}

.fv__ttl01 {
  width: 695px;
}

.fv__img01 {
  width: 575px;
  margin: 26px 0 0 60px;
}

/*===============================================================================
wha
===============================================================================*/
.wha__bg {
  padding: 54px 0 55px;
  background: url(../img/wha_bg01.png) top center/2000px no-repeat, url(../img/wha_bg03.png) top center/2000px repeat-x;
}

.wha__inner {
  width: 1080px;
}

.wha__comment {
  width: 424px;
  margin: 0 auto;
}

.wha__ttl01 {
  width: 616px;
  margin-left: 40px;
}

.wha__wrap {
  margin: 60px auto 0;
  padding: 40px;
  background: #fff;
  background: url(../img/wha_bg02.png) top center/100% 100% no-repeat;
}

.wha__box {
  padding: 59px 0 55px;
  border-radius: 20px;
  background-color: #fff;
}

.wha__en {
  width: 526px;
  margin: 0 auto;
}

.wha__txt01 {
  margin-top: 33px;
  color: #313131;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: center;
}

.wha__txt01 .bold {
  font-size: 30px;
}

.wha__txt02 {
  margin-top: 33px;
  color: #fff;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  text-align: center;
}

/*===============================================================================
mov
===============================================================================*/
.mov__bg {
  padding: 0 0 100px;
}

.mov__flex {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mov__left {
  width: 469px;
}

.mov__txt01 {
  width: 309px;
  margin: 40px auto 0;
}

.mov__box {
  width: 500px;
  margin-left: 30px;
}

.mov__lead {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  border-radius: 33px 33px 0 0;
  background: #e60012;
  color: #fff;
  font-size: 21px;
  font-weight: bold;
  letter-spacing: 0.06em;
}

/*===============================================================================
sup
===============================================================================*/
.sup__bg {
  padding: 45px 0 70px;
  background-color: #e6f8ff;
}

.sup__img01 {
  margin-top: 6px;
}

/*===============================================================================
not
===============================================================================*/
.not__bg {
  z-index: 3;
  position: relative;
  padding: 75px 0;
  background: url(../img/not_shape01.png) top 207px center/1969px repeat-x, url(../img/not_bg01.png) bottom center/2000px no-repeat, url(../img/not_bg02.png) bottom center/2000px repeat-x;
}

.not__ttl01 {
  -webkit-transform: translateX(-34px);
  -ms-transform: translateX(-34px);
  width: 1068px;
  transform: translateX(-34px);
}

.not__txt02 {
  width: 840px;
  margin: -25px auto 0;
}

.not__box {
  margin-top: 285px;
  padding: 47px 65px 45px;
  border-radius: 30px;
  background: #fff;
}

.not__txt03 {
  font-size: 20px;
  font-weight: 500;
  line-height: 2;
}

.not__txt03 .border {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(70%, transparent), color-stop(70%, #fff728));
  background: -webkit-linear-gradient(top, transparent 70%, #fff728 70%);
  background: linear-gradient(to bottom, transparent 70%, #fff728 70%);
  line-height: 1.2;
}

/*===============================================================================
ach
===============================================================================*/
.ach__bg {
  z-index: 2;
  position: relative;
  margin-top: -20px;
  padding: 120px 0 120px;
  overflow: hidden;
  background: url(../img/not_shape01.png) top left/2000px repeat-x, #eaf5f8;
}

.ach__inner {
  z-index: 1;
  position: relative;
}

.ach__inner::after {
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  display: block;
  z-index: -1;
  position: absolute;
  top: -360px;
  left: 50%;
  width: 2426px;
  height: 396px;
  padding: 108px 213px 35px;
  transform: translateX(-50%);
  border-radius: 50%;
  background-color: #009bcf;
  content: "";
}

.ach__ttl01 {
  -webkit-transform: translateX(-33px);
  -ms-transform: translateX(-33px);
  width: 1066px;
  transform: translateX(-33px);
}

.ach__box {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-box-align: end;
  -ms-flex-align: end;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: 58px;
}

.ach__info {
  width: 576px;
}

.ach__img01 {
  width: 560px;
  margin: 40px 0 0 5px;
}

.ach__img02 {
  width: 391px;
}

.ach__slide01 {
  margin-top: 70px;
}

/*===============================================================================
kar
===============================================================================*/
.kar__bg {
  padding-top: 140px;
  background: url(../img/kar_bg01.png) top center/2000px;
}

.kar__head {
  position: relative;
  margin-top: 75px;
}

.kar__txt01 {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.91;
}

.kar__txt01--num01 {
  position: absolute;
  top: 0;
  right: 100px;
  width: 350px;
}

.kar__txt01--num02 {
  width: 470px;
  margin-top: -190px;
}

.kar__txt01 .border {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(70%, transparent), color-stop(70%, #fff728));
  background: -webkit-linear-gradient(top, transparent 70%, #fff728 70%);
  background: linear-gradient(to bottom, transparent 70%, #fff728 70%);
  line-height: 1.2;
}

.kar__ttl02 {
  width: 934px;
  margin: 110px auto 0;
}

.kar__img03 {
  width: 670px;
  margin: 40px auto 0;
}

/*===============================================================================
fea
===============================================================================*/
.fea__bg {
  padding-top: 20px;
  background: url(../img/kar_bg01.png) top center/2000px;
}

.fea__bg--num02 {
  padding-bottom: 100px;
}

.fea__ttl01 {
  -webkit-transform: translateX(5px);
  -ms-transform: translateX(5px);
  width: 1010px;
  margin: 0 auto;
  transform: translateX(5px);
}

.fea__inner {
  padding: 1px 50px 50px;
  border-radius: 0 0 30px 30px;
  background-color: #fff;
}

.fea__inner--num02 {
  margin-bottom: -20px;
  border-radius: 0;
}

.fea__inner--num03 {
  padding: 15px 50px 50px;
}

.fea__lead {
  margin-top: 20px;
  color: #009bcf;
  font-size: 40px;
  font-weight: bold;
  letter-spacing: 0.06em;
  line-height: 1.35;
  text-align: center;
}

.fea__lead .num {
  font-size: 50px;
}

.fea__lead .alert {
  font-size: 18px;
  vertical-align: top;
}

.fea__lead--num02 {
  letter-spacing: 0;
}

.fea__flex {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  margin-top: 36px;
  padding-right: 10px;
}

.fea__flex .fea__img01 {
  width: 407px;
  margin-top: 0;
}

.fea__flex .fea__txt01 {
  width: 434px;
  color: #313131;
  font-size: 17px;
  letter-spacing: 0.04em;
  line-height: 1.66;
}

.fea__flex .fea__txt01--num02 {
  margin: -10px 0;
  font-size: 20px;
  line-height: 2;
}

.fea__img01 {
  margin-top: 25px;
}

.fea__img01--num01 {
  margin-top: -25px;
}

.fea__img01--num02 {
  margin-top: 60px;
}

.fea__img01--num03 {
  margin-top: 60px;
}

.fea__img01--num04 {
  -webkit-transform: translateY(-10px);
  -ms-transform: translateY(-10px);
  transform: translateY(-10px);
}

.fea__img01--num05 {
  width: 650px;
  margin: 25px auto 0;
}

.fea__lead02 {
  margin-top: 55px;
  color: #009bcf;
  font-size: 40px;
  font-weight: bold;
  letter-spacing: 0.06em;
  line-height: 1.435;
  text-align: center;
}

.fea__lead02 .bold {
  font-size: 50px;
}

.fea__lead02--num02 {
  margin-top: 40px;
  color: #000;
  font-size: 36px;
}

.fea__bg02 {
  padding: 0 50px 55px;
  background: url(../img/fea_bg02.png) top center/900px repeat;
}

.fea__ttl02 {
  -webkit-transform: translateY(-20px);
  -ms-transform: translateY(-20px);
  margin-bottom: -100px;
  transform: translateY(-20px);
}

.fea__box {
  position: relative;
  padding: 20px 98px 23px;
  border-radius: 30px;
  background-color: #009bcf;
  color: #fff;
}

.fea__box::after {
  display: block;
  position: absolute;
  top: -20px;
  left: 23px;
  width: 78px;
  height: 78px;
  background: url(../img/fea_arrow01.png) top center/contain no-repeat;
  content: "";
}

.fea__box--num02 {
  margin-top: 65px;
}

.fea__box__ttl {
  padding: 0 0 12px;
  border-bottom: dotted 3px #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
}

.fea__box__ttl .big {
  font-size: 30px;
}

.fea__box__txt {
  margin-top: 20px;
  font-size: 25px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
}

.fea__txt03 {
  margin-top: 25px;
  font-size: 20px;
  text-align: center;
}

.fea__txt02 {
  margin-top: 5px;
  font-size: 28px;
  font-weight: bold;
  text-align: center;
}

.fea__box02 {
  position: relative;
  width: 552px;
  margin: 25px 0 0 60px;
  padding: 20px 20px 17px 73px;
  border-radius: 19px;
  background-color: #fff;
  color: #009bcf;
}

.fea__box02--num02 {
  margin: 10px 0 0 185px;
  padding: 17px 95px 17px 45px;
  color: #f65a0e;
}

.fea__box02--num02 .fea__icon01 {
  right: -45px;
  left: inherit;
}

.fea__icon01 {
  position: absolute;
  top: 15px;
  left: -20px;
  width: 69px;
  height: 69px;
}

.fea__box02__en {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1.43;
}

.fea__box02__txt {
  margin-top: 22px;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.43;
}

.fea__close {
  display: block;
  width: 400px;
  margin: 30px auto 0;
}

.fea__close .on {
  display: none;
}

.fea__close .off {
  display: block;
}

.fea__close.open .on {
  display: block;
}

.fea__close.open .off {
  display: none;
}

.fea__content {
  display: none;
  margin-top: -15px;
}

.fea__note {
  margin-top: -4px;
  padding-right: 20px;
  color: #68c1e1;
  font-size: 12px;
  font-weight: 500;
  text-align: right;
}

/*===============================================================================
mor
===============================================================================*/
.mor__bg {
  padding-bottom: 100px;
  background-color: #e6f7fe;
}

.mor__ttl01 {
  width: 1361px;
  margin-left: -152px;
}

.mor__lead {
  margin-top: 35px;
  font-size: 32px;
  font-weight: bold;
  letter-spacing: 0.06em;
  text-align: center;
}

.mor__lead .big {
  font-size: 44px;
  line-height: 1;
}

.mor__lead--num02 {
  margin-top: 70px;
}

.mor__flex {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  margin-top: 25px;
}

.mor__img01 {
  width: 532px;
}

.mor__img02 {
  width: 500px;
}

.mor__txt01 {
  width: 436px;
  color: #313131;
  font-size: 20px;
  font-weight: 500;
  line-height: 2;
}

.mor__box {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  align-items: center;
  margin-top: 40px;
  padding: 30px 79px;
  border-radius: 30px;
  background-color: #fff;
}

.mor__box::after {
  display: block;
  position: absolute;
  top: 30px;
  right: -30px;
  width: 228px;
  height: 158px;
  background: url(../img/mor_icon02.png) top center/contain no-repeat;
  content: "";
}

.mor__txt02 {
  margin-right: 53px;
  color: #313131;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 2;
}

/*===============================================================================
flo
===============================================================================*/
.flo__bg {
  padding: 100px 0;
  background: url(../img/kar_bg01.png) top center/2000px;
}

.flo__ttl01 {
  width: 448px;
  margin: 0 auto;
}

.flo__wrap {
  margin-top: 60px;
}

.flo__tabs {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
}

.flo__tab {
  width: 275px;
  margin: 0 10px;
}

.flo__tab .on {
  display: none;
}

.flo__tab .off {
  display: block;
}

.flo__tab.show .on {
  display: block;
}

.flo__tab.show .off {
  display: none;
}

.flo__contents {
  display: none;
  width: 800px;
  margin: 20px auto 0;
}

.flo__contents.show {
  display: block;
}

.flo__box {
  width: 800px;
  margin: 80px auto 0;
}

.flo__lead {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 70px;
  border-radius: 33px 33px 0 0;
  background: #009bcf;
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.06em;
}

/*===============================================================================
one
===============================================================================*/
.one__bg {
  padding: 100px 0px 110px;
}

.one__ttl01 {
  width: 951px;
  margin: 0 auto;
}

.one__flex {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-box-align: start;
  -ms-flex-align: start;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-top: 60px;
}

.one__box {
  position: relative;
  width: 400px;
  padding: 66px 26px 50px;
  border-radius: 30px;
  background-color: #7c8588;
}

.one__box::after {
  display: block;
  position: absolute;
  right: -20px;
  bottom: -20px;
  width: 106px;
  height: 200px;
  background: url(../img/one_icon01.png) top center/contain no-repeat;
  content: "";
}

.one__head01 {
  position: absolute;
  top: -30px;
  right: 0;
  left: 0;
  width: 350px;
  margin: 0 auto;
}

.one__list {
  margin-top: 15px;
  padding-left: 20px;
}

.one__list--num02 {
  margin-top: 25px;
  padding-left: 100px;
}

.one__list--num02 .one__item {
  font-size: 30px;
  line-height: 1.6;
}

.one__list--num02 .one__item::before {
  display: block;
  width: 30px;
  height: 20px;
  margin-right: 15px;
  background: url(../img/one_check01.png) top center/contain no-repeat;
  content: "";
}

.one__item {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.7;
}

.one__item::before {
  display: block;
  width: 20px;
  height: 15px;
  margin-right: 10px;
  background: url(../img/one_check01.png) top center/contain no-repeat;
  content: "";
}

.one__box02 {
  -webkit-transform: translateY(-29px);
  -ms-transform: translateY(-29px);
  position: relative;
  width: 581px;
  padding: 0 11px 30px 12px;
  transform: translateY(-29px);
  border-radius: 30px;
  background-color: #00b0ec;
}

.one__box02::after {
  display: block;
  position: absolute;
  right: 20px;
  bottom: -20px;
  width: 106px;
  height: 204px;
  background: url(../img/one_icon02.png) top center/contain no-repeat;
  content: "";
}

.one__head02 {
  -webkit-transform: translateY(-40px);
  -ms-transform: translateY(-40px);
  margin-bottom: -45px;
  transform: translateY(-40px);
}

.one__img02 {
  width: 493px;
  margin: 0 auto;
}

.one__txt01 {
  margin-top: 45px;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: center;
}

.one__txt01 .bold {
  font-size: 28px;
}

/*===============================================================================
man
===============================================================================*/
.man__bg {
  padding: 100px 0px 120px;
  background-color: #f2f2f2;
}

.man__ttl01 {
  width: 613px;
  margin: 0 auto;
}

.man__wrap {
  position: relative;
  margin-top: 45px;
  padding: 54px 20px 60px 60px;
  border-radius: 34px;
  background-color: #fff;
}

.man__lead {
  color: #313131;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 2.2;
}

.man__lead .big {
  font-size: 34px;
  line-height: 1.2;
}

.man__img01 {
  position: absolute;
  top: 0;
  right: -132px;
  width: 546px;
}

.man__txt02 {
  margin-top: 15px;
  color: #313131;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 2.2;
}

.man__ttl02 {
  width: 838px;
  margin: 105px auto 0;
}

.man__check {
  margin: 50px auto 0;
}

.man__box02 {
  margin-top: 40px;
  padding: 35px 80px;
  border-radius: 30px;
  background-color: #009bcf;
}

.man__ttl03 {
  color: #fff;
  font-size: 40px;
  font-weight: bold;
  letter-spacing: 0.04em;
  text-align: center;
}

.man__list {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -ms-flex-wrap: wrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.man__item {
  width: 243px;
  margin-top: 24px;
}

.man__item__txt {
  margin-top: 4px;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}

/*===============================================================================
voi
===============================================================================*/
.voi__bg {
  padding: 90px 0px 170px;
  background-color: #eef9fc;
}

.voi__ttl01 {
  width: 380px;
  margin: 0 auto;
}

.voi__box {
  width: 800px;
  margin: 40px auto 0;
}

.voi__lead {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 70px;
  border-radius: 33px 33px 0 0;
  background: #009bcf;
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.06em;
}

.voi__slider {
  position: relative;
  margin: 60px 0 0;
}

.voi .swiper-container-tab {
  overflow: visible;
}

.voi .swiper-container-tab .swiper-wrapper {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-transform: translate(0) !important;
  -ms-transform: translate(0) !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  transform: translate(0) !important;
}

.voi .swiper-container-tab .swiper-slide {
  width: 126px !important;
  height: inherit;
  margin: 0 5px;
}

.voi .swiper-container-tab .swiper-slide .on {
  display: none;
}

.voi .swiper-container-tab .swiper-slide .off {
  display: block;
}

.voi .swiper-container-tab .swiper-slide.swiper-slide-thumb-active .on {
  display: block;
}

.voi .swiper-container-tab .swiper-slide.swiper-slide-thumb-active .off {
  display: none;
}

.voi .swiper-container01 {
  margin-top: 30px;
}

.voi .swiper-button-prev:after,
.voi .swiper-container-rtl .swiper-button-next:after {
  display: none;
  content: "prev";
}

.voi .swiper-button-next:after,
.voi .swiper-container-rtl .swiper-button-prev:after {
  display: none;
  content: "next";
}

.voi .swiper-button-prev,
.voi .swiper-button-next {
  z-index: 99;
  top: inherit;
  bottom: -73px;
  width: 50px;
  height: 50px;
}

.voi .swiper-button-prev {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  left: 320px;
  transform: rotate(180deg);
  background: url(../img/voi_arrow01.png) top center/contain no-repeat;
}

.voi .swiper-button-next {
  right: 320px;
  background: url(../img/voi_arrow01.png) top center/contain no-repeat;
}

.voi__pagination {
  position: absolute;
  right: 0;
  left: 0;
  margin: 40px auto 0;
}

.voi__pagination .swiper-pagination {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.voi__pagination .swiper-pagination-bullet {
  display: block;
  width: 14px;
  height: 14px;
  margin: 0 13px;
  background-color: #c9c9c9;
  opacity: 1;
}

.voi__pagination .swiper-pagination-bullet-active {
  background-color: #009bcf;
}

.voi .swiper-container01 {
  -webkit-box-shadow: 5.2px 4.7px 0 0 rgba(0, 155, 207, 0.1);
  box-shadow: 5.2px 4.7px 0 0 rgba(0, 155, 207, 0.1);
}

.voi .swiper-container01 .swiper-slide {
  padding: 40px 40px 55px;
  background: url(../img/voi_bg01.png) top center/100% repeat;
}

.voi__flex {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}

.voi__lead02 {
  -webkit-box-align: end;
  -ms-flex-align: end;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-left: 40px;
  color: #009bcf;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.06em;
}

.voi__lead02 .big {
  font-size: 40px;
}

.voi__lead02::before {
  -webkit-transform: translateY(-10px);
  -ms-transform: translateY(-10px);
  display: block;
  width: 71px;
  height: 55px;
  margin-right: 12px;
  transform: translateY(-10px);
  background: url(../img/voi_icon01.png) top center/contain no-repeat;
  content: "";
}

.voi__img01 {
  width: 420px;
}

.voi__q {
  margin-top: 35px;
  padding: 0 20px 10px 20px;
  border-bottom: 5px dotted #e1d9c5;
  color: #009bcf;
  font-size: 26px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.25;
}

.voi__q:nth-child(2) {
  margin-top: 55px;
}

.voi__a {
  margin-top: 26px;
  padding: 0px 20px;
  color: #333;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.67;
}

/*===============================================================================
how
===============================================================================*/
.how__bg {
  z-index: 2;
  position: relative;
  padding-bottom: 80px;
  background-color: #f2f2f2;
}

.how__ttl01 {
  -webkit-transform: translate(-499px, -32px);
  -ms-transform: translate(-499px, -32px);
  width: 1999px;
  transform: translate(-499px, -32px);
}

.how__list {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -ms-flex-wrap: wrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: -70px;
}

.how__item {
  width: 310px;
  margin-top: 50px;
}

.how__info {
  margin: 26px 10px 0;
}

.how__ttl02 {
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1;
  text-align: left;
}

.how__txt01 {
  margin-top: 10px;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.63;
}

.how__box {
  margin-top: 15px;
  padding: 25px 22px;
  border-radius: 10px;
  background-color: #fff;
}

.how__txt02 {
  color: #009bcf;
  font-size: 16px;
  font-weight: bold;
}

.how__list02 {
  margin-top: 5px;
}

.how__item02 {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.63;
}

.how__item02 .circle {
  color: #009bcf;
}

.how__note {
  font-size: 16px;
}

/*===============================================================================
faq
===============================================================================*/
.faq__bg {
  padding: 80px 0 110px;
}

.faq__ttl01 {
  width: 544px;
  margin-left: 228px;
}

.faq__list {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -ms-flex-wrap: wrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 30px;
}

.faq__item {
  width: 490px;
  margin-top: 40px;
  border-radius: 10px;
  background-color: #f2f2f2;
}

.faq__dt {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  min-height: 120px;
  padding: 20px 34px;
  border-radius: 10px 10px 0 0;
  background-color: #009bcf;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.06em;
  line-height: 1.82;
}

.faq__dd {
  padding: 25px 30px 35px;
  border-radius: 0 0 10px 10px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.89;
}

.faq__link {
  display: table;
  margin-top: 6px;
  border-bottom: 1px solid #000;
  color: #000;
  line-height: 1;
}

/*===============================================================================
sample
===============================================================================*/
/*===============================================================================
sample
===============================================================================*/
/*===============================================================================
sample
===============================================================================*/
/*===============================================================================
sample
===============================================================================*/
/*===============================================================================
cta
===============================================================================*/
.cta__bg {
  z-index: 2;
  position: relative;
  margin-top: -30px;
  padding: 60px 0 65px;
  background: url(../img/cta_bg01.png) top center/2256px repeat-x;
}

.cta__inner {
  position: relative;
}

.cta__inner::before {
  display: block;
  position: absolute;
  top: -40px;
  right: -20px;
  width: 94px;
  height: 295px;
  background: url(../img/cta_icon02.png) top center/contain no-repeat;
  content: "";
}

.cta__inner::after {
  display: block;
  position: absolute;
  top: -40px;
  left: -20px;
  width: 97px;
  height: 292px;
  background: url(../img/cta_icon01.png) top center/contain no-repeat;
  content: "";
}

.cta__ttl01 {
  color: #fff;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
  text-align: center;
}

.cta__ttl01 .big {
  font-size: 36px;
  font-weight: bold;
}

.cta__ttl01--small {
  font-size: 25px;
}

.cta__ttl01--small .big {
  font-size: 30px;
  font-weight: bold;
}

.cta__btn01 {
  display: block;
  width: 800px;
  margin: 35px auto 0;
}

/*===============================================================================
modal
===============================================================================*/
.modal {
  display: none;
}

.modal__bg {
  z-index: 100;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
}

.modal__block {
  z-index: 101;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 1000px;
  height: 548px;
  margin: auto;
  background-color: #fff;
}

.modal__block iframe {
  width: 100%;
}

.modal__close {
  display: block;
  position: absolute;
  top: -64px;
  right: 0;
  width: 64px;
  height: 64px;
  background-color: #000;
  cursor: pointer;
}

.modal__close .border01 {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  position: absolute;
  top: 30px;
  left: 15px;
  width: 34px;
  height: 3px;
  transform: rotate(45deg);
  background-color: #fff;
}

.modal__close .border02 {
  -webkit-transform: rotate(315deg);
  -ms-transform: rotate(315deg);
  position: absolute;
  top: 30px;
  left: 15px;
  width: 34px;
  height: 3px;
  transform: rotate(315deg);
  background-color: #fff;
}

.cv {
  display: none;
  z-index: 100;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  width: 100%;
  margin: 0 auto;
  background: #d8d8d8;
}

/*===============================================================================
footer
===============================================================================*/
.footer-bg {
  padding: 40px;
}

.footer-txt {
  display: block;
  color: #009bcf;
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
}










/*▼よくある質問、画像ボタン化*/
.faq .faq__btn01 {
    display: inline-block;
    width: 66%;
    margin: 20px 0 0 68px;
}	
.faq .faq__btn01:hover {
    opacity:0.8;
}	
/*▲よくある質問、画像ボタン化*/
/*▼カリキュラムの柱文字サイズ*/
.wha__txt01 .bold {
    font-size: 28px;
}
/*▲カリキュラムの柱文字サイズ*/
/*▼幼児教育無償化*/
.fv .fv__txt01 {
    padding: 34px 0 28px;
}	
.fv .fv__txt01 .box {
    border: 3px solid #00a61c;
    border-radius: 16px;
    width: 718px;
    margin: 0 auto;
	overflow:hidden;
}	
.fv .fv__txt01 .box .ttl {
    background: #00a61c;
    color: #fff;
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    padding: 6px 0;
    letter-spacing: 0.08rem;
}	
.fv .fv__txt01 .box .txt {
    background: #fff;
    padding: 10px 16px;
    font-size: 18px;
}
.fv .fv__txt01 .box .txt .anno {
    font-size: 14px;
}
.fv__bg {
    padding: 85px 0 100px;
}
/*▲幼児教育無償化*/
/*▼CTA背景とテキスト色変更（ABテスト）*/
.cta__ttl01 {
    color: #009bcf;
}
/*▲CTA背景とテキスト色変更（ABテスト）*/

/*▼入園までの流れCVボタン追加（ABテスト）*/
.how .how__btn01 {
    display: inline-block;
    width: 88%;
    margin: 20px 0 0 20px;
}			
.how .how__btn01:hover {
    opacity:0.8;
}
/*▲入園までの流れCVボタン追加（ABテスト）*/

/*▼英会話教育へ変更後の位置修正*/
.wha__txt01 {
    line-height: 1.6;
    text-align: left;
    padding: 0 20px;
}
.kar__txt01--num01 {
    right: 66px;
    width: 380px;
}
/*▲英会話教育へ変更後の位置修正*/

/*▼年齢別会話例　改修*/
.fea__box__ttl {
    font-size: 28px;
}			
.fea__box__ttl .big {
    font-size: 34px;
}
.fea__box__txt {
    font-size: 20px;
}
.fea__box02 {
    background: #e2f8ff;
    color: #333;
	width: 600px;
}
.fea__box02.fea__box02--num02 {
	background:#fff3d9;
	margin: 10px 0 0 130px;
    padding: 17px 60px 17px 60px;
}
.fea__box02__en {
    font-size: 20px;
}
.fea__box02__txt {
    font-size: 18px;
}
/*▲年齢別会話例　改修*/
