@charset "UTF-8";
body {
  font-family: "游ゴシック","Yu Gothic", "Yu Gothic UI",sans-serif;
  font-size: 16px;
  line-height: 1.6;
}

img {
  vertical-align: top;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
}

button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background-color: inherit;
  font: inherit;
  cursor: pointer;
}

#header_sky {
  max-width: 959px;
  width: 100%;
}
#header_sky p.onair {
  right: 0;
  left: auto;
}

.area-bg-01 {
  background: url(../img/bg-grid-01.png) repeat, url(../img/bg-01.png) top center/cover no-repeat;
}
@media screen and (max-width: 767px) {
  .area-bg-01 {
    background-image: url(../img/bg-grid-01.png), url(../img/bg-01_sp.png);
    background-size: 4%, 100%;
  }
}
.area-bg-02 {
  background: url(../img/bg-grid-02.png) repeat, #FEFFB6;
}
@media screen and (max-width: 767px) {
  .area-bg-02 {
    background-size: 4%;
  }
}
.area-bg-03 {
  background: url(../img/bg-02.png) center bottom/contain no-repeat, url(../img/bg-grid-02.png) repeat, #F2F9FC;
}
@media screen and (max-width: 767px) {
  .area-bg-03 {
    background-size: 100%, 4%;
    background-image: url(../img/bg-02_sp.png), url(../img/bg-grid-02.png);
  }
}
.area-bg-05 {
  background: url(../img/bg-grid-02.png) repeat, #FFDFF0;
}
@media screen and (max-width: 767px) {
  .area-bg-05 {
    background-size: 4%;
  }
}
.area-bg-04 {
  position: relative;
  background: url(../img/bg-grid-02.png) repeat, #F4F4F2;
}
@media screen and (max-width: 767px) {
  .area-bg-04 {
    background-size: 4%;
  }
}

.bd-cmn {
  background: #FFFFFF;
  border: 5px solid #000000;
}
@media screen and (max-width: 767px) {
  .bd-cmn {
    border-width: 0.8vw;
  }
}

.f-01 {
  font-family: "Hiragino Kaku Gothic Pro",sans-serif;
}

.ttl {
  text-align: center;
}
.ttl-01 {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  min-width: 83.4%;
}
@media screen and (max-width: 767px) {
  .ttl-01 {
    width: 84vw;
  }
}
.ttl-02 {
  margin-bottom: 90px;
}
@media screen and (max-width: 767px) {
  .ttl-02 {
    margin-bottom: 8vw;
  }
}
.ttl-03 {
  font-size: 26px;
  display: inline-block;
  line-height: 1.6;
  margin-bottom: 1.6em;
}
@media screen and (max-width: 1300px) {
  .ttl-03 {
    font-size: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-03 {
    font-size: 3.4666666667vw;
  }
}
.ttl-03-01 {
  border-bottom: 3px solid #DB769B;
}
.ttl-03-02 {
  border-bottom: 3px solid #FFEC00;
}
.ttl-04 {
  text-align: center;
  margin: 65px 0;
}
@media screen and (max-width: 767px) {
  .ttl-04 {
    margin: 8vw 0;
  }
}
.ttl-05 {
  margin: 0 auto 36px;
}
@media screen and (max-width: 1300px) {
  .ttl-05 {
    max-width: 70.9230769231vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-05 {
    margin-bottom: 1.6vw;
    max-width: none;
  }
}
.ttl-06 img {
  width: 100%;
  max-width: 678px;
}
@media screen and (max-width: 1300px) {
  .ttl-06 img {
    width: 52.1538461538vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-06 img {
    width: 69.3333333333vw;
  }
}

.txt-period {
  margin-top: 1em;
  font-size: 38px;
  margin-bottom: 3.5em;
}
@media screen and (max-width: 1300px) {
  .txt-period {
    font-size: 2.9230769231vw;
  }
}
@media screen and (max-width: 767px) {
  .txt-period {
    font-size: 3.7333333333vw;
  }
}
.txt-c-01 {
  color: #DB769B;
}
.txt-c-02 {
  color: #00A6E6;
}
.txt-dlg p {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.txt-dlg span {
  min-width: 2em;
}
.txt-dlg .letter-2 {
  min-width: 3em;
}
.txt-dlg .letter-3 {
  min-width: 4em;
}
.txt-dlg .s-mt2 {
  margin-top: 1.8em;
}
.txt-dlg .s-mt0 {
  margin-top: 0 !important;
}

.s-txt-l {
  font-size: 30px;
  line-height: 1.6;
}
@media screen and (max-width: 1300px) {
  .s-txt-l {
    font-size: 2.3076923077vw;
  }
}
@media screen and (max-width: 767px) {
  .s-txt-l {
    font-size: 2.9333333333vw;
  }
}

.mod-noscript {
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 20px;
  text-align: center;
  -webkit-box-shadow: 0 1px 8px #CCCCCC;
          box-shadow: 0 1px 8px #CCCCCC;
  font-weight: bold;
  color: #FF0000;
  font-size: 14px;
}

.hero-01 {
  position: relative;
  margin-bottom: 60px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .hero-01 {
    margin-bottom: 9.8666666667vw;
  }
}
.hero-01 .btn-oubo {
  position: absolute;
  right: 16.2%;
  bottom: 9%;
  width: 30.6%;
}
.hero-01 .btn-oubo:hover {
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .hero-01 .btn-oubo {
    width: 35.0666666667vw;
    bottom: 3%;
    right: 9%;
  }
}

.btn {
  display: block;
  margin: auto;
}
.btn img {
  width: 100%;
}
.btn:hover {
  opacity: 0.8;
}
.btn-oubo {
  width: 38.16%;
}
@media screen and (max-width: 767px) {
  .btn-oubo {
    width: 52vw;
  }
}
.btn-nonio {
  width: 35.23%;
}
@media screen and (max-width: 767px) {
  .btn-nonio {
    width: 49.0666666667vw;
  }
}

.box-about {
  width: 82.6%;
  font-size: 21px;
  padding: 1em 2.5em 2em;
  line-height: 2.2;
  text-align: center;
  font-weight: 600;
  margin: auto;
  max-width: 1074px;
}
@media screen and (max-width: 1300px) {
  .box-about {
    font-size: 1.6153846154vw;
  }
}
@media screen and (max-width: 767px) {
  .box-about {
    width: auto;
    margin: 0 4.5333333333vw;
    padding: 0 3.7333333333vw 4vw;
    font-size: 2.4vw;
  }
}
.box-about p {
  margin-top: 2.5em;
}
@media screen and (max-width: 767px) {
  .box-about p {
    margin-top: 1.5em;
  }
}
.box-about-btn {
  font-size: 28px;
  background-color: #F4F4F2;
  max-width: 930px;
  position: relative;
  top: -24px;
  margin: auto;
}
@media screen and (max-width: 1300px) {
  .box-about-btn {
    font-size: 2.1538461538vw;
  }
}
@media screen and (max-width: 767px) {
  .box-about-btn {
    font-size: 2.9333333333vw;
  }
}
.box-about-btn:after {
  position: absolute;
  right: 5%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.box-bg {
  text-align: left;
  padding: 0.2em 1.5em 1.5em;
  margin-top: 2em;
  letter-spacing: 0.1em;
  line-height: 2.4;
  background-color: #F4F4F2;
}
@media screen and (max-width: 767px) {
  .box-bg {
    padding: 1.5em;
    line-height: 2;
  }
  .box-bg p {
    margin-top: 0;
  }
}
.box-nonio {
  font-size: 53px;
  line-height: 1.3;
  padding: 0.8em 0;
  position: relative;
  margin-bottom: 140px;
}
@media screen and (max-width: 1300px) {
  .box-nonio {
    font-size: 4.0151515152vw;
  }
}
@media screen and (max-width: 767px) {
  .box-nonio {
    font-size: 4vw;
    padding: 0.8em 0;
    margin-bottom: 10vw;
  }
}
.box-nonio:after {
  content: "";
  display: block;
  width: 101%;
  height: 13px;
  background: url(../img/bg-pattern.png) repeat-x;
  position: absolute;
  left: -0.5%;
  bottom: -18px;
}
@media screen and (max-width: 1300px) {
  .box-nonio:after {
    background-size: 0.8vw;
  }
}
@media screen and (max-width: 767px) {
  .box-nonio:after {
    height: 1vw;
    bottom: -1.8vw;
    background-size: 1.5vw;
  }
}
.box-copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 2.4;
  font-size: 18px;
  position: relative;
  font-weight: 600;
  padding-bottom: 50px;
  z-index: 1;
}
@media screen and (max-width: 1300px) {
  .box-copy {
    font-size: 1.3846153846vw;
  }
}
@media screen and (max-width: 767px) {
  .box-copy {
    display: block;
    font-size: 2.4vw;
    padding-bottom: 2em;
  }
}
.box-copy-item {
  width: 50%;
  padding: 45px 20px 0 30px;
}
@media screen and (max-width: 1300px) {
  .box-copy-item {
    padding: 45px 1.5384615385vw 0 2.3076923077vw;
  }
}
@media screen and (max-width: 767px) {
  .box-copy-item {
    width: 100%;
    padding: 2.2em 2em 0;
  }
}
.box-copy:before {
  content: "";
  display: block;
  background: url(../img/pin.png) center top/contain no-repeat;
  width: 94px;
  height: 66px;
  position: absolute;
  left: 50%;
  top: 4px;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .box-copy:before {
    width: 12.5333333333vw;
    height: 8.8vw;
    top: -0.2vw;
  }
}
.box-product {
  background: #FFFFFF;
  border-radius: 10px;
  text-align: center;
  padding: 50px;
  margin-bottom: 90px;
}
@media screen and (max-width: 767px) {
  .box-product {
    padding: 6.6666666667vw 9.6vw;
    margin-bottom: 8vw;
  }
}
.box-cd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .box-cd {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 8vw;
  }
}
.box-cd-img {
  font-weight: 600;
  text-align: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 50%;
          flex: 0 50%;
  font-size: 20px;
}
@media screen and (max-width: 1300px) {
  .box-cd-img {
    font-size: 1.5151515152vw;
  }
}
@media screen and (max-width: 767px) {
  .box-cd-img {
    font-size: 1.8666666667vw;
    -ms-flex-preferred-size: 38vw;
        flex-basis: 38vw;
    line-height: 2;
  }
}
.box-cd-img img {
  width: 69%;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .box-cd-img img {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .box-cd-img span {
    display: block;
    font-size: 2.4vw;
  }
}
.box-cd-txt {
  font-size: 22px;
  -webkit-box-flex: 1;
      -ms-flex: 1 auto;
          flex: 1 auto;
  line-height: 1.8;
  font-weight: 500;
}
@media screen and (max-width: 1300px) {
  .box-cd-txt {
    font-size: 1.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .box-cd-txt {
    font-size: 2.4vw;
    padding-left: 2vw;
    -ms-flex-preferred-size: 50vw;
        flex-basis: 50vw;
  }
}
.box-cd-txt p {
  margin-bottom: 1.5em;
}
.box-interview {
  font-size: 22px;
  font-weight: 500;
  padding: 1em 1.5em;
  margin-bottom: 20px;
  line-height: 1.8;
}
@media screen and (max-width: 1300px) {
  .box-interview {
    font-size: 1.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .box-interview {
    font-size: 2.4vw;
    padding: 1em 0;
  }
}
.box-interview p {
  margin: 1.24em 0;
  position: relative;
  padding-left: 3.1em;
}
@media screen and (max-width: 767px) {
  .box-interview p {
    margin: 1.6em 0;
  }
}
.box-interview span {
  display: inline-block;
}
.box-interview .name {
  font-weight: 600;
  position: absolute;
  left: 0;
  top: 0;
}
.box-interview .txt-em {
  font-size: 30px;
  margin-top: 1.5em;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(40%, transparent), color-stop(0%, #E1D500));
  background: linear-gradient(transparent 40%, #E1D500 0%);
  line-height: 1;
  font-weight: 600;
}
@media screen and (max-width: 1300px) {
  .box-interview .txt-em {
    font-size: 2.2727272727vw;
  }
}
@media screen and (max-width: 767px) {
  .box-interview .txt-em {
    font-size: 2.9333333333vw;
  }
}
.box-profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1040px;
  margin: 70px auto 40px;
}
@media screen and (max-width: 767px) {
  .box-profile {
    display: block;
    margin: 6.6666666667vw 0;
  }
}
.box-profile-img {
  margin-right: 6%;
  width: 36.3%;
}
@media screen and (max-width: 767px) {
  .box-profile-img {
    width: 60vw;
    margin: auto;
  }
}
.box-profile-txt {
  width: 57.7%;
  font-size: 17px;
  line-height: 2.2;
  letter-spacing: 0.09em;
  font-weight: 500;
}
@media screen and (max-width: 1300px) {
  .box-profile-txt {
    font-size: 1.2878787879vw;
  }
}
@media screen and (max-width: 767px) {
  .box-profile-txt {
    padding: 2em 4vw 0;
    font-size: 2.4vw;
    width: 100%;
  }
}
.box-profile .txt-profile {
  font-weight: 600;
  font-size: 30px;
  line-height: 1.5;
  margin-bottom: 1em;
}
@media screen and (max-width: 1300px) {
  .box-profile .txt-profile {
    font-size: 2.2727272727vw;
  }
}
@media screen and (max-width: 767px) {
  .box-profile .txt-profile {
    font-size: 2.9333333333vw;
  }
}
.box-step-wrap {
  margin: 20px auto 90px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .box-step-wrap {
    margin: 4vw auto 8vw;
  }
}
.box-step-01 .link-step:before {
  content: "";
  display: block;
}
.box-step-03 .link-step:after {
  content: "";
  display: block;
}

.link-step {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.link-step a {
  width: 48.5%;
}
.link-step a:hover {
  opacity: 0.8;
}

.tips img {
  position: absolute;
  width: 19.3%;
}
.tips-01 img {
  right: 16.4%;
  top: 13%;
}
@media screen and (max-width: 767px) {
  .tips-01 img {
    right: -3%;
    top: 21%;
  }
}
.tips-02 img {
  right: 23%;
  top: -488%;
}
@media screen and (max-width: 767px) {
  .tips-02 img {
    right: 3%;
  }
}
.tips-03 img {
  right: 14%;
  top: 36%;
}
@media screen and (max-width: 767px) {
  .tips-03 img {
    right: -3.5%;
    top: -72%;
  }
}
.tips-04 img {
  right: 8%;
  top: -88%;
}
@media screen and (max-width: 767px) {
  .tips-04 img {
    right: -4%;
    top: -153%;
  }
}
.tips-05 img {
  right: 8%;
  top: -59%;
}
@media screen and (max-width: 767px) {
  .tips-05 img {
    right: -2%;
    top: 0;
  }
}

.entry-lead {
  font-size: 24px;
  text-align: center;
  line-height: 2;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1300px) {
  .entry-lead {
    font-size: 1.8461538462vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-lead {
    font-size: 2.9333333333vw;
  }
}
.entry-lead-note {
  font-size: 75%;
}
.entry-box {
  margin: 175px 0 0;
  padding: 95px 50px 50px;
  position: relative;
}
@media screen and (max-width: 1300px) {
  .entry-box {
    padding: 95px 3.8461538462vw 50px;
  }
}
@media screen and (max-width: 767px) {
  .entry-box {
    padding: 8vw 4vw 5.3333333333vw;
    margin-top: 24vw;
  }
}
.entry-box.s-first {
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  .entry-box.s-first {
    margin-top: 18.6666666667vw;
  }
}
.entry-content {
  background-color: #F9FFDF;
  padding: 30px 28px 10px;
  margin: 40px 0;
  line-height: 2.4;
  font-size: 24px;
}
@media screen and (max-width: 1300px) {
  .entry-content {
    font-size: 1.8461538462vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-content {
    padding: 2.6666666667vw;
    font-size: 2.4vw;
    margin: 5.3333333333vw 0;
  }
}
.entry-num {
  font-size: 54px;
  font-family: "Fira Sans", sans-serif;
  background: #FEFFB6;
  border-radius: 50%;
  text-align: center;
  width: 2.9em;
  height: 2.9em;
  line-height: 1;
  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-weight: 500;
  letter-spacing: -0.02em;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 1300px) {
  .entry-num {
    font-size: 4.1538461538vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-num {
    font-size: 7.2vw;
    -webkit-transform: translate(-50%, -70%);
            transform: translate(-50%, -70%);
  }
}
.entry-num span {
  font-size: 68%;
  font-family: "Bebas Neue", cursive;
  display: block;
  letter-spacing: normal;
}
.entry-name {
  font-size: 28px;
  margin-bottom: 0.2em;
}
@media screen and (max-width: 1300px) {
  .entry-name {
    font-size: 2.1538461538vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-name {
    font-size: 2.6666666667vw;
  }
}
.entry-ttl {
  font-size: 30px;
}
@media screen and (max-width: 1300px) {
  .entry-ttl {
    font-size: 2.3076923077vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-ttl {
    font-size: 2.9333333333vw;
  }
}
.entry-btn {
  position: relative;
  display: block;
  font-size: 28px;
  width: 457px;
  height: 100px;
  margin: 40px auto 0;
  background: url(../img/btn-vote_bg.png) center/contain no-repeat;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .entry-btn {
    width: 42vw;
    height: 10vw;
    font-size: 2.9333333333vw;
    background-image: url(../img/btn-vote_bg_sp.png);
    margin-top: 5.3333333333vw;
  }
}
.entry-btn:disabled {
  cursor: auto;
  opacity: 0.6;
  color: inherit;
  color: #666666;
}
.entry-btn-more {
  text-align: center;
  position: absolute;
  bottom: 17px;
  left: 0;
  right: 0;
  z-index: 1;
  font-size: 0;
  display: block;
  width: 182px;
  height: 121px;
  background: url(../img/btn-close.png) center/contain no-repeat;
  vertical-align: top;
  margin: auto;
}
@media screen and (max-width: 1300px) {
  .entry-btn-more {
    width: 14vw;
    height: 9.3076923077vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-btn-more {
    width: 16.8vw;
    height: 11.2vw;
    bottom: 2vw;
    background-image: url(../img/btn-close_sp.png);
  }
}
.entry-aco-wrap {
  position: relative;
  overflow: hidden;
  background-color: #F9FFDF;
  margin: 40px 0 0;
  font-size: 24px;
  -webkit-transition: height 0.4s ease;
  transition: height 0.4s ease;
}
@media screen and (max-width: 1300px) {
  .entry-aco-wrap {
    font-size: 1.8461538462vw;
  }
}
@media screen and (max-width: 767px) {
  .entry-aco-wrap {
    font-size: 2.4vw;
    margin: 5.3333333333vw 0 0;
  }
}
.entry-aco-wrap:before {
  display: none;
}
.entry-aco {
  padding: 5px 28px 7em;
  line-height: 2;
}
.entry-aco p {
  margin-top: 1em;
}
@media screen and (max-width: 1300px) {
  .entry-aco {
    padding: 5px 2.1538461538vw 7em;
  }
}
@media screen and (max-width: 767px) {
  .entry-aco {
    line-height: 1.6;
    padding: 0.5vw 2.5vw 17vw;
  }
  .entry-aco p {
    margin-top: 1em;
  }
}

.is-hide.entry-aco-wrap {
  height: 19em;
}
@media screen and (max-width: 767px) {
  .is-hide.entry-aco-wrap {
    height: 39.4666666667vw !important;
  }
}
.is-hide.entry-aco-wrap:before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 8.6em;
  z-index: 1;
  background: url(../img/dots.png) top 5% center/auto 19.4% no-repeat, #F9FFDF;
}
@media screen and (max-width: 767px) {
  .is-hide.entry-aco-wrap:before {
    height: 20vw;
    background: url(../img/dots.png) top 2.8vw center/auto 3vw no-repeat, #F9FFDF;
  }
}
.is-hide .entry-btn-more {
  background-image: url(../img/btn-open.png);
}
@media screen and (max-width: 767px) {
  .is-hide .entry-btn-more {
    background-image: url(../img/btn-open_sp.png);
  }
}

.modal-content {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 10;
  overflow: auto;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease-in-out,visibility 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out,visibility 0.3s ease-in-out;
  visibility: hidden;
  overflow: auto;
}
.modal-content.is-show {
  opacity: 1;
  visibility: visible;
}
.modal-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  cursor: pointer;
  z-index: 1;
}
.modal-inner-wrapper {
  padding: 5vmin 12%;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .modal-inner-wrapper {
    padding: 5vmin 6%;
  }
}
.modal-inner {
  text-align: center;
  margin: auto;
  max-width: 1020px;
  background: #FFFFFF;
  padding: 3%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  position: relative;
  z-index: 2;
  min-height: 50vh;
}
.modal-inner-content {
  width: 100%;
  margin: auto;
  font-size: 36px;
  font-weight: 600;
}
@media screen and (max-width: 1300px) {
  .modal-inner-content {
    font-size: 2.7692307692vw;
  }
}
@media screen and (max-width: 767px) {
  .modal-inner-content {
    font-size: 4.8vw;
  }
}
.modal-ttl {
  width: 81.27%;
  margin: 0 auto 1.55em;
}
@media screen and (max-width: 767px) {
  .modal-ttl {
    width: 100%;
  }
}
.modal-close {
  font-size: 28px;
  border: 5px solid #000000;
  padding: 0.5em 1em;
  line-height: 1;
  margin-top: 3.57em;
  background-color: #FFFFFF;
}
@media screen and (max-width: 1300px) {
  .modal-close {
    font-size: 2.1538461538vw;
  }
}
@media screen and (max-width: 767px) {
  .modal-close {
    font-size: 4vw;
    border-width: 0.8vw;
  }
}
.modal-close:hover {
  opacity: 0.8;
}
.modal-close span {
  font-size: 118%;
}

.loading {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  display: none;
}
.loading.is-show {
  display: block;
}
.loading img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 8em;
}

.loader {
  color: #888888;
  margin: auto;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  text-indent: -9999em;
  -webkit-animation: load4 1.3s infinite linear;
          animation: load4 1.3s infinite linear;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  font-size: 10px;
}
@media screen and (max-width: 767px) {
  .loader {
    font-size: 1.5vw;
  }
}
.loader-bg {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  background: rgba(255, 255, 255, 0.4);
}
.loader-bg.is-show {
  display: block;
}

@-webkit-keyframes load4 {
  0%,
	100% {
    -webkit-box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
            box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
  }
  12.5% {
    -webkit-box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  25% {
    -webkit-box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  37.5% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 0, 2em 2em 0 0.2em, 0 3em 0 0, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 0, 2em 2em 0 0.2em, 0 3em 0 0, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  50% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  62.5% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
  }
  75% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0.2em, -2em -2em 0 0;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0.2em, -2em -2em 0 0;
  }
  87.5% {
    -webkit-box-shadow: 0 -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0, -2em -2em 0 0.2em;
            box-shadow: 0 -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0, -2em -2em 0 0.2em;
  }
}

@keyframes load4 {
  0%,
	100% {
    -webkit-box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
            box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
  }
  12.5% {
    -webkit-box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  25% {
    -webkit-box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  37.5% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 0, 2em 2em 0 0.2em, 0 3em 0 0, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 0, 2em 2em 0 0.2em, 0 3em 0 0, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  50% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0 0 -1em, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  62.5% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
  }
  75% {
    -webkit-box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0.2em, -2em -2em 0 0;
            box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0.2em, -2em -2em 0 0;
  }
  87.5% {
    -webkit-box-shadow: 0 -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0, -2em -2em 0 0.2em;
            box-shadow: 0 -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0 0 0, -2em -2em 0 0.2em;
  }
}
.inner {
  max-width: 1300px;
  margin: auto;
  padding: 0 50px;
}
@media screen and (max-width: 1300px) {
  .inner {
    padding: 0 3.8461538462vw;
  }
}
@media screen and (max-width: 767px) {
  .inner {
    padding: 0 4.5333333333vw;
  }
}

.sec-01 {
  padding-bottom: 166px;
}
.sec-01 .inner {
  padding: 0;
  max-width: 1300px;
}
@media screen and (max-width: 767px) {
  .sec-01 {
    padding-bottom: 16vw;
  }
}
.sec-02 {
  position: relative;
  padding: 148px 0 200px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .sec-02 {
    padding: 15.4666666667vw 0;
  }
}
.sec-03 {
  position: relative;
  padding: 216px 0 100px;
  text-align: center;
  font-weight: 600;
}
.sec-03 picture img {
  display: block;
  margin-bottom: 72px;
}
@media screen and (max-width: 767px) {
  .sec-03 picture img {
    margin-bottom: 8vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-03 {
    padding: 18.6666666667vw 0 15.4666666667vw;
  }
}
.sec-04 {
  padding: 90px 0 150px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .sec-04 {
    padding: 8vw 0 12vw;
  }
}
.sec-04 .ttl-02 {
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translate(-50%, -115%);
          transform: translate(-50%, -115%);
  max-width: 903px;
  width: 69.5%;
}
@media screen and (max-width: 767px) {
  .sec-04 .ttl-02 {
    position: relative;
    left: 0;
    -webkit-transform: none;
            transform: none;
    z-index: 1;
    width: 100%;
  }
}
.sec-05 {
  padding: 150px 0 100px;
  position: relative;
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .sec-05 {
    padding: 15.7333333333vw 0 10.6666666667vw;
    margin-bottom: 12vw;
  }
}
.sec-05 .inner {
  padding: 0;
}
@media screen and (max-width: 767px) {
  .sec-05 .inner {
    padding: 0 4.5333333333vw;
  }
}
.sec-06 {
  padding-top: 50px;
}
@media screen and (max-width: 767px) {
  .sec-06 {
    padding-top: 4vw;
  }
}
.sec-06-bg {
  max-width: 1542px;
  margin: auto;
  text-align: center;
}
.sec-06-bg img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .sec-06 .ttl-02 {
    margin-bottom: 0;
  }
}
.sec-07 {
  padding: 30px 0;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .only-pc {
    display: none;
  }
}
.only-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .only-sp {
    display: block;
  }
}

.s-mt-1 {
  margin-top: 1.25em;
}

.mod-aco-02 {
  padding-bottom: 100px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .mod-aco-02 {
    padding-bottom: 13.3333333333vw;
  }
}
.mod-aco-ttl {
  cursor: pointer;
  text-align: center;
  font-size: 28px;
  font-weight: 600;
}
.mod-aco-ttl:after {
  content: "";
  display: block;
  width: 35px;
  height: 24px;
  background: url(../img/arrow.png) center/contain no-repeat;
}
@media screen and (max-width: 767px) {
  .mod-aco-ttl:after {
    width: 4.6666666667vw;
    height: 3.2vw;
  }
}
.mod-aco-ttl-01 {
  font-size: 28px;
  background-color: #F4F4F2;
  position: relative;
  margin-top: 1.5em;
}
@media screen and (max-width: 1300px) {
  .mod-aco-ttl-01 {
    font-size: 2.1538461538vw;
  }
}
@media screen and (max-width: 767px) {
  .mod-aco-ttl-01 {
    font-size: 2.9333333333vw;
  }
}
.mod-aco-ttl-01:after {
  position: absolute;
  right: 5%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .mod-aco-ttl-01:after {
    width: 3.7333333333vw;
    height: 2.56vw;
  }
}
.mod-aco-ttl-01 p {
  margin: 0;
}
.mod-aco-ttl-02 {
  padding: 30px 0;
}
.mod-aco-ttl-02 p {
  margin-bottom: 0.5em;
}
.mod-aco-ttl-02:after {
  margin: auto;
}
@media screen and (max-width: 767px) {
  .mod-aco-ttl-02 {
    padding: 0 0 8vw;
    font-size: 3.2vw;
  }
}
.mod-aco-content {
  display: none;
}

.is-open.mod-aco .mod-aco-ttl-01:after {
  -webkit-transform: rotate(180deg) translateY(50%);
          transform: rotate(180deg) translateY(50%);
}
.is-open.mod-aco .mod-aco-ttl-02:after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.is-open.mod-aco .mod-aco-content {
  opacity: 1;
}
.is-open.mod-aco-02 {
  padding: 0;
}

@-webkit-keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 100%;
  }
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 100%;
  }
}
@-webkit-keyframes fadeout {
  0% {
    opacity: 100%;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeout {
  0% {
    opacity: 100%;
  }
  100% {
    opacity: 0;
  }
}
#js-fade .box-step-cmn {
  -webkit-animation: fadeout 0.15s;
          animation: fadeout 0.15s;
  display: none;
}
#js-fade .box-step-cmn.is-show {
  display: block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  -webkit-animation: fadein 0.15s;
          animation: fadein 0.15s;
}

.p-01 .txt-period {
  font-size: 33px;
  margin-bottom: 0;
}
@media screen and (max-width: 1300px) {
  .p-01 .txt-period {
    font-size: 2.5384615385vw;
  }
}
@media screen and (max-width: 767px) {
  .p-01 .txt-period {
    font-size: 3.4666666667vw;
  }
}

.p-03 .entry-lead {
  font-size: 40px;
  line-height: 1.4;
  margin-top: 1em;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 1300px) {
  .p-03 .entry-lead {
    font-size: 3.0769230769vw;
  }
}
@media screen and (max-width: 767px) {
  .p-03 .entry-lead {
    font-size: 3.4666666667vw;
  }
}
.p-03 .entry-box.s-first {
  margin-bottom: 115px;
}
@media screen and (max-width: 767px) {
  .p-03 .entry-box.s-first {
    margin-bottom: 16vw;
  }
}

/*# sourceMappingURL=style.css.map */