@charset "UTF-8";
.fadein {
  opacity: 0;
  -webkit-transform: translate(0, 50px);
      -ms-transform: translate(0, 50px);
          transform: translate(0, 50px);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
}

.fadein2nd_pc {
  -webkit-transition-delay: .3s;
       -o-transition-delay: .3s;
          transition-delay: .3s;
}

.fadein3rd_pc {
  -webkit-transition-delay: .6s;
       -o-transition-delay: .6s;
          transition-delay: .6s;
}

.fadein4th_pc {
  -webkit-transition-delay: .9s;
       -o-transition-delay: .9s;
          transition-delay: .9s;
}

.fadein5th_pc {
  -webkit-transition-delay: 1.2s;
       -o-transition-delay: 1.2s;
          transition-delay: 1.2s;
}

.fadein6th_pc {
  -webkit-transition-delay: 1.5s;
       -o-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

.fadein7th_pc {
  -webkit-transition-delay: 1.8s;
       -o-transition-delay: 1.8s;
          transition-delay: 1.8s;
}

.fadein8th_pc {
  -webkit-transition-delay: 2.1s;
       -o-transition-delay: 2.1s;
          transition-delay: 2.1s;
}

.fadein.scrollin {
  opacity: 1;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}

@media (max-width: 750px) {
  .fadein2nd_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadein3rd_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadein4th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadein5th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadein6th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadein7th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadein8th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
}

.fadeInDown {
  opacity: 0;
  -webkit-transform: translate(0, -50px);
      -ms-transform: translate(0, -50px);
          transform: translate(0, -50px);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
}

.fadeInDown2nd_pc {
  -webkit-transition-delay: .3s;
       -o-transition-delay: .3s;
          transition-delay: .3s;
}

.fadeInDown3rd_pc {
  -webkit-transition-delay: .6s;
       -o-transition-delay: .6s;
          transition-delay: .6s;
}

.fadeInDown4th_pc {
  -webkit-transition-delay: .9s;
       -o-transition-delay: .9s;
          transition-delay: .9s;
}

.fadeInDown5th_pc {
  -webkit-transition-delay: 1.2s;
       -o-transition-delay: 1.2s;
          transition-delay: 1.2s;
}

.fadeInDown6th_pc {
  -webkit-transition-delay: 1.5s;
       -o-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

.fadeInDown7th_pc {
  -webkit-transition-delay: 1.8s;
       -o-transition-delay: 1.8s;
          transition-delay: 1.8s;
}

.fadeInDown8th_pc {
  -webkit-transition-delay: 2.1s;
       -o-transition-delay: 2.1s;
          transition-delay: 2.1s;
}

.fadeInDown.scrollin {
  opacity: 1;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}

@media (max-width: 750px) {
  .fadeInDown2nd_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadeInDown3rd_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadeInDown4th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadeInDown5th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadeInDown6th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadeInDown7th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .fadeInDown8th_pc {
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
}

.rating_star {
  position: relative;
  z-index: 0;
  display: inline-block;
  white-space: nowrap;
  color: #E5E5E5;
}

.rating_star:before, .rating_star:after {
  content: '★★★★★';
}

.rating_star:after {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  overflow: hidden;
  white-space: nowrap;
  color: #FFC400;
  /* イエローカラー 自由に設定化 */
}

.rating_star[data-rate="5"]:after {
  width: 100%;
  /* 星5 */
}

.rating_star[data-rate="4.5"]:after {
  width: 90%;
  /* 星4.5 */
}

.rating_star[data-rate="4"]:after {
  width: 80%;
  /* 星4 */
}

.rating_star[data-rate="3.5"]:after {
  width: 70%;
  /* 星3.5 */
}

.rating_star[data-rate="3"]:after {
  width: 60%;
  /* 星3 */
}

.rating_star[data-rate="2.5"]:after {
  width: 50%;
  /* 星2.5 */
}

.rating_star[data-rate="2"]:after {
  width: 40%;
  /* 星2 */
}

.rating_star[data-rate="1.5"]:after {
  width: 30%;
  /* 星1.5 */
}

.rating_star[data-rate="1"]:after {
  width: 20%;
  /* 星1 */
}

.rating_star[data-rate="0.5"]:after {
  width: 10%;
  /* 星0.5 */
}

.rating_star[data-rate="0"]:after {
  width: 0%;
  /* 星0 */
}

.cta {
  background: url(../img/cta-bg.jpg) 50%/cover;
  overflow: hidden;
}

.cta .container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 240px;
  padding: 33px 0 0;
  position: relative;
}

.cta h2 {
  margin-bottom: 24px;
}

.cta .ttl {
  width: 430px;
}

.cta .btn img {
  width: 506px;
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
}

.cta .ill {
  position: absolute;
  bottom: 0;
  z-index: 1;
  -webkit-transform: translateX(0) translateY(1000px);
      -ms-transform: translateX(0) translateY(1000px);
          transform: translateX(0) translateY(1000px);
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
}

.cta .ill01 {
  width: 197px;
  left: 55px;
}

.cta .ill02 {
  width: 230px;
  right: 53px;
}

.cta .kirakira {
  position: absolute;
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  -webkit-transition-delay: .4s;
       -o-transition-delay: .4s;
          transition-delay: .4s;
}

.cta .kirakira01 {
  width: 45px;
  top: 16px;
  left: 214px;
}

.cta .kirakira02 {
  width: 60px;
  top: 134px;
  right: 30px;
}

.cta.scrollin .ill {
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}

.cta.scrollin .kirakira {
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.cta.scrollin .btn img {
  -webkit-animation: ctaBtn .3s .8s forwards;
          animation: ctaBtn .3s .8s forwards;
}

@media (max-width: 750px) {
  .cta {
    display: none;
  }
}

@-webkit-keyframes ctaBtn {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  80% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes ctaBtn {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  80% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

.btn {
  -webkit-transition: .2s;
  -o-transition: .2s;
  transition: .2s;
}

.btn:hover {
  opacity: 1;
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}

#mv {
  position: relative;
}

#mv .bg {
  width: 100%;
  height: 100%;
  background: url(../img/mv-bg.jpg) 50%/cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  overflow: hidden;
}

#mv .bg:before {
  content: '';
  display: block;
  width: 742px;
  height: 742px;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
}

#mv .container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 620px;
  padding-top: 45px;
  position: relative;
}

#mv .mv-img01 {
  width: 544px;
}

#mv .mv-ill {
  position: absolute;
  z-index: 1;
  -webkit-transition: 0s;
  -o-transition: 0s;
  transition: 0s;
}

#mv .mv-ill01 {
  width: 218px;
  top: 67px;
  left: 39px;
}

#mv .mv-ill02 {
  width: 235px;
  top: 50px;
  right: 30px;
}

#mv .mv-ill03 {
  width: 64px;
  top: 193px;
  left: 226px;
  -webkit-transform: scale(0, 0);
      -ms-transform: scale(0, 0);
          transform: scale(0, 0);
}

#mv .mv-ill04 {
  width: 251px;
  top: -1000px;
  left: 39px;
}

#mv .mv-ill05 {
  width: 299px;
  top: -1000px;
  right: 31px;
}

#mv .btn {
  margin-top: 42px;
}

@media (max-width: 750px) {
  #mv .bg {
    background: url(../img/sp/mv-bg.jpg) 50%/cover;
  }
  #mv .bg:before {
    width: calc(628 / 750 * 100vw);
    height: calc(628 / 750 * 100vw);
  }
  #mv .container {
    height: calc(800 / 750 * 100vw);
    padding-top: calc(86 / 750 * 100vw);
  }
  #mv .mv-img01 {
    width: calc(611 / 750 * 100vw);
  }
  #mv .mv-ill {
    position: absolute;
    z-index: 1;
    -webkit-transition: 0s;
    -o-transition: 0s;
    transition: 0s;
  }
  #mv .mv-ill01 {
    width: calc(161 / 750 * 100vw);
    top: calc(80 / 750 * 100vw);
    left: calc(30 / 750 * 100vw);
  }
  #mv .mv-ill02 {
    width: calc(185 / 750 * 100vw);
    top: calc(27 / 750 * 100vw);
    right: calc(19 / 750 * 100vw);
  }
  #mv .mv-ill03 {
    display: none;
  }
  #mv .mv-ill04 {
    width: calc(180 / 750 * 100vw);
    left: calc(-3 / 750 * 100vw);
  }
  #mv .mv-ill05 {
    width: calc(190 / 750 * 100vw);
    right: 0;
  }
  #mv .btn {
    margin-top: calc(56 / 750 * 100vw);
  }
  #mv .mv-btn {
    width: calc(560 / 750 * 100vw);
    margin-left: calc(12 / 750 * 100vw);
  }
}

section {
  padding-top: 99px;
  margin-top: -99px;
}

@media (max-width: 750px) {
  section {
    padding-top: calc(99 / 750 * 100vw);
    margin-top: calc(-99 / 750 * 100vw);
  }
}

#reason .inner {
  padding: 64px 0 60px;
  background-size: auto auto;
  background-color: #F3EDD4;
  background-image: -webkit-repeating-linear-gradient(left, transparent, transparent 24px, rgba(240, 232, 196, 0.15) 24px, rgba(240, 232, 196, 0.15) 48px);
  background-image: -o-repeating-linear-gradient(left, transparent, transparent 24px, rgba(240, 232, 196, 0.15) 24px, rgba(240, 232, 196, 0.15) 48px);
  background-image: repeating-linear-gradient(90deg, transparent, transparent 24px, rgba(240, 232, 196, 0.15) 24px, rgba(240, 232, 196, 0.15) 48px);
}

#reason h2 {
  margin-bottom: 50px;
}

#reason h2 img {
  width: 697px;
}

#reason .secHeading p {
  font-size: 18px;
  line-height: 42px;
  font-weight: 500;
  text-align: center;
}

#reason .secBody {
  margin-top: 60px;
}

#reason .list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

#reason .item {
  width: 480px;
  height: 460px;
  padding: 40px 62px 0;
  margin: 0 42px 40px 0;
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
}

#reason .item:before {
  content: '';
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 110px 110px 0 0;
  border-color: #532B75 transparent transparent transparent;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

#reason .item .num {
  font-size: 54px;
  color: #fff;
  position: absolute;
  top: 12px;
  left: 16px;
  z-index: 2;
}

#reason .item h3 {
  margin-bottom: 36px;
  font-size: 32px;
  line-height: 42px;
  font-weight: 900;
  text-align: center;
}

#reason .item h3 .bog {
  font-size: 36px;
}

#reason .item .imgArea {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 145px;
  margin-bottom: 15px;
}

#reason .item p {
  line-height: 26px;
  font-weight: 500;
}

#reason .item:nth-child(1) .ill {
  width: 209px;
}

#reason .item:nth-child(2) .ill {
  width: 164px;
}

#reason .item:nth-child(3) .ill {
  width: 206px;
}

#reason .item:nth-child(4) .ill {
  width: 242px;
}

#reason .item:nth-child(2n) {
  margin-right: 0;
}

@media (max-width: 750px) {
  #reason .inner {
    padding: calc(82 / 750 * 100vw) 0 calc(80 / 750 * 100vw);
    background-size: auto auto;
    background-color: #F3EDD4;
    background-image: -webkit-repeating-linear-gradient(left, transparent, transparent calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(48 / 750 * 100vw));
    background-image: -o-repeating-linear-gradient(left, transparent, transparent calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(48 / 750 * 100vw));
    background-image: repeating-linear-gradient(90deg, transparent, transparent calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(48 / 750 * 100vw));
  }
  #reason h2 {
    margin-bottom: calc(32 / 750 * 100vw);
  }
  #reason h2 img {
    width: calc(698 / 750 * 100vw);
  }
  #reason .secHeading p {
    font-size: calc(32 / 750 * 100vw);
    line-height: calc(48 / 750 * 100vw);
  }
  #reason .secBody {
    padding: 0 calc(30 / 750 * 100vw);
    margin-top: calc(50 / 750 * 100vw);
  }
  #reason .item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    width: 100%;
    height: auto;
    min-height: calc(330 / 750 * 100vw);
    padding: calc(46 / 750 * 100vw) calc(50 / 750 * 100vw) calc(55 / 750 * 100vw) calc(23 / 750 * 100vw);
    margin: 0 0 calc(30 / 750 * 100vw);
    border-radius: calc(16 / 750 * 100vw);
  }
  #reason .item:before {
    border-width: calc(94 / 750 * 100vw) calc(94 / 750 * 100vw) 0 0;
  }
  #reason .item .num {
    font-size: calc(39 / 750 * 100vw);
    top: calc(12 / 750 * 100vw);
    left: calc(16 / 750 * 100vw);
  }
  #reason .item h3 {
    width: 100%;
    padding-left: calc(95 / 750 * 100vw);
    margin-bottom: calc(32 / 750 * 100vw);
    font-size: calc(36 / 750 * 100vw);
    line-height: 1.5;
    text-align: left;
  }
  #reason .item h3 .bog {
    font-size: calc(36 / 750 * 100vw);
  }
  #reason .item .spFlex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #reason .item .imgArea {
    width: calc(243 / 750 * 100vw);
    min-width: calc(243 / 750 * 100vw);
    height: calc(146 / 750 * 100vw);
    margin-bottom: 0;
    margin-right: calc(24 / 750 * 100vw);
  }
  #reason .item .txtArea {
    width: calc(352 / 750 * 100vw);
    min-width: calc(352 / 750 * 100vw);
  }
  #reason .item p {
    line-height: calc(42 / 750 * 100vw);
  }
  #reason .item:nth-child(1) .ill {
    width: calc(210 / 750 * 100vw);
  }
  #reason .item:nth-child(2) .ill {
    width: calc(164 / 750 * 100vw);
  }
  #reason .item:nth-child(3) .ill {
    width: calc(206 / 750 * 100vw);
  }
  #reason .item:nth-child(4) .ill {
    width: calc(243 / 750 * 100vw);
  }
  #reason .item:nth-child(2n) {
    margin-right: 0;
  }
}

#voice .inner {
  padding: 120px 0 80px;
}

#voice h2 img {
  width: 753px;
}

#voice .secBody {
  margin-top: 80px;
}

#voice .list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

#voice .item {
  width: 480px;
  height: 328px;
  padding: 30px;
  margin: 0 40px 40px 0;
  border-radius: 16px;
  background: #F7F7F7;
}

#voice .item .imgArea {
  margin-right: 30px;
}

#voice .item .img {
  width: 128px;
}

#voice .item .txtArea .cat {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 262px;
  height: 44px;
  margin-bottom: 12px;
  border-radius: 22px;
  background: #FFE13C;
  font-size: 20px;
  font-weight: 900;
}

#voice .item .txtArea .personal {
  display: block;
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 900;
  text-align: center;
}

#voice .item:nth-child(2n) {
  margin-right: 0;
}

#voice .itemHeading {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

#voice .ratingArea {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

#voice .rating_star {
  padding-bottom: 2px;
  font-size: 30px;
  letter-spacing: .2em;
}

#voice .rating_num {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}

#voice .rating_num .txt {
  margin-top: 7px;
  font-size: 12px;
  font-weight: 900;
  color: #5E96C9;
}

#voice .rating_num .num {
  font-size: 45px;
  font-weight: 900;
  color: #5E96C9;
}

#voice .itemBody {
  padding: 0 32px;
  margin-top: 26px;
}

#voice .itemBody h3 {
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 2px solid #5E96C9;
  font-size: 17px;
  font-weight: 900;
  color: #5E96C9;
}

#voice .itemBody p {
  line-height: 26px;
}

@media (max-width: 750px) {
  #voice .inner {
    padding: calc(80 / 750 * 100vw) 0;
  }
  #voice h2 img {
    width: calc(690 / 750 * 100vw);
  }
  #voice .secBody {
    padding: 0 calc(30 / 750 * 100vw);
    margin-top: calc(86 / 750 * 100vw);
  }
  #voice .item {
    width: 100%;
    height: auto;
    padding: calc(30 / 750 * 100vw);
    margin: 0 0 calc(30 / 750 * 100vw);
    border-radius: calc(16 / 750 * 100vw);
  }
  #voice .item .imgArea {
    margin-right: 30px;
  }
  #voice .item .imgArea img {
    width: calc(128 / 750 * 100vw);
  }
  #voice .item .imgArea .personal {
    margin-top: calc(14 / 750 * 100vw);
    font-size: calc(20 / 750 * 100vw);
    font-weight: 900;
    text-align: center;
  }
  #voice .item .img {
    width: 128px;
  }
  #voice .item .txtArea .cat {
    width: calc(367 / 750 * 100vw);
    height: calc(62 / 750 * 100vw);
    margin-bottom: calc(30 / 750 * 100vw);
    border-radius: calc(35 / 750 * 100vw);
    font-size: calc(32 / 750 * 100vw);
  }
  #voice .item .txtArea .personal {
    display: none;
  }
  #voice .itemHeading .txtArea {
    margin-left: auto;
  }
  #voice .rating_star {
    padding-bottom: calc(7 / 750 * 100vw);
    font-size: calc(42 / 750 * 100vw);
    letter-spacing: .2em;
  }
  #voice .rating_num {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  #voice .rating_num .txt {
    margin-top: calc(13 / 750 * 100vw);
    font-size: calc(21 / 750 * 100vw);
  }
  #voice .rating_num .num {
    font-size: calc(79 / 750 * 100vw);
  }
  #voice .itemBody {
    padding: 0;
    margin-top: calc(20 / 750 * 100vw);
  }
  #voice .itemBody h3 {
    padding-bottom: calc(6 / 750 * 100vw);
    margin-bottom: calc(12 / 750 * 100vw);
    border-bottom: calc(4 / 750 * 100vw) solid #5E96C9;
    font-size: calc(32 / 750 * 100vw);
    line-height: calc(48 / 750 * 100vw);
  }
  #voice .itemBody p {
    line-height: calc(42 / 750 * 100vw);
  }
}

#step .inner {
  padding: 120px 0 108px;
  background-size: auto auto;
  background-color: #F3EDD4;
  background-image: -webkit-repeating-linear-gradient(left, transparent, transparent 24px, rgba(240, 232, 196, 0.15) 24px, rgba(240, 232, 196, 0.15) 48px);
  background-image: -o-repeating-linear-gradient(left, transparent, transparent 24px, rgba(240, 232, 196, 0.15) 24px, rgba(240, 232, 196, 0.15) 48px);
  background-image: repeating-linear-gradient(90deg, transparent, transparent 24px, rgba(240, 232, 196, 0.15) 24px, rgba(240, 232, 196, 0.15) 48px);
}

#step .secHeading {
  margin-bottom: 80px;
}

#step h2 {
  margin-bottom: 50px;
}

#step h2 img {
  width: 697px;
}

#step .list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

#step .item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 740px;
  height: 216px;
  padding: 0 30px 0 70px;
  margin-bottom: 78px;
  border-radius: 16px;
  background: #fff;
  position: relative;
}

#step .item:before {
  content: '';
  display: block;
  width: 73px;
  height: 27px;
  background: url(../img/sec03-item-arrow@2x.png) 50%/cover;
  position: absolute;
  bottom: -50px;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
  -webkit-transition-delay: .5s;
       -o-transition-delay: .5s;
          transition-delay: .5s;
  opacity: 0;
}

#step .item .stepNum {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 144px;
  height: 40px;
  padding-bottom: 8px;
  background: url(../img/sec03-step-bg@2x.png) 50%/cover;
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  position: absolute;
  top: -8px;
  left: 70px;
  z-index: 1;
}

#step .item .stepNum .big {
  margin-left: 4px;
  font-size: 24px;
  position: relative;
  top: 1px;
}

#step .item .txtArea {
  padding-top: 25px;
}

#step .item .txtArea p {
  line-height: 26px;
  font-weight: 500;
}

#step .item h3 {
  margin-bottom: 28px;
  font-size: 28px;
  font-weight: 900;
}

#step .item .imgArea {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 290px;
  margin-left: auto;
}

#step .item:last-child {
  margin-bottom: 0;
}

#step .item:last-child:before {
  content: none;
}

#step .item.scrollin:before {
  opacity: 1;
}

@media (max-width: 750px) {
  #step .inner {
    padding: calc(80 / 750 * 100vw) 0;
    background-color: #F3EDD4;
    background-image: -webkit-repeating-linear-gradient(left, transparent, transparent calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(48 / 750 * 100vw));
    background-image: -o-repeating-linear-gradient(left, transparent, transparent calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(48 / 750 * 100vw));
    background-image: repeating-linear-gradient(90deg, transparent, transparent calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(24 / 750 * 100vw), rgba(240, 232, 196, 0.15) calc(48 / 750 * 100vw));
  }
  #step .secHeading {
    margin-bottom: 0;
  }
  #step h2 {
    margin-bottom: 0;
  }
  #step h2 img {
    width: calc(690 / 750 * 100vw);
  }
  #step .secBody {
    padding: 0 calc(30 / 750 * 100vw);
    margin-top: calc(100 / 750 * 100vw);
  }
  #step .item {
    width: 100%;
    height: auto;
    padding: calc(13 / 750 * 100vw) calc(30 / 750 * 100vw) calc(13 / 750 * 100vw) calc(50 / 750 * 100vw);
    margin-bottom: calc(78 / 750 * 100vw);
    border-radius: calc(16 / 750 * 100vw);
  }
  #step .item:before {
    width: calc(77 / 750 * 100vw);
    height: calc(31 / 750 * 100vw);
    background: url(../img/sec03-item-arrow@2x.png) 50%/calc(74 / 750 * 100vw) no-repeat;
    bottom: calc(-56 / 750 * 100vw);
  }
  #step .item .stepNum {
    width: calc(144 / 750 * 100vw);
    height: calc(40 / 750 * 100vw);
    padding-bottom: calc(8 / 750 * 100vw);
    background: url(../img/sec03-step-bg@2x.png) 50%/cover;
    font-size: calc(18 / 750 * 100vw);
    top: calc(-8 / 750 * 100vw);
    left: calc(70 / 750 * 100vw);
  }
  #step .item .stepNum .big {
    margin-left: calc(4 / 750 * 100vw);
    font-size: calc(24 / 750 * 100vw);
    position: relative;
    top: calc(1 / 750 * 100vw);
  }
  #step .item .txtArea {
    padding-top: calc(25 / 750 * 100vw);
  }
  #step .item .txtArea p {
    line-height: calc(42 / 750 * 100vw);
  }
  #step .item h3 {
    margin-bottom: calc(20 / 750 * 100vw);
    font-size: calc(32 / 750 * 100vw);
  }
  #step .item .imgArea {
    width: calc(234 / 750 * 100vw);
  }
}

#area .inner {
  padding: 80px 0;
  background: url(../img/sec04-bg.jpg) 50%/cover;
}

#area .container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

#area h2 {
  margin-bottom: 32px;
}

#area h2 img {
  width: 465px;
}

#area .areaList {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 540px;
  height: 92px;
  margin-bottom: 24px;
  border-radius: 16px;
  background: #fff;
}

#area .areaList li {
  margin-right: 30px;
  padding-left: 18px;
  font-size: 20px;
  line-height: 20px;
  font-weight: 900;
  position: relative;
}

#area .areaList li:before {
  content: '';
  width: 9px;
  height: 9px;
  border-radius: 5px;
  background: #FFE13C;
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 1;
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

#area .areaList li:last-child {
  margin-right: 0;
}

#area .arrowTxt {
  display: block;
  width: 400px;
  height: 30px;
  padding-left: 10px;
  margin: 0 auto;
  position: relative;
}

#area .arrowTxt p {
  font-size: 28px;
  font-weight: 900;
  text-align: center;
}

#area .arrowTxt .arrowWrap {
  display: block;
  width: 63px;
  height: 25px;
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 1;
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

#area .arrowTxt .arrowWrap01 {
  background: url(../img/sec04-txt-arrow-left.svg) 0 repeat-x;
  background-position: 0 0;
  -webkit-animation: arrowTxtLeft 1.5s steps(3) infinite;
          animation: arrowTxtLeft 1.5s steps(3) infinite;
}

#area .arrowTxt .arrowWrap02 {
  background: url(../img/sec04-txt-arrow-right.svg) 0 repeat-x;
  background-position: 0 0;
  left: auto;
  right: 0;
  -webkit-animation: arrowTxtRight 1.5s steps(3) infinite;
          animation: arrowTxtRight 1.5s steps(3) infinite;
}

#area .areaMap {
  display: none;
}

#area .secBody {
  margin-left: 90px;
}

#area .secBody img {
  width: 341px;
}

@media (max-width: 750px) {
  #area .inner {
    padding: calc(80 / 750 * 100vw) 0;
    background: url(../img/sp/sec04-bg.jpg) 50%/cover;
  }
  #area .container {
    padding: 0 calc(30 / 750 * 100vw);
  }
  #area h2 {
    margin-bottom: calc(25 / 750 * 100vw);
  }
  #area h2 img {
    width: calc(467 / 750 * 100vw);
  }
  #area .spFlex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #area .areaList {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    width: calc(395 / 750 * 100vw);
    height: calc(152 / 750 * 100vw);
    padding: 0 calc(36 / 750 * 100vw);
    margin-bottom: 0;
    margin-right: calc(27 / 750 * 100vw);
    border-radius: calc(16 / 750 * 100vw);
  }
  #area .areaList li {
    width: 50%;
    margin-right: 0;
    padding-left: calc(32 / 750 * 100vw);
    font-size: calc(30 / 750 * 100vw);
    line-height: 1;
  }
  #area .areaList li:before {
    width: calc(12 / 750 * 100vw);
    height: calc(12 / 750 * 100vw);
    border-radius: calc(6 / 750 * 100vw);
  }
  #area .areaList li:last-child {
    margin-right: 0;
  }
  #area .areaMap {
    width: calc(268 / 750 * 100vw);
  }
  #area .arrowTxt {
    display: block;
    width: calc(608 / 750 * 100vw);
    height: calc(50 / 750 * 100vw);
    padding-left: calc(10 / 750 * 100vw);
    margin-top: calc(24 / 750 * 100vw);
  }
  #area .arrowTxt p {
    font-size: calc(42 / 750 * 100vw);
  }
  #area .arrowTxt .arrowWrap {
    width: calc(93 / 750 * 100vw);
    height: calc(42 / 750 * 100vw);
  }
  #area .arrowTxt .arrowWrap01 {
    background: url(../img/sec04-txt-arrow-left.svg) 0/calc(93 / 750 * 100vw) repeat-x;
    background-position: 0 50%;
    -webkit-animation: arrowTxtLeft 1.5s steps(3) infinite;
            animation: arrowTxtLeft 1.5s steps(3) infinite;
  }
  #area .arrowTxt .arrowWrap02 {
    background: url(../img/sec04-txt-arrow-right.svg) 0/calc(93 / 750 * 100vw) repeat-x;
    background-position: 0 50%;
    left: auto;
    right: 0;
    -webkit-animation: arrowTxtRight 1.5s steps(3) infinite;
            animation: arrowTxtRight 1.5s steps(3) infinite;
  }
  #area .areaMap {
    display: block;
  }
  #area .secBody {
    display: none;
  }
}

@-webkit-keyframes arrowTxtLeft {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 63px 0;
  }
}

@keyframes arrowTxtLeft {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 63px 0;
  }
}

@-webkit-keyframes arrowTxtRight {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -63px 0;
  }
}

@keyframes arrowTxtRight {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -63px 0;
  }
}

@media (max-width: 750px) {
  @-webkit-keyframes arrowTxtLeft {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: calc(93 / 750 * 100vw) 0;
    }
  }
  @keyframes arrowTxtLeft {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: calc(93 / 750 * 100vw) 0;
    }
  }
  @-webkit-keyframes arrowTxtRight {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: calc(-93 / 750 * 100vw) 0;
    }
  }
  @keyframes arrowTxtRight {
    0% {
      background-position: 0 0;
    }
    100% {
      background-position: calc(-93 / 750 * 100vw) 0;
    }
  }
}

#form .inner {
  padding: 80px 0;
  background: url(../img/sec05-bg.jpg) 50%;
}

#form .secHeading {
  margin-bottom: 80px;
}

#form h2 img {
  width: 551px;
}

#form form#mail_form {
  max-width: 1022px;
  padding: 80px 50px 100px;
  margin: 0 auto;
  border-radius: 16px;
  background: #F7F3E5;
}

#form form#mail_form dl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  overflow: visible;
}

#form form#mail_form dl dt {
  position: relative;
}

#form form#mail_form dl dt span.required {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 42px;
  height: 22px;
  border: 1px solid #E60A0A;
  background: #E60A0A;
  float: none;
  color: #fff;
  padding: 0;
  border-radius: 2px;
  position: absolute;
  top: 10px;
  right: 16px;
  z-index: 1;
}

#form form#mail_form .dl {
  width: 100%;
  margin-bottom: 48px;
}

#form form#mail_form .dl.other {
  display: block !important;
  padding: 24px 40px;
  border-radius: 8px;
  background: #fff;
}

#form form#mail_form .dl.other .dl {
  display: block;
}

#form form#mail_form .dl.other dt {
  margin-bottom: 14px;
}

#form form#mail_form .dl.other dd {
  padding: 0;
  border-radius: 0;
}

#form form#mail_form .dl.other .dd dt {
  margin-bottom: 14px;
}

#form form#mail_form .dl.other .dd dd {
  padding: 0;
  border-radius: 0;
}

#form form#mail_form .dl.location .dd {
  padding: 24px 40px;
  border-radius: 8px;
  background: #fff;
}

#form form#mail_form .dl.location .dd dt {
  width: 202px;
  min-width: 202px;
  padding-top: 13px;
}

#form form#mail_form .dl.location .dd dd {
  padding: 0;
  border-radius: 0;
}

#form form#mail_form .dl.tel dd p {
  margin-left: 20px;
}

#form form#mail_form .dl:last-child {
  margin-bottom: 0;
}

#form form#mail_form dt, #form form#mail_form .dt {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 900;
}

#form form#mail_form dt.sub, #form form#mail_form .dt.sub {
  display: block;
  margin-bottom: 12px;
  font-size: 18px;
  color: #000;
}

#form form#mail_form dd .dl, #form form#mail_form .dd .dl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 14px;
}

#form form#mail_form dd .dl.checkboxDl, #form form#mail_form .dd .dl.checkboxDl {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-bottom: 21px;
}

#form form#mail_form dd dt, #form form#mail_form .dd dt {
  margin-bottom: 0;
  font-size: 16px;
}

#form form#mail_form dd dt.sub, #form form#mail_form .dd dt.sub {
  margin-bottom: 12px;
  font-size: 18px;
}

#form form#mail_form dd dd, #form form#mail_form .dd dd {
  display: -webkit-box !important;
  display: -webkit-flex !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

#form form#mail_form input[type="text"], #form form#mail_form input[type="tel"], #form form#mail_form input[type="email"] {
  width: 100%;
  height: 42px;
  padding-left: 30px;
  border-radius: 8px;
  background: #F5F5F5;
}

#form form#mail_form input[type="text"].s, #form form#mail_form input[type="tel"].s, #form form#mail_form input[type="email"].s {
  width: 243px;
  margin-right: 20px;
}

#form form#mail_form input[type="text"].m, #form form#mail_form input[type="tel"].m, #form form#mail_form input[type="email"].m {
  width: 506px;
}

#form form#mail_form input[type="text"]:nth-last-of-type(1), #form form#mail_form input[type="tel"]:nth-last-of-type(1), #form form#mail_form input[type="email"]:nth-last-of-type(1) {
  margin-right: 0;
}

#form form#mail_form input[type="radio"], #form form#mail_form input[type="checkbox"] {
  display: block;
  height: 0;
  border: none;
}

#form form#mail_form input[type="radio"]:checked ~ .radioBtn, #form form#mail_form input[type="radio"]:checked ~ .checkboxBtn, #form form#mail_form input[type="checkbox"]:checked ~ .radioBtn, #form form#mail_form input[type="checkbox"]:checked ~ .checkboxBtn {
  border: 3px solid #75489B;
  background: #75489B;
  color: #fff;
}

#form form#mail_form .radioBtnList, #form form#mail_form .checkboxList {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

#form form#mail_form .radioBtnList li, #form form#mail_form .checkboxList li {
  margin-right: 18px;
}

#form form#mail_form .radioBtnList li:last-child, #form form#mail_form .checkboxList li:last-child {
  margin-right: 0;
}

#form form#mail_form .checkboxList {
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}

#form form#mail_form .checkboxList li {
  margin-right: 10px;
  margin-bottom: 12px;
}

#form form#mail_form .checkboxList li:nth-child(8n) {
  margin-right: 0;
}

#form form#mail_form .radioBtn, #form form#mail_form .checkboxBtn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 170px;
  height: 96px;
  border-radius: 8px;
  border: 3px solid #fff;
  background: #fff;
  line-height: 22px;
  font-weight: 900;
  text-align: center;
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
  cursor: pointer;
}

#form form#mail_form .radioBtn .small, #form form#mail_form .checkboxBtn .small {
  margin-top: 8px;
  margin-bottom: -5px;
  font-size: 15px;
  line-height: 20px;
  font-weight: 400;
}

#form form#mail_form .radioBtn:hover, #form form#mail_form .checkboxBtn:hover {
  border: 3px solid #75489B;
}

#form form#mail_form .checkboxBtn {
  width: 106px;
  height: 60px;
  line-height: 20px;
}

#form form#mail_form .kodawariTrigger {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 540px;
  height: 80px;
  margin: 0 auto 30px;
  border-radius: 40px;
  border: 3px solid #000;
  background: #5CA9EF;
  position: relative;
  -webkit-transition: .1s;
  -o-transition: .1s;
  transition: .1s;
  cursor: pointer;
}

#form form#mail_form .kodawariTrigger:before, #form form#mail_form .kodawariTrigger:after {
  content: '';
  display: block;
  width: 32px;
  height: 8px;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 37px;
  z-index: 1;
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
}

#form form#mail_form .kodawariTrigger:after {
  -webkit-transform: translate(0, -50%) rotate(90deg);
      -ms-transform: translate(0, -50%) rotate(90deg);
          transform: translate(0, -50%) rotate(90deg);
}

#form form#mail_form .kodawariTrigger p {
  font-size: 24px;
  font-weight: 900;
  color: #fff;
}

#form form#mail_form .kodawariTrigger.clicked:after {
  -webkit-transform: translate(0, -50%) rotate(0);
      -ms-transform: translate(0, -50%) rotate(0);
          transform: translate(0, -50%) rotate(0);
}

#form form#mail_form .kodawariTrigger:hover {
  -webkit-transform: scale(1.05);
      -ms-transform: scale(1.05);
          transform: scale(1.05);
}

#form form#mail_form .kodawariForm {
  display: none;
  padding: 10px 0 30px;
}

#form form#mail_form .kodawariForm .other {
  margin: -21px 0 0;
}

#form form#mail_form #agreement {
  margin: 30px 0 60px;
}

#form form#mail_form #agreement .policy {
  width: 640px;
  height: 176px;
  padding: 22px 55px;
  margin: 0 auto 32px;
  border-radius: 8px;
  background: #fff;
  overflow: scroll;
}

#form form#mail_form #agreement .policy h3 {
  margin-bottom: 15px;
  font-weight: 900;
  text-align: center;
}

#form form#mail_form #agreement .policy p {
  font-size: 14px;
  line-height: 24px;
}

#form form#mail_form #agreement #agree_check {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}

#form form#mail_form #agreement #agree_check .error_check {
  width: 100%;
  text-align: center;
}

#form form#mail_form #agreement .agree_check_label {
  padding-left: 36px;
  line-height: 24px;
  position: relative;
  cursor: pointer;
}

#form form#mail_form #agreement .agree_check_label:before {
  content: '';
  display: block;
  width: 24px;
  height: 24px;
  border: 2px solid #000;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 1;
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

#form form#mail_form #agreement .agree_check_label:after {
  content: '';
  display: block;
  width: 10px;
  height: 16px;
  border-right: 3px solid #fff;
  border-bottom: 3px solid #fff;
  position: absolute;
  top: 1px;
  left: 7px;
  z-index: 1;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  opacity: 0;
}

#form form#mail_form #agreement #agree_check_check {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

#form form#mail_form #agreement #agree_check_check:checked ~ .agree_check_label:before {
  background: #75489B;
}

#form form#mail_form #agreement #agree_check_check:checked ~ .agree_check_label:after {
  opacity: 1;
}

#form form#mail_form .submitBtnWrap .submitBtn {
  display: block;
  cursor: pointer;
  -webkit-transition: .2s;
  -o-transition: .2s;
  transition: .2s;
}

#form form#mail_form .submitBtnWrap .submitBtn:hover {
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}

#form form#mail_form .submitBtnWrap .submitBtn img {
  width: 640px;
  margin: 0 auto;
}

#form form#mail_form .submitBtnWrap input {
  display: none;
}

@media (max-width: 750px) {
  #form .inner {
    padding: calc(100 / 750 * 100vw) 0;
    background: url(../img/sec05-bg.jpg) 50%;
  }
  #form .secHeading {
    margin-bottom: calc(80 / 750 * 100vw);
  }
  #form h2 img {
    width: calc(555 / 750 * 100vw);
  }
  #form form#mail_form {
    padding: calc(70 / 750 * 100vw) calc(30 / 750 * 100vw) calc(100 / 750 * 100vw);
    border-radius: 0;
  }
  #form form#mail_form dl {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    overflow: visible;
  }
  #form form#mail_form dl dt {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
  }
  #form form#mail_form dl dt span.required {
    width: calc(60 / 750 * 100vw);
    height: calc(32 / 750 * 100vw);
    padding: 0;
    margin: 0 0 0 calc(26 / 750 * 100vw);
    border-radius: calc(2 / 750 * 100vw);
    font-size: calc(20 / 750 * 100vw);
    position: relative;
    top: 0;
    right: 0;
  }
  #form form#mail_form .dl {
    width: 100%;
    margin-bottom: calc(60 / 750 * 100vw);
  }
  #form form#mail_form .dl.volume .radioBtn, #form form#mail_form .dl.volume .checkboxBtn {
    font-size: calc(25 / 750 * 100vw);
    line-height: calc(1 / 750 * 100vw);
  }
  #form form#mail_form .dl.other {
    display: block !important;
    padding: calc(24 / 750 * 100vw) calc(40 / 750 * 100vw);
    border-radius: calc(8 / 750 * 100vw);
  }
  #form form#mail_form .dl.other .dl {
    display: block;
  }
  #form form#mail_form .dl.other dt {
    margin-bottom: calc(16 / 750 * 100vw);
  }
  #form form#mail_form .dl.other dd {
    padding: 0;
    border-radius: 0;
  }
  #form form#mail_form .dl.other .dd dt {
    margin-bottom: calc(16 / 750 * 100vw);
  }
  #form form#mail_form .dl.other .dd dd {
    padding: 0;
    border-radius: 0;
  }
  #form form#mail_form .dl.location {
    margin-bottom: calc(80 / 750 * 100vw);
  }
  #form form#mail_form .dl.location .dl.name input {
    width: calc(300 / 750 * 100vw);
  }
  #form form#mail_form .dl.location .dd {
    padding: calc(40 / 750 * 100vw) calc(40 / 750 * 100vw) calc(10 / 750 * 100vw);
    border-radius: 8px;
  }
  #form form#mail_form .dl.location .dd dt {
    width: 100%;
    min-width: auto;
    padding-top: 0;
    margin-bottom: calc(16 / 750 * 100vw);
  }
  #form form#mail_form .dl.location .dd dd {
    padding: 0;
    border-radius: 0;
  }
  #form form#mail_form .dl.tel dd p {
    margin-top: calc(15 / 750 * 100vw);
    margin-left: 0;
  }
  #form form#mail_form .dl:last-child {
    margin-bottom: 0;
  }
  #form form#mail_form dt, #form form#mail_form .dt {
    margin-bottom: calc(24 / 750 * 100vw);
    font-size: calc(36 / 750 * 100vw);
  }
  #form form#mail_form dt.sub, #form form#mail_form .dt.sub {
    display: block;
    margin-bottom: 12px;
    font-size: 18px;
    color: #000;
  }
  #form form#mail_form dd .dl, #form form#mail_form .dd .dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: calc(30 / 750 * 100vw);
  }
  #form form#mail_form dd .dl.checkboxDl, #form form#mail_form .dd .dl.checkboxDl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: calc(50 / 750 * 100vw);
  }
  #form form#mail_form dd dt, #form form#mail_form .dd dt {
    margin-bottom: 0;
    font-size: calc(30 / 750 * 100vw);
  }
  #form form#mail_form dd dt.sub, #form form#mail_form .dd dt.sub {
    margin-bottom: calc(20 / 750 * 100vw);
    font-size: calc(30 / 750 * 100vw);
  }
  #form form#mail_form dd dd, #form form#mail_form .dd dd {
    display: -webkit-box !important;
    display: -webkit-flex !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #form form#mail_form input[type="text"], #form form#mail_form input[type="tel"], #form form#mail_form input[type="email"] {
    width: 100%;
    height: calc(80 / 750 * 100vw);
    padding-left: calc(20 / 750 * 100vw);
    border-radius: calc(8 / 750 * 100vw);
  }
  #form form#mail_form input[type="text"].s, #form form#mail_form input[type="tel"].s, #form form#mail_form input[type="email"].s {
    width: calc(360 / 750 * 100vw);
    margin-right: calc(10 / 750 * 100vw);
  }
  #form form#mail_form input[type="text"].m, #form form#mail_form input[type="tel"].m, #form form#mail_form input[type="email"].m {
    width: 100%;
  }
  #form form#mail_form input[type="text"]:nth-last-of-type(1), #form form#mail_form input[type="tel"]:nth-last-of-type(1), #form form#mail_form input[type="email"]:nth-last-of-type(1) {
    margin-right: 0;
  }
  #form form#mail_form input[type="radio"], #form form#mail_form input[type="checkbox"] {
    display: block;
  }
  #form form#mail_form input[type="radio"]:checked ~ .radioBtn, #form form#mail_form input[type="radio"]:checked ~ .checkboxBtn, #form form#mail_form input[type="checkbox"]:checked ~ .radioBtn, #form form#mail_form input[type="checkbox"]:checked ~ .checkboxBtn {
    border: none;
    background: #75489B;
    color: #fff;
  }
  #form form#mail_form .radioBtnList, #form form#mail_form .checkboxList {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    margin-bottom: calc(-20 / 750 * 100vw);
  }
  #form form#mail_form .radioBtnList li, #form form#mail_form .checkboxList li {
    margin-right: calc(21 / 750 * 100vw);
    margin-bottom: calc(20 / 750 * 100vw);
  }
  #form form#mail_form .radioBtnList li:nth-child(3n), #form form#mail_form .checkboxList li:nth-child(3n) {
    margin-right: 0;
  }
  #form form#mail_form .radioBtnList li:last-child, #form form#mail_form .checkboxList li:last-child {
    margin-right: 0;
  }
  #form form#mail_form .checkboxList {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  #form form#mail_form .checkboxList li {
    margin-right: calc(16 / 750 * 100vw);
    margin-bottom: calc(20 / 750 * 100vw);
  }
  #form form#mail_form .checkboxList li:nth-child(3n) {
    margin-right: calc(16 / 750 * 100vw);
  }
  #form form#mail_form .checkboxList li:nth-child(4n) {
    margin-right: 0;
  }
  #form form#mail_form .checkboxList li:nth-child(8n) {
    margin-right: 0;
  }
  #form form#mail_form .radioBtn, #form form#mail_form .checkboxBtn {
    width: calc(216 / 750 * 100vw);
    height: calc(120 / 750 * 100vw);
    padding: 0 calc(10 / 750 * 100vw);
    border-radius: calc(8 / 750 * 100vw);
    border: none;
    line-height: calc(42 / 750 * 100vw);
  }
  #form form#mail_form .radioBtn .small, #form form#mail_form .checkboxBtn .small {
    margin-top: calc(24 / 750 * 100vw);
    margin-bottom: calc(-14 / 750 * 100vw);
    font-size: calc(22 / 750 * 100vw);
    line-height: calc(30 / 750 * 100vw);
  }
  #form form#mail_form .radioBtn:hover, #form form#mail_form .checkboxBtn:hover {
    border: none;
  }
  #form form#mail_form .checkboxBtn {
    width: calc(160 / 750 * 100vw);
    height: calc(100 / 750 * 100vw);
    font-size: calc(26 / 750 * 100vw);
    line-height: calc(39 / 750 * 100vw);
  }
  #form form#mail_form .kodawariTrigger {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: calc(560 / 750 * 100vw);
    height: calc(100 / 750 * 100vw);
    margin: 0 auto calc(40 / 750 * 100vw);
    border-radius: calc(50 / 750 * 100vw);
    border: calc(5 / 750 * 100vw) solid #000;
    background: #5CA9EF;
  }
  #form form#mail_form .kodawariTrigger:before, #form form#mail_form .kodawariTrigger:after {
    width: calc(32 / 750 * 100vw);
    height: calc(8 / 750 * 100vw);
    right: calc(40 / 750 * 100vw);
  }
  #form form#mail_form .kodawariTrigger p {
    font-size: calc(32 / 750 * 100vw);
  }
  #form form#mail_form .kodawariTrigger:hover {
    -webkit-transform: scale(1);
        -ms-transform: scale(1);
            transform: scale(1);
  }
  #form form#mail_form .kodawariForm {
    display: none;
    padding: calc(10 / 750 * 100vw) 0 calc(30 / 750 * 100vw);
  }
  #form form#mail_form .kodawariForm .other {
    margin: calc(-20 / 750 * 100vw) 0 0;
  }
  #form form#mail_form #agreement {
    margin: calc(40 / 750 * 100vw) 0 60px;
  }
  #form form#mail_form #agreement .policy {
    width: 100%;
    height: calc(240 / 750 * 100vw);
    padding: calc(32 / 750 * 100vw) calc(55 / 750 * 100vw);
    margin: 0 auto calc(40 / 750 * 100vw);
    border-radius: calc(8 / 750 * 100vw);
  }
  #form form#mail_form #agreement .policy h3 {
    margin-bottom: calc(20 / 750 * 100vw);
    font-size: calc(28 / 750 * 100vw);
  }
  #form form#mail_form #agreement .policy p {
    font-size: calc(28 / 750 * 100vw);
    line-height: calc(42 / 750 * 100vw);
  }
  #form form#mail_form #agreement #agree_check {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: relative;
  }
  #form form#mail_form #agreement #agree_check .error_check {
    width: 100%;
    text-align: center;
  }
  #form form#mail_form #agreement .agree_check_label {
    padding-left: calc(67 / 750 * 100vw);
    line-height: calc(50 / 750 * 100vw);
  }
  #form form#mail_form #agreement .agree_check_label:before {
    width: calc(50 / 750 * 100vw);
    height: calc(50 / 750 * 100vw);
    border: calc(3 / 750 * 100vw) solid #000;
  }
  #form form#mail_form #agreement .agree_check_label:after {
    width: calc(16 / 750 * 100vw);
    height: calc(32 / 750 * 100vw);
    border-right: calc(5 / 750 * 100vw) solid #fff;
    border-bottom: calc(5 / 750 * 100vw) solid #fff;
    top: calc(6 / 750 * 100vw);
    left: calc(17 / 750 * 100vw);
  }
  #form form#mail_form #agreement #agree_check_check {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
  }
  #form form#mail_form #agreement #agree_check_check:checked ~ .agree_check_label:before {
    background: #75489B;
  }
  #form form#mail_form #agreement #agree_check_check:checked ~ .agree_check_label:after {
    opacity: 1;
  }
  #form form#mail_form .submitBtnWrap .submitBtn:hover {
    -webkit-transform: scale(1);
        -ms-transform: scale(1);
            transform: scale(1);
  }
  #form form#mail_form .submitBtnWrap .submitBtn img {
    width: calc(610 / 750 * 100vw);
  }
}
