@charset "UTF-8";
/* --------------------------------------------------------------
   共通
-------------------------------------------------------------- */
body {
  min-width: 11.6rem;
  color: #000;
  font-size: 0.18rem;
}

a {
  color: #000;
}

.wrapper {
  overflow: hidden;
}

.container {
  width: 12.3rem;
  margin: 0 auto;
}

.u-pc-only {
  display: block;
}

.cmn_header {
  padding: 0.26rem 0 0.3rem;
}
.cmn_header .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.cmn_header .logo img {
  width: 0.91rem;
}
.cmn_header .btn {
  pointer-events: none;
}
.cmn_header .btn img {
  width: 3.715rem;
}

.cmn_footer {
  padding: 0.35rem 0 1.8rem;
  background-color: #C1C1C1;
}
.cmn_footer small {
  text-align: center;
  display: block;
  font-size: 0.14rem;
  letter-spacing: 0.05em;
  color: #ffffff;
}

.fixed_btn {
  width: 100%;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(1.72rem);
          transform: translateY(1.72rem);
  -webkit-transition: 0.4s;
  transition: 0.4s;
  position: fixed;
  z-index: 15;
  bottom: 0;
  left: 0;
  background-color: #F9EEDF;
}
.fixed_btn .container {
  width: 100%;
}
.fixed_btn .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.fixed_btn .anchor_lists {
  width: 9rem;
  padding: 0.14rem 0.34rem 0.14rem 0.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.fixed_btn .anchor_lists li a {
  width: 2.7rem;
  height: 1.14rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-flow: row-reverse;
          flex-flow: row-reverse;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 0.1rem;
  background-color: #ffffff;
  border: 0.02rem solid #F6A555;
}
.fixed_btn .anchor_lists li .txt {
  font-size: 0.2rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.fixed_btn .anchor_lists li:nth-of-type(1) .img {
  margin-left: 0.07rem;
}
.fixed_btn .anchor_lists li:nth-of-type(1) .img img {
  width: 0.7rem;
}
.fixed_btn .anchor_lists li:nth-of-type(2) .img {
  margin-left: 0.35rem;
}
.fixed_btn .anchor_lists li:nth-of-type(2) .img img {
  width: 0.6rem;
}
.fixed_btn .anchor_lists li:nth-of-type(3) .img {
  margin-left: 0.3rem;
}
.fixed_btn .anchor_lists li:nth-of-type(3) .img img {
  width: 0.6rem;
}
.fixed_btn .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.fixed_btn .btn a {
  width: 3rem;
  height: 100%;
  padding-top: 0.6rem;
  text-align: center;
  font-size: 0.22rem;
  display: block;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #ffffff;
  background-color: #009D91;
}
.fixed_btn .btn a.c-btn-fixedLearning {
  display: -ms-grid;
  display: grid;
  place-content: center;
  border: 1px solid #009D91;
  background: #fff;
  color: #009D91;
  line-height: 1.5;
  padding: unset;
}

.fixed_btn.show {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  position: fixed;
  bottom: 0;
}

.mv {
  margin-top: -1.5rem;
  padding: 1.85rem 0 0.8rem;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../images/mv/mv.jpg);
}
.mv .tit,
.mv .txt,
.mv .btn {
  text-align: right;
}
.mv .tit {
  margin-right: 0.45rem;
}
.mv .tit img {
  width: 5.945rem;
}
.mv .txt {
  margin: 0.24rem 1.5rem 0 0;
}
.mv .txt img {
  width: 4.36rem;
}
.mv .btn {
  margin-right: 1.2rem;
}
.mv .btn img {
  width: 4.65rem;
}
.mv .medal01 {
  display: block;
  position: absolute;
  right: 0.34rem;
  top: 3.1rem;
  width: 2.6rem;
}
.mv .medal01:hover {
  opacity: 1;
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
}

.slider_sec {
  padding: 0.55rem 0 0.5rem;
}
.slider_sec .swiper-wrapper {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}
.slider_sec .swiper-wrapper .swiper-slide {
  height: 0.64rem !important;
  width: auto !important;
}
.slider_sec .swiper-wrapper .swiper-slide img {
  height: 0.64rem;
}

.sec01 {
  padding: 1.25rem 0 1.5rem;
  position: relative;
}
.sec01::before {
  content: "";
  width: 2.86rem;
  height: 3.91rem;
  position: absolute;
  z-index: -1;
  top: 0.15rem;
  right: 0;
  background-size: 100%;
  background-repeat: no-repeat;
  background-image: url(../images/sec01/pic01.jpg);
}
.sec01 .tit {
  margin-bottom: 0.7rem;
  text-align: center;
  font-size: 0.34rem;
  letter-spacing: 0.1em;
  line-height: 1.94;
  font-weight: 400;
}
.sec01 .tit .strong {
  font-size: 0.46rem;
  color: #1A7884;
}
.sec01 .swiper02 {
  position: relative;
}
.sec01 .swiper02 .swiper-pagination-bullet {
  width: 0.14rem;
  height: 0.14rem;
  border: 1px solid #707070;
  background-color: #ffffff;
  opacity: 1;
}
.sec01 .swiper02 .swiper-pagination-bullets {
  bottom: -0.8rem !important;
}
.sec01 .swiper02 .swiper-pagination-bullet-active {
  background: #009D91;
}
.sec01 .swiper02 .swiper-pagination-bullet {
  margin: 0 0.1rem !important;
}

.sec02 {
  padding: 1.12rem 0 1.65rem;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../images/sec02/bg.jpg);
}
.sec02 .tit {
  margin-bottom: 0.35rem;
  text-align: center;
  line-height: 2.14;
  letter-spacing: 0.1em;
  font-weight: 400;
}
.sec02 .tit .fs01 {
  font-size: 0.24rem;
  color: #009D91;
}
.sec02 .tit .fs02 {
  font-size: 0.4rem;
}
.sec02 .lists {
  margin-left: 0.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.sec02 .lists li {
  text-align: center;
}
.sec02 .lists li:nth-of-type(2) {
  margin: 0 0.7rem 0 0.9rem;
}
.sec02 .lists .img {
  margin-bottom: 0.2rem;
}
.sec02 .lists .img img {
  width: 2.5rem;
}
.sec02 .lists .txt {
  font-size: 0.24rem;
  line-height: 1.66;
  letter-spacing: 0.1em;
}
.sec02 .lists .txt .strong {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #F8FF95));
  background: linear-gradient(transparent 60%, #F8FF95 60%);
}

.sec03 {
  padding: 1.4rem 0 3rem;
}
.sec03 .tit {
  margin-bottom: 1.05rem;
  text-align: center;
  font-size: 0.4rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
  font-weight: 400;
  color: #009D91;
}
.sec03 .wrap {
  position: relative;
}
.sec03 .lists {
  margin-left: 1.2rem;
}
.sec03 .lists li {
  padding: 0.23rem 0.45rem 0.23rem;
  display: table;
  font-size: 0.24rem;
  letter-spacing: 0.05em;
  -webkit-box-shadow: 0 0.03rem 0.06rem rgba(0, 0, 0, 0.16);
          box-shadow: 0 0.03rem 0.06rem rgba(0, 0, 0, 0.16);
  position: relative;
  border-radius: 0.1rem;
  background-color: #ffffff;
}
.sec03 .lists li .strong {
  color: #1A7884;
}
.sec03 .lists li::before {
  content: "";
  width: 0.15rem;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 0.1rem 0 0 0.1rem;
  background-color: #1A7884;
}
.sec03 .lists li:not(:last-of-type) {
  margin-bottom: 0.35rem;
}
.sec03 .pic {
  position: absolute;
  z-index: -1;
  top: -0.3rem;
  right: 0;
}
.sec03 .pic img {
  width: 6.91rem;
}

.sec04 .tit {
  padding: 1rem 0 0;
  text-align: center;
  line-height: 2;
  font-weight: 400;
  background-color: #F9EEDF;
}
.sec04 .tit .fs01 {
  font-size: 0.24rem;
  letter-spacing: 0.05em;
}
.sec04 .tit .fs02 {
  font-size: 0.5rem;
  letter-spacing: 0.1em;
}
.sec04 .tit .strong {
  color: #1A7884;
}
.sec04 .tit .num {
  font-weight: 700;
}
.sec04 .p_tit img {
  width: 100%;
}
.sec04 .point01 {
  padding: 0.6rem 0 0.5rem;
  background-color: #F9EEDF;
}
.sec04 .point01 .f_txt {
  margin: 0.5rem 0 0.55rem;
  text-align: center;
  font-size: 0.2rem;
  letter-spacing: 0.1em;
}
.sec04 .point01 .lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.sec04 .point01 .lists01 {
  width: 9.9rem;
  margin: 0 auto;
}
.sec04 .point01 .lists01 li {
  margin-bottom: 0.25rem;
}
.sec04 .point01 .lists01 li img {
  width: 3.01rem;
}
.sec04 .point01 .lists02 {
  margin-top: 1.45rem;
  padding: 0 0.5rem;
}
.sec04 .point01 .lists02 .item {
  text-align: center;
  margin-bottom: 0.65rem;
}
.sec04 .point01 .lists02 .item img {
  margin-bottom: 0.35rem;
  width: 3.5rem;
}
.sec04 .point01 .lists02 .item dl {
  margin-bottom: 0.1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.sec04 .point01 .lists02 .item dl dt {
  margin-right: 0.2rem;
  font-size: 0.23rem;
}
.sec04 .point01 .lists02 .item dl dd {
  font-size: 0.18rem;
  color: #1A7884;
}
.sec04 .point01 .lists02 .item dl .num {
  margin-right: 0;
  font-size: 0.23rem;
  color: #000000;
}
.sec04 .point01 .lists02 .item .desc {
  min-height: 0.5rem;
  font-size: 0.16rem;
  letter-spacing: 0.05em;
  line-height: 1.375;
}
.sec04 .point01 .lists02 .item .child_lists {
  margin-top: 0.1rem;
}
.sec04 .point01 .lists02 .item .child_lists li {
  width: 2.7rem;
  margin: 0 auto;
  line-height: 0.4rem;
  font-size: 0.16rem;
  background-color: #ffffff;
  border: 1px solid #1A7884;
  border-radius: 0.07rem;
}
.sec04 .point01 .lists02 .item .child_lists li:not(:last-of-type) {
  margin-bottom: 0.1rem;
}
.sec04 .point02 {
  padding: 1.1rem 0 1.4rem;
}
.sec04 .point02 .f_txt {
  margin: 0.5rem 0 1.05rem;
  text-align: center;
  font-size: 0.2rem;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.sec04 .point02 .conts {
  padding: 0.7rem 0.55rem 0.45rem;
  border-radius: 0.4rem;
  background-color: #E2EFF1;
}
.sec04 .point02 .conts .conts_tit {
  width: 8rem;
  margin: -1.1rem auto 0.5rem;
  padding: 0.35rem 0 0.35rem;
  text-align: center;
  font-size: 0.26rem;
  letter-spacing: 0.1em;
  background-color: #ffffff;
  border-radius: 10rem;
  border: 0.02rem solid #1A7884;
}
.sec04 .point02 .conts .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.sec04 .point02 .conts .img01 img {
  width: 5.24rem;
}
.sec04 .point02 .conts .img02 img {
  width: 5.32rem;
}
.sec04 .point02 .conts .txt {
  width: 5.5rem;
}
.sec04 .point02 .conts .desc {
  margin-bottom: 0.45rem;
  font-size: 0.18rem;
  letter-spacing: 0.1em;
  line-height: 2;
}
.sec04 .point02 .conts:not(:last-of-type) {
  margin-bottom: 1.2rem;
}
.sec04 .point03 {
  padding: 1.3rem 0 0.85rem;
  background-color: #F9EEDF;
}
.sec04 .point03 .f_txt {
  margin: 0.5rem 0 1.05rem;
  text-align: center;
  font-size: 0.2rem;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.sec04 .point03 .conts {
  padding: 1.1rem 0.55rem 0.45rem;
  border-radius: 0.4rem;
  background-color: #E2EFF1;
}
.sec04 .point03 .conts .conts_tit {
  width: 8rem;
  margin: -1.5rem auto 0.4rem;
  padding: 0.35rem 0 0.35rem;
  text-align: center;
  font-size: 0.26rem;
  letter-spacing: 0.1em;
  background-color: #ffffff;
  border-radius: 10rem;
}
.sec04 .point03 .conts .conts_tit .strong {
  color: #1A7884;
}
.sec04 .point03 .conts .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.sec04 .point03 .conts .img01 {
  padding-top: 0.4rem;
}
.sec04 .point03 .conts .img01 img {
  width: 5.24rem;
}
.sec04 .point03 .conts .img02 img {
  width: 5.32rem;
}
.sec04 .point03 .conts .img04 {
  padding-top: 0;
}
.sec04 .point03 .conts .img04 img {
  width: 5.03rem;
}
.sec04 .point03 .conts .txt {
  width: 5.5rem;
}
.sec04 .point03 .conts .desc {
  margin-bottom: 0.45rem;
  font-size: 0.18rem;
  letter-spacing: 0.1em;
  line-height: 2;
}
.sec04 .point03 .conts:not(:last-of-type) {
  margin-bottom: 1.2rem;
}
.sec04 .point03 .conts02 {
  padding: 1.1rem 0.7rem 0.3rem;
}

.sec05 {
  padding: 1.25rem 0 1.65rem;
}
.sec05 .tit {
  margin-bottom: 0.35rem;
  text-align: center;
  font-size: 0.34rem;
  letter-spacing: 0.1em;
  line-height: 1.76;
}
.sec05 .tit .strong {
  color: #F6A555;
}
.sec05 .lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.sec05 .lists li {
  text-align: center;
}
.sec05 .lists li:not(:last-of-type) {
  margin-right: 0.2rem;
}
.sec05 .lists .img {
  padding-bottom: 0.05rem;
}
.sec05 .lists .img img {
  width: 2.47rem;
}
.sec05 .lists .txt {
  font-size: 0.2rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
}

.sec06 {
  padding: 0.8rem 0 1.15rem;
  text-align: center;
  background-color: #FFF6E9;
}
.sec06 .tit {
  margin-bottom: 0.35rem;
  font-size: 0.34rem;
  line-height: 1.76;
  letter-spacing: 0.1em;
  color: #1A7884;
  font-weight: 400;
}
.sec06 .img img {
  width: 6.19rem;
}

.cta {
  padding: 1.77rem 0 1.2rem;
  text-align: center;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../images/cta/bg.jpg);
}
.cta .tit {
  margin-bottom: 0.55rem;
}
.cta .tit img {
  width: 9.965rem;
}
.cta .btn img {
  width: 8rem;
}

.cta02 {
  padding: 1.1rem 0 0.6rem;
  background-image: url(../images/cta/bg02.jpg);
}
.cta02 .txt {
  margin: 0.45rem 0 0.05rem;
  display: block;
  font-size: 0.24rem;
  letter-spacing: 0.15em;
}
.cta02 .tel_btn {
  pointer-events: none;
}
.cta02 .tel_btn img {
  width: 8rem;
}

.sec07 {
  padding: 1rem 0 1.7rem;
}
.sec07 .tit {
  text-align: center;
  font-size: 0.4rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
  color: #1A7884;
}
.sec07 .f_txt {
  margin: 0.55rem 0 0.5rem;
  text-align: center;
  font-size: 0.2rem;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.sec07 .lists li .wrap {
  margin-top: -0.06rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  border-radius: 0.2rem;
  position: relative;
  border: 1px solid #CCC;
}
.sec07 .lists li:nth-of-type(odd) .wrap {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-flow: row-reverse;
          flex-flow: row-reverse;
}
.sec07 .lists li:nth-of-type(odd) .order {
  padding-left: 0.3rem;
  text-align: left;
}
.sec07 .lists li:nth-of-type(odd) .txt {
  padding: 0 0 0 0.5rem;
}
.sec07 .lists li:nth-of-type(odd) .list_catch {
  left: 0;
}
.sec07 .lists li:nth-of-type(even) .order {
  padding-right: 0.15rem;
  text-align: right;
}
.sec07 .lists li:nth-of-type(even) .pic img {
  border-radius: 0.2rem 0 0 0.2rem;
}
.sec07 .lists li:nth-of-type(even) .txt {
  padding: 0 0.3rem 0 0;
}
.sec07 .lists li:nth-of-type(even) .list_catch {
  right: 0;
}
.sec07 .lists li:not(:last-of-type) {
  margin-bottom: 0.33rem;
}
.sec07 .lists li .order {
  font-size: 0.8rem;
  font-weight: 300;
  letter-spacing: 0.1em;
  color: #1A7884;
}
.sec07 .lists li .pic {
  width: 50%;
}
.sec07 .lists li .pic02 {
  padding: 0.36rem 0 0.2rem;
}
.sec07 .lists li .txt {
  width: 50%;
  background-color: #ffffff;
}
.sec07 .lists li .list_tit {
  font-size: 0.34rem;
  letter-spacing: 0.1em;
  color: #1A7884;
}
.sec07 .lists li .list_tit01 {
  margin-bottom: 1.3rem;
}
.sec07 .lists li .list_tit02 {
  margin-bottom: 1.3rem;
}
.sec07 .lists li .list_tit03 {
  margin-bottom: 1.2rem;
}
.sec07 .lists li .list_tit04 {
  padding-left: 0.85rem;
  margin-bottom: 1.4rem;
}
.sec07 .lists li .list_tit.right {
  text-align: right;
}
.sec07 .lists li .list_catch {
  position: absolute;
}
.sec07 .lists li .list_catch img {
  width: auto;
  height: 0.5rem;
}
.sec07 .lists li .catch01 {
  top: 1.4rem;
}
.sec07 .lists li .catch02 {
  top: 1.4rem;
}
.sec07 .lists li .catch03 {
  top: 1.4rem;
}
.sec07 .lists li .catch04 {
  top: 1.4rem;
}
.sec07 .lists li .catch04 img {
  height: 0.97rem;
}
.sec07 .lists li .desc {
  font-size: 0.2rem;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
.sec07 .lists li .desc02 {
  padding-left: 0.5rem;
}
.sec07 .lists li .desc04 {
  padding-left: 0.95rem;
}

.sec08 {
  padding: 0 0 1.35rem;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: relative;
  z-index: 1;
  background-image: url(../images/sec08/bg.jpg);
}
.sec08::before, .sec08::after {
  content: "";
  position: absolute;
  z-index: -1;
  background-repeat: no-repeat;
  background-size: 100%;
}
.sec08::before {
  width: 100%;
  height: 2.97rem;
  top: 0;
  left: 0;
  background-image: url(../images/sec08/arrow.png);
}
.sec08::after {
  width: 8.13rem;
  height: 2.18rem;
  top: 2rem;
  right: 0;
  background-image: url(../images/sec08/img02.png);
}
.sec08 .tit {
  margin-bottom: 0.65rem;
  text-align: center;
  font-weight: 400;
  font-size: 0.36rem;
  letter-spacing: 0.1em;
  line-height: 1.94;
}
.sec08 .tit .strong {
  color: #009D91;
}
.sec08 .img img {
  width: 2.55rem;
}
.sec08 .txt {
  margin: 0.15rem 0 0.4rem;
}
.sec08 .txt img {
  width: 9.29rem;
}
.sec08 .txt02 {
  margin-bottom: 0.45rem;
  text-align: center;
  font-size: 0.24rem;
  letter-spacing: 0.1em;
  line-height: 1.66;
}
.sec08 .btn {
  text-align: center;
}
.sec08 .btn img {
  width: 5.61rem;
}

.sec09 {
  padding: 0.6rem 0 1.2rem;
  text-align: center;
}
.sec09 .tit {
  font-size: 0.4rem;
  letter-spacing: 0.05em;
}
.sec09 .txt {
  margin: 0.6rem 0 0.65rem;
  font-size: 0.2rem;
  line-height: 1.9;
}
.sec09 .img img {
  width: 10rem;
}

.faq {
  padding: 1.2rem 0 0;
}
.faq .tit {
  margin-bottom: 0.85rem;
  text-align: center;
  font-size: 0.4rem;
  letter-spacing: 0.05em;
  font-weight: 400;
}
.faq .ac {
  width: 100%;
  padding: 0 0.15rem;
  margin: 0 auto;
}
.faq .ac_parent {
  padding: 0.31rem 0 0.25rem 0.4rem;
  position: relative;
  font-size: 0.22rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.58;
  cursor: pointer;
  color: #ffffff;
  border-radius: 0.2rem 0.2rem 0 0;
  background-color: #CEB88D;
}
.faq .ac_parent::before, .faq .ac_parent::after {
  content: "";
  position: absolute;
  z-index: 5;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #ffffff;
}
.faq .ac_parent::before {
  top: 50%;
  right: 0.4rem;
  width: 0.22rem;
  height: 0.03rem;
}
.faq .ac_parent::after {
  right: 0.49rem;
  -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;
  transition: opacity 0.4s, -webkit-transform 0.4s;
  transition: transform 0.4s, opacity 0.4s;
  transition: transform 0.4s, opacity 0.4s, -webkit-transform 0.4s;
  width: 0.03rem;
  height: 0.22rem;
}
.faq .ac_parent:not(:first-of-type) {
  margin-top: 0.3rem;
}
.faq .ac_child {
  display: none;
  padding: 0.25rem 0.35rem 0.3rem;
  letter-spacing: 0.05em;
  font-size: 0.18rem;
  line-height: 1.77;
  border-right: 1px solid #C8C8C8;
  border-bottom: 1px solid #C8C8C8;
  border-left: 1px solid #C8C8C8;
  border-radius: 0 0 0.2rem 0.2rem;
}
.faq .ac_parent.open::after {
  top: 50%;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  opacity: 0;
}

.company {
  padding: 0.85rem 0 0.3rem;
}
.company .tit {
  text-align: center;
  font-size: 0.4rem;
  letter-spacing: 0.1em;
  font-weight: 400;
}
.company .bg {
  width: 8.65rem;
  margin: 0 auto;
  padding: 0.4rem 0 0.75rem;
}
.company .logo {
  text-align: center;
  margin-bottom: 0.5rem;
}
.company .logo img {
  width: 1.2rem;
}
.company .lists {
  padding-left: 1.3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.company .lists dt,
.company .lists dd {
  font-size: 0.18rem;
  letter-spacing: 0.1em;
  line-height: 2;
}
.company .lists dt {
  width: 1.6rem;
}
.company .lists dd {
  width: calc(100% - 1.6rem);
}

.campaign01 {
  background: url(../images/campaign01/bg01.png) no-repeat center top;
  background-size: cover;
  padding: 1.13rem 0 0.9rem;
}
.campaign01 .head_catch {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  color: #FF795D;
  font-weight: 900;
  font-size: 0.24rem;
}
.campaign01 .head_catch > li {
  background: #fff;
  border: solid 2px #FF795D;
  border-radius: 100px;
  width: 2.55rem;
  margin: 0 0.06rem;
  padding: 0.05rem 0 0.1rem;
}
.campaign01 .head_catch b {
  font-size: calc(32 /24 * 100%);
}
.campaign01 .tit01 {
  margin-top: 0.5rem;
  text-align: center;
  color: #FF795D;
  font-size: 0.5rem;
  font-weight: 700;
}
.campaign01 .contact_btn {
  width: min(26vw, 500px);
  margin: 0.5rem auto;
}
.campaign01 .contact_btn a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #009D91;
  border-radius: 40px;
  height: 0.6rem;
  color: white;
}
.campaign01 .period {
  background: #FFCEC4;
  border-radius: 0.1rem;
  width: 6.88rem;
  margin: 0.5rem auto 0;
  padding: 0.16rem 0.3rem;
}
.campaign01 .period .tbl01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.25rem;
  font-weight: 700;
}
.campaign01 .period .tbl01 th, .campaign01 .period .tbl01 td {
  padding: 0.5em 0;
}
.campaign01 .period .tbl01 th {
  white-space: nowrap;
}
.campaign01 .period .notes {
  margin-top: 0.1rem;
  font-size: 0.18rem;
  line-height: calc(28 / 18);
  letter-spacing: 0.1em;
}
.campaign01 .txt01 {
  text-align: center;
  margin: 0.5rem 0 0;
  font-size: 0.24rem;
  line-height: calc(48 / 24);
}
.campaign01 .img01 {
  display: block;
  width: 10.2rem;
  margin: 0.6rem auto 0;
}
.campaign01 .target {
  background: #fff;
  border-radius: 0.3rem;
  -webkit-box-shadow: 0.03rem 0 0.06rem rgba(0, 0, 0, 0.16);
          box-shadow: 0.03rem 0 0.06rem rgba(0, 0, 0, 0.16);
  width: 9rem;
  margin: 0.75rem auto 0;
  padding: 0.6rem 0.6rem 0.65rem;
}
.campaign01 .target .tit02 {
  text-align: center;
  color: #FF795D;
  font-size: 0.28rem;
  font-weight: 700;
}
.campaign01 .target .list01 {
  margin: 0.5rem 0 0;
  line-height: 1.6;
}
.campaign01 .target .list01 > li {
  position: relative;
  padding: 0 0 0 2em;
  font-size: 0.26rem;
  font-weight: 500;
}
.campaign01 .target .list01 > li::before {
  content: "";
  display: block;
  background: url(../images/campaign01/list01_ico01.png) no-repeat center center;
  background-size: 100% auto;
  width: 0.22rem;
  height: 1em;
  position: absolute;
  left: 0;
  top: 0.4em;
}
.campaign01 .target .list01 > li:nth-of-type(n+2) {
  margin-top: 1em;
}

/* コンタクトページ ------------------------------------- */
.contact_page .cmn_footer,
.thanks_page .cmn_footer {
  padding: 0.35rem 0 0.35rem;
}

.contact_f_sec {
  padding: 1.7rem 0 1.3rem;
  text-align: center;
}
.contact_f_sec .logo {
  margin-bottom: 1.05rem;
}
.contact_f_sec .logo img {
  width: 1.2rem;
}
.contact_f_sec .txt {
  font-size: 0.24rem;
  letter-spacing: 0.1em;
  line-height: 1.66;
}

.contact_sec {
  width: 13.6rem;
  padding: 1.03rem 2.1rem 1.9rem;
  margin: 0 auto 1.55rem;
  background-color: #F9EEDF;
}
.contact_sec .tit {
  margin-bottom: 0.7rem;
  text-align: center;
  font-size: 0.4rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #030303;
}
.contact_sec .lists input,
.contact_sec .lists select {
  width: 100%;
  height: 0.8rem;
}
.contact_sec .lists textarea {
  padding-top: 0.1rem;
  width: 100%;
  min-height: 1.8rem;
}
.contact_sec .lists input,
.contact_sec .lists select,
.contact_sec .lists textarea {
  padding-left: 0.25rem;
  font-size: 0.22rem;
  border: none;
}
.contact_sec .lists input::-webkit-input-placeholder, .contact_sec .lists select::-webkit-input-placeholder, .contact_sec .lists textarea::-webkit-input-placeholder {
  font-size: 0.24rem;
  color: #ACACAC;
}
.contact_sec .lists input::-moz-placeholder, .contact_sec .lists select::-moz-placeholder, .contact_sec .lists textarea::-moz-placeholder {
  font-size: 0.24rem;
  color: #ACACAC;
}
.contact_sec .lists input:-ms-input-placeholder, .contact_sec .lists select:-ms-input-placeholder, .contact_sec .lists textarea:-ms-input-placeholder {
  font-size: 0.24rem;
  color: #ACACAC;
}
.contact_sec .lists input::-ms-input-placeholder, .contact_sec .lists select::-ms-input-placeholder, .contact_sec .lists textarea::-ms-input-placeholder {
  font-size: 0.24rem;
  color: #ACACAC;
}
.contact_sec .lists input::placeholder,
.contact_sec .lists select::placeholder,
.contact_sec .lists textarea::placeholder {
  font-size: 0.24rem;
  color: #ACACAC;
}
.contact_sec .lists .select_wrap {
  position: relative;
}
.contact_sec .lists .select_wrap::after {
  content: "";
  width: 0.15rem;
  height: 0.15rem;
  position: absolute;
  top: calc(50% - .075rem);
  right: 0.2rem;
  pointer-events: none;
  border-top: 0.04rem solid #58504A;
  border-right: 0.04rem solid #58504A;
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
}
.contact_sec .lists select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.contact_sec .lists dt {
  margin-bottom: 0.13rem;
  font-size: 0.27rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #000000;
}
.contact_sec .lists dt .req {
  margin-left: 0.15rem;
  font-size: 0.2rem;
  font-weight: 400;
  color: #FF0000;
}
.contact_sec .lists dd:not(:last-of-type) {
  margin-bottom: 0.55rem;
}
.contact_sec .lists dd .txt {
  height: 1.75rem;
  padding: 0.25rem 0.3rem 0.35rem;
  overflow-y: scroll;
  background-color: #ffffff;
}
.contact_sec .lists dd .txt p {
  font-size: 0.2rem;
  line-height: 1.5;
  color: #666;
}
.contact_sec .lists dd .txt p:not(:last-of-type) {
  margin-bottom: 0.45rem;
}
.contact_sec .privacy {
  margin: 0.65rem 0 0.45rem;
  text-align: center;
}
.contact_sec .privacy .check_txt {
  font-size: 0.17rem;
  color: #000000;
}
.contact_sec .privacy .check_txt .strong {
  border-bottom: 1px solid #000000;
}
.contact_sec label {
  position: relative;
}
.contact_sec input[type=checkbox] {
  opacity: 0;
  position: absolute;
  left: 0;
  top: 0;
}
.contact_sec input[type=checkbox] + span {
  display: none;
  cursor: pointer;
  display: inline-block;
  position: relative;
  padding-left: 0.25rem;
  padding-right: 0.1rem;
}
.contact_sec input[type=checkbox] + span::before {
  content: "";
  width: 0.28rem;
  height: 0.28rem;
  display: block;
  position: absolute;
  top: calc(50% - .11rem);
  left: -0.2rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 0.05rem;
  background-color: #ffffff;
}
.contact_sec input[type=checkbox]:checked + span::after {
  content: "";
  width: 0.225rem;
  height: 0.245rem;
  position: absolute;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  top: -0.06rem;
  left: -0.16rem;
  background-repeat: no-repeat;
  background-size: 100%;
  background-image: url(../images/contact/check.png);
}
.contact_sec input[type=radio] {
  opacity: 0;
  position: absolute;
  left: 0;
  top: 0;
}
.contact_sec input[type=radio] + span {
  display: none;
  cursor: pointer;
  display: inline-block;
  position: relative;
  padding-left: 0.25rem;
  padding-right: 0.1rem;
}
.contact_sec input[type=radio] + span::before {
  content: "";
  width: 0.28rem;
  height: 0.28rem;
  display: block;
  position: absolute;
  top: calc(50% - .12rem);
  left: -0.2rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 50%;
  border: 0.03rem solid #9D9D9D;
  background-color: #ffffff;
}
.contact_sec input[type=radio]:checked + span::after {
  content: "";
  width: 0.28rem;
  height: 0.28rem;
  position: absolute;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  top: calc(50% - .12rem);
  left: -0.2rem;
  -webkit-transform: scale(0.6);
          transform: scale(0.6);
  border-radius: 50%;
  background-repeat: no-repeat;
  background-size: 100%;
  background: #9D9D9D;
}
.contact_sec .form_btn {
  text-align: center;
}
.contact_sec .form_btn button {
  width: 5.45rem;
  line-height: 0.78rem;
  font-size: 0.27rem;
  font-weight: 700;
  text-align: center;
  border: none;
  border-radius: 10rem;
  color: #ffffff;
  background-color: #009D91;
  position: relative;
}
.contact_sec .form_btn button::after {
  content: "";
  width: 0.13rem;
  height: 0.21rem;
  top: calc(50% - .105rem);
  right: 0.4rem;
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100%;
  background-image: url(../images/contact/arrow.png);
}
.contact_sec .detailcheck {
  background: #fff;
  margin: 0.4rem 0 0;
  padding: 0.45rem;
  font-size: 0.24rem;
}
.contact_sec .detailcheck input[type=checkbox] + span::before {
  border: 2px solid #9D9D9D;
}
.contact_sec .detailcheck .checklist_group:nth-child(n+2) {
  margin-top: 0.5rem;
}
.contact_sec .detailcheck .checklist_group legend {
  font-size: 0.26rem;
}
.contact_sec .detailcheck .checklist_group legend + .checklist {
  margin-top: 1.4em;
}
.contact_sec .detailcheck .checklist_group legend .notes {
  font-size: 80%;
  margin-left: 1em;
}
.contact_sec .detailcheck .checklist {
  margin: 0 0 0 0.2rem;
}
.contact_sec .detailcheck .checklist > li:nth-of-type(n+2) {
  margin-top: 1em;
}

/* //コンタクトページ ----------------------------------- */
/* サンクスページ --------------------------------------- */
.thanks_sec {
  padding: 1.7rem 0 1.55rem;
  text-align: center;
}
.thanks_sec .logo img {
  width: 1.2rem;
}
.thanks_sec .img {
  margin: 0.85rem 0 0.7rem;
}
.thanks_sec .img img {
  width: 1.73rem;
}
.thanks_sec .txt01 {
  font-size: 0.24rem;
  line-height: 1.66;
  letter-spacing: 0.1em;
}
.thanks_sec .txt02 {
  width: 8.05rem;
  margin: 0.41rem auto 0.57rem;
  padding: 0.35rem 0 0.35rem;
  font-size: 0.26rem;
  line-height: 1.69;
  letter-spacing: 0.1em;
  border: 0.05rem solid #F6A555;
  background-color: #FBFBFB;
}
.thanks_sec .txt02 .strong {
  font-weight: 700;
  color: #F6A555;
}
.thanks_sec .txt03 {
  font-size: 0.23rem;
  line-height: 1.73;
}
.thanks_sec .txt03 .tel {
  width: 5.55rem;
  padding: 0.05rem 0 0.05rem;
  margin: 0.25rem auto 0.1rem;
  display: block;
  font-size: 0.25rem;
  border: 0.02rem solid #464646;
}
.thanks_sec .txt03 .tel .txt {
  margin-right: 0.3rem;
  position: relative;
}
.thanks_sec .txt03 .tel .txt::after {
  content: ":";
  position: absolute;
  top: -0.07rem;
  right: -0.3rem;
}
.thanks_sec .txt03 .tel .num {
  font-size: 0.3rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.thanks_sec .txt03 .strong {
  font-weight: 500;
}
.thanks_sec .btn {
  display: table;
  margin: 0.9rem auto 0;
}
.thanks_sec .btn a {
  width: 5.44rem;
  line-height: 0.78rem;
  display: block;
  font-size: 0.27rem;
  font-weight: 700;
  text-align: center;
  border-radius: 10rem;
  color: #ffffff;
  background-color: #009D91;
  position: relative;
}
.thanks_sec .btn a::after {
  content: "";
  width: 0.13rem;
  height: 0.21rem;
  position: absolute;
  top: calc(50% - .105rem);
  right: 0.4rem;
  background-repeat: no-repeat;
  background-size: 100%;
  background-image: url(../images/contact/arrow.png);
}

/* //サンクスページ ------------------------------------- */
/*# sourceMappingURL=style.css.map */