@charset "UTF-8";
body {
  font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", sans-serif;
}

body#top article section .inner {
  padding: 0 15px;
}

body#top article section .inner h2.type_10 {
  font-size: 19px;
  font-weight: normal;
  text-align: center;
  line-height: 1.578;
  letter-spacing: 0.1em;
  position: relative;
  padding-bottom: 10px;
}

body#top article section .inner h2.type_10:before {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  content: '';
  width: 50px;
  height: 1px;
  background: #019abc;
}

body#top article section .inner h2.type_20 {
  line-height: 1;
  text-align: center;
  margin-bottom: 23.5px;
}

body#top article section .inner h2.type_20 .colorful {
  font-family: 'Josefin Sans', sans-serif;
  font-size: 50px;
}

body#top article section .inner h2.type_20 .colorful span:nth-child(5n+1) {
  color: #5dcfce;
}

body#top article section .inner h2.type_20 .colorful span:nth-child(5n+2) {
  color: #b6d6dd;
}

body#top article section .inner h2.type_20 .colorful span:nth-child(5n+3) {
  color: #88bdc9;
}

body#top article section .inner h2.type_20 .colorful span:nth-child(5n+4) {
  color: #94d9e8;
}

body#top article section .inner h2.type_20 .colorful span:nth-child(5n+5) {
  color: #bde2f3;
}

body#top article section .inner h2.type_20 .sub {
  display: block;
  margin-top: 10px;
  font-size: 19px;
  letter-spacing: 0.1em;
  font-weight: normal;
}

body#top article section .inner h3 {
  font-size: 19px;
  text-align: center;
  font-weight: normal;
  line-height: 1.578;
  letter-spacing: 0.01em;
}

body#top article section .inner > * {
  color: #444444;
}

body#top article section .inner p {
  font-size: 14px;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.01em;
  line-height: 1.857;
}

body#top article section.mv {
  background: url(../img/mv.jpg) no-repeat;
  background-size: contain;
  height: 116.00vw;
  position: relative;
}

body#top article section.mv .inner {
  padding: unset;
  position: absolute;
  bottom: 25px;
  left: 30px;
  -webkit-font-smoothing: antialiased;
}

body#top article section.mv .inner h1 {
  font-size: 23px;
  line-height: 1.304;
  letter-spacing: 0.1em;
  font-weight: normal;
  color: #fff;
}

body#top article section.mv .inner p {
  margin-top: 10px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #fff;
}

body#top article section.sec10 {
  position: relative;
  padding-bottom: 3.5vw;
  margin-bottom: 13.47vw;
}

body#top article section.sec10:before {
  position: absolute;
  content: '';
  background: url(../img/wave_bg.png) no-repeat;
  background-size: cover;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8vw;
}

body#top article section.sec10 .inner {
  padding: 12.67vw 15px 6.93vw;
  background: #b6d6dd;
}

body#top article section.sec10 .inner img {
  max-width: 68.67vw;
  width: 100%;
  display: block;
  margin: 25px auto;
}

body#top article section.sec20 .inner {
  padding: .8vw 15px 11vw;
}

body#top article section.sec20 .inner .tag_list {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 23.5px 0 25px;
}

body#top article section.sec20 .inner .tag_list li {
  width: 105px;
  height: 30px;
  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;
  font-size: 13px;
  margin-bottom: 10px;
  border-radius: 15px;
  line-height: 1;
}

body#top article section.sec20 .inner .tag_list li:nth-child(5n+1) {
  background: #5dcfce;
}

body#top article section.sec20 .inner .tag_list li:nth-child(5n+2) {
  background: #b6d6dd;
}

body#top article section.sec20 .inner .tag_list li:nth-child(5n+3) {
  background: #94d9e8;
}

body#top article section.sec20 .inner .tag_list li:nth-child(5n+4) {
  background: #94d9e8;
}

body#top article section.sec20 .inner .tag_list li:nth-child(5n+5) {
  background: #bde2f3;
}

body#top article section.sec20 .inner .concept {
  border: 1px solid #dedede;
  border-radius: 10px;
  width: 100%;
  padding: 25px 15px;
  margin-bottom: 13.33vw;
}

body#top article section.sec20 .inner .concept h4 {
  font-family: 'Josefin Sans', sans-serif;
  font-size: 20px;
  margin-bottom: 10px;
}

body#top article section.sec20 .inner .concept p {
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.857;
}

body#top article section.sec20 img {
  width: 100%;
  display: block;
  margin: 0 0 6.67vw;
}

body#top article section.sec20 img + .inner {
  padding: 0 15px;
}

body#top article section.sec20 .gallery > * {
  color: #444;
}

body#top article section.sec20 .gallery img {
  border-radius: 10px;
  margin: 0;
}

body#top article section.sec20 .gallery .txt p {
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.857;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

body#top article section.sec20 .gallery .type_10 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

body#top article section.sec20 .gallery .type_10 img {
  border-radius: 0 10px 10px 0;
  width: 44.00vw;
  height: 72.00vw;
  -o-object-fit: contain;
     object-fit: contain;
}

body#top article section.sec20 .gallery .type_10 .txt {
  padding: 6.67vw 20px 0;
  padding-left: 6.00vw;
}

body#top article section.sec20 .gallery .type_20 {
  margin-top: 9.33vw;
  padding: 0px 15px;
}

body#top article section.sec20 .gallery .type_20 img {
  width: 100%;
}

body#top article section.sec20 .gallery .type_20 .txt {
  margin-top: 4.67vw;
}

body#top article section.sec20 .gallery .type_30 {
  margin-top: 9.33vw;
}

body#top article section.sec20 .gallery .type_30 .txt {
  position: relative;
  min-height: 65.33vw;
}

body#top article section.sec20 .gallery .type_30 .txt p {
  width: 56vw;
  margin-left: 44vw;
  padding-top: 6.67vw;
  padding-left: 6vw;
  padding-right: 18px;
}

body#top article section.sec20 .gallery .type_30 .txt img {
  position: absolute;
  left: 0;
  top: 0;
  border-radius: 0 10px 10px 0;
  width: 44.00vw;
}

body#top article section.sec20 .gallery .type_30 .txt.reverse {
  height: 80.00vw;
}

body#top article section.sec20 .gallery .type_30 .txt.reverse p {
  margin-left: unset;
  margin-right: 44vw;
  padding-top: 14.00vw;
  padding-right: 3vw;
  padding-left: 20px;
}

body#top article section.sec20 .gallery .type_30 .txt.reverse img {
  right: 0;
  left: unset;
  border-radius: 10px 0 0 10px;
}

body#top article section.sec20 .gallery .type_30 + .type_20 {
  margin-top: 15.33vw;
}

body#top article section.sec20 .gallery .type_30 + .type_20 + .type_30 + .type_20 {
  margin-top: 2vw;
}

body#top article section.sec30 {
  background: url(../img/wave_bg_20.png) no-repeat top 5px right 0, url(../img/wave_bg_20.png) no-repeat bottom 5px right 0;
  background-size: contain;
  margin: 15vw 0 13.33vw;
  padding: 25px 0;
}

body#top article section.sec30 .inner {
  background: #009cbf;
  padding: 5.87vw 15px 10.00vw;
}

body#top article section.sec30 .inner h2 {
  color: #fff;
  -webkit-font-smoothing: antialiased;
  font-weight: normal;
  text-align: center;
  font-size: 19px;
  letter-spacing: 0.1em;
  line-height: 1.578;
  margin-bottom: 30px;
  background: url(../img/cta_h2_bg.png) no-repeat center;
  background-size: contain;
}

body#top article section.sec30 .inner a.cta {
  display: block;
  background: #fff;
  border: 5px solid #000;
  border-radius: 5px;
  padding-top: 6.27vw;
  text-decoration: none;
  height: 86.67vw;
  position: relative;
}

body#top article section.sec30 .inner a.cta .group .yellow {
  background: #fffc27;
  width: 49vw;
  height: 7.47vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 1;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 14px;
  color: #000;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin: 0 auto 9px;
  padding-left: 7px;
  padding-top: 3px;
}

body#top article section.sec30 .inner a.cta .group b {
  font-size: 23px;
  letter-spacing: 0.1em;
  line-height: 1;
  margin-bottom: 8.5px;
  text-align: center;
  display: block;
  padding-left: 10px;
}

body#top article section.sec30 .inner a.cta .group b .blue {
  color: #009cbf;
}

body#top article section.sec30 .inner a.cta .group img {
  width: 39.60vw;
  display: block;
  margin: 0 auto 5px;
}

body#top article section.sec30 .inner a.cta .group .txt {
  width: 79.93vw;
  display: block;
  margin: 0 auto;
  font-size: 12.5px;
  line-height: 1.6;
}

body#top article section.sec30 .inner a.cta .group .black {
  position: absolute;
  bottom: -5px;
  background: #000;
  font-size: 16px;
  letter-spacing: 0.1em;
  line-height: 1;
  font-weight: bold;
  width: 100%;
  height: 50px;
  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;
  color: #fff;
  border-radius: 0 0 5px 5px;
  -webkit-font-smoothing: antialiased;
}

body#top article section.sec30 .inner a.cta .group .black:before {
  position: absolute;
  content: '';
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 15px;
  background: url(../img/arrow.png) no-repeat;
  background-size: cover;
  width: 7.5px;
  height: 12.5px;
}

body#top article section.sec40 .customer_date {
  border: #dedede solid 1px;
  border-radius: 5px;
  max-width: 250px;
  width: 100%;
  height: 33px;
  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;
  font-size: 12px;
  line-height: 1;
  margin: 0 auto 5.73vw;
}

body#top article section.sec40 .question {
  margin: 13.33vw 0 9.33vw;
  background: #b6d6dd;
  position: relative;
  padding: 3.93vw 5vw;
  padding-left: 16.13vw;
  font-size: 19px;
  letter-spacing: 0.1em;
  line-height: 1.578;
  color: #444;
  font-weight: normal;
}

body#top article section.sec40 .question:before {
  position: absolute;
  content: 'Q';
  line-height: 1;
  color: #009cbf;
  font-size: 24px;
  font-family: 'Josefin Sans', sans-serif;
  width: 35px;
  height: 35px;
  background: #fff;
  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;
  border-radius: 50%;
  padding-top: 5px;
  top: 3.93vw;
  left: 15px;
}

body#top article section.sec40 .inner img {
  width: 100%;
  margin-top: 8.67vw;
}

body#top article section.sec40 .inner img + p {
  margin-top: 8.67vw;
}

body#top #for_top {
  width: 50px;
  height: 50px;
  background: #b6d6dd;
  border-radius: 50%;
  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;
  position: fixed;
  bottom: 33.33vw;
  right: 15px;
  opacity: 0;
  -webkit-transition-duration: 0.5s;
          transition-duration: 0.5s;
}

body#top #for_top img {
  width: 12.5px;
  height: 7.5px;
}

body#top #float_cta {
  width: 100%;
  height: 60px;
  background: #ff6920;
  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;
  position: fixed;
  bottom: 0;
  right: 0;
  opacity: 0;
  -webkit-transition-duration: 0.5s;
          transition-duration: 0.5s;
  color: #fff;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-decoration: unset;
}

body#top #float_cta:before {
  position: absolute;
  top: 47%;
  right: 15px;
  display: block;
  width: 10px;
  height: 10px;
  content: '';
  -webkit-transform: rotate(-45deg) translateY(-50%);
          transform: rotate(-45deg) translateY(-50%);
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
}

body#top #float_cta span.flex {
  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;
  line-height: 1;
}

body#top #float_cta span.flex span {
  background: #fff;
  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;
  width: 25px;
  height: 25px;
  color: #ff6920;
}

body#top #float_cta span.flex span:first-child {
  margin-right: 5px;
}

body#top #float_cta span.flex span:last-child {
  margin-right: 10px;
}

body#top footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 150px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

body#top footer p {
  line-height: 1;
  font-family: 'Josefin Sans', sans-serif;
  color: #000000;
  font-size: 10px;
  letter-spacing: 0.1em;
}

body.Android .sec30 {
  background: url(../img/wave_bg_20.png) no-repeat top 6px right 0, url(../img/wave_bg_20.png) no-repeat bottom 6px right 0 !important;
  background-size: contain !important;
}

body.Android .sec30 .inner a.cta {
  height: 92.67vw !important;
}

body.Android .sec30 .inner a.cta .group b {
  letter-spacing: 0 !important;
}
/*# sourceMappingURL=style.css.map */