.l-mv {
  position: relative;
  overflow: hidden;
}
.l-mv img {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.l-mv .site-ttl {
  width: 50.9%;
  position: absolute;
  top: 47%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 821px) {
  .l-mv .site-ttl {
    width: 92%;
  }
}
.l-mv .txt {
  position: absolute;
}
.l-mv .txt.txt01 {
  width: 16.66666%;
  top: 14.45%;
  left: 13.67%;
}
@media screen and (max-width: 821px) {
  .l-mv .txt.txt01 {
    top: 12.45%;
    width: 34.66666%;
    left: 4%;
  }
}
.l-mv .txt.txt02 {
  top: 8.22%;
  right: 15.82%;
  width: 20.67%;
}
@media screen and (max-width: 821px) {
  .l-mv .txt.txt02 {
    top: 12.22%;
    right: 4%;
    width: 35.67%;
  }
}
.l-mv .geinin {
  position: absolute;
}
.l-mv .geinin.geinin01 {
  width: 4.4%;
  left: 9.1%;
  bottom: 29%;
}
@media screen and (max-width: 821px) {
  .l-mv .geinin.geinin01 {
    width: 12%;
    left: 9.1%;
    bottom: 9%;
    z-index: 99;
  }
}
.l-mv .geinin.geinin02 {
  width: 5.7%;
  bottom: 11.6%;
  left: 21.7%;
}
@media screen and (max-width: 821px) {
  .l-mv .geinin.geinin02 {
    width: 12%;
    bottom: 15.6%;
    left: 26.7%;
  }
}
.l-mv .geinin.geinin03 {
  width: 5.5%;
  left: 37.1%;
  bottom: 0.8%;
}
@media screen and (max-width: 821px) {
  .l-mv .geinin.geinin03 {
    width: 12%;
    left: 48.1%;
    bottom: 7.8%;
    z-index: 99;
  }
}
.l-mv .geinin.geinin04 {
  width: 5.79%;
  right: 25.3%;
  bottom: 6.8%;
}
@media screen and (max-width: 821px) {
  .l-mv .geinin.geinin04 {
    width: 12%;
    right: 13.3%;
    bottom: 13.8%;
  }
}
.l-mv .fruit {
  position: absolute;
  left: 23.56%;
  width: 24.47%;
  bottom: -8.8%;
}
@media screen and (max-width: 821px) {
  .l-mv .fruit {
    width: 100%;
    bottom: 0;
    left: 0;
  }
}

.p-intro {
  padding: 60px 0 140px 0;
  background-color: #fffcf3;
}
@media screen and (max-width: 821px) {
  .p-intro {
    padding: 60px 0 42px 0;
  }
}
.p-intro .container {
  position: relative;
}
.p-intro .geinin01 {
  position: absolute;
  width: 226px;
  top: 100px;
  left: -50px;
}
@media screen and (max-width: 821px) {
  .p-intro .geinin01 {
    width: 137px;
    top: -56px;
    left: 20px;
  }
}
.p-intro .geinin02 {
  position: absolute;
  width: 241px;
  right: 34px;
  bottom: -50px;
}
@media screen and (max-width: 821px) {
  .p-intro .geinin02 {
    width: 170px;
    right: 22px;
    bottom: -75px;
  }
}
.p-intro .fruit01 {
  position: absolute;
  width: 250px;
  top: -10px;
  right: -30px;
}
@media screen and (max-width: 821px) {
  .p-intro .fruit01 {
    width: 120px;
    top: -50px;
    right: -30px;
  }
}
.p-intro .fruit02 {
  position: absolute;
  width: 201px;
  top: 410px;
  right: 0;
}
@media screen and (max-width: 821px) {
  .p-intro .fruit02 {
    width: 100px;
    top: 428px;
    right: -22px;
  }
}
.p-intro .fruit03 {
  position: absolute;
  width: 331px;
  bottom: -85px;
  left: -62px;
}
@media screen and (max-width: 821px) {
  .p-intro .fruit03 {
    width: 180px;
    bottom: -96px;
  }
}
.p-intro__ttl {
  max-width: 546px;
  margin: 0 auto;
}
.p-intro__txt {
  text-align: center;
  font-size: 21px;
  font-weight: bold;
  margin-top: 30px;
  letter-spacing: 0.14em;
  line-height: 1.85714286;
}
@media screen and (max-width: 821px) {
  .p-intro__txt {
    font-size: 18px;
    line-height: 1.72222222;
    letter-spacing: 0.06em;
  }
}
.p-intro__txt strong {
  color: #e10022;
}
.p-intro__box {
  max-width: 816px;
  margin: 40px auto 0;
  padding: 40px 70px;
  text-align: center;
  border-radius: 18px;
  background: #e10022 url(../img/top/bg_box.png) no-repeat center/255px;
}
@media screen and (max-width: 821px) {
  .p-intro__box {
    padding: 35px 25px;
  }
}
.p-intro__box p {
  font-size: 20px;
  letter-spacing: 0.1em;
  line-height: 1.727;
  font-weight: 500;
  color: #fff;
}
@media screen and (max-width: 821px) {
  .p-intro__box p {
    font-size: 19px;
    line-height: 1.63157895;
  }
}
.p-intro__box p:last-of-type {
  margin-top: 24px;
}
.p-intro__box .txt01 img {
  max-width: 540px;
  display: inline-block;
  margin-right: 10px;
}
@media screen and (max-width: 821px) {
  .p-intro__box .txt01 img {
    max-width: 288px;
    display: block;
    margin: 0 auto;
  }
}
.p-intro__box .txt02 {
  margin-top: 12px;
}
@media screen and (max-width: 821px) {
  .p-intro__box .txt02 {
    margin-top: 5px;
  }
}
.p-intro__box .txt03 {
  margin-top: 12px;
}
.p-intro__box .line {
  max-width: 413px;
  margin: 12px auto 0;
}
@media screen and (max-width: 821px) {
  .p-intro__box .line {
    margin: 10px auto 0;
  }
}

.p-brand {
  padding: 140px 0 120px 0;
}
@media screen and (max-width: 821px) {
  .p-brand {
    padding: 70px 0 60px 0;
  }
}
.p-brand__list li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}
@media screen and (max-width: 821px) {
  .p-brand__list li {
    display: block;
  }
}
.p-brand__list li:not(:last-of-type) {
  margin-bottom: 50px;
}
@media screen and (max-width: 821px) {
  .p-brand__list li:not(:last-of-type) {
    margin-bottom: 46px;
  }
}
.p-brand__list li .logo-wrap {
  width: 27%;
}
@media screen and (max-width: 821px) {
  .p-brand__list li .logo-wrap {
    width: 100%;
  }
}
.p-brand__list li .txt-wrap {
  width: 71%;
  padding: 40px 30px;
  background-color: #f2f2f2;
  border-radius: 18px;
}
@media screen and (max-width: 821px) {
  .p-brand__list li .txt-wrap {
    margin-top: 20px;
    width: 100%;
    padding: 34px 15px;
  }
}
.p-brand__list li h3 {
  font-weight: bold;
  letter-spacing: 0.12em;
  line-height: 1.51724138;
  font-size: 29px;
  padding-bottom: 15px;
  border-bottom: 2px solid #fff;
}
@media screen and (max-width: 821px) {
  .p-brand__list li h3 {
    line-height: 1.52380952;
    font-size: 21px;
  }
}
.p-brand__list li p {
  font-size: 16px;
  padding-top: 15px;
  letter-spacing: 0.08em;
  line-height: 1.5925;
}
@media screen and (max-width: 821px) {
  .p-brand__list li p {
    line-height: 1.8125;
  }
}
.p-brand__list li:nth-of-type(1) h3 {
  color: #e10022;
}
.p-brand__list li:nth-of-type(1) .logo-wrap img {
  width: 238px;
}
.p-brand__list li:nth-of-type(2) h3 {
  color: #1dab1e;
}
.p-brand__list li:nth-of-type(2) .logo-wrap img {
  width: 276px;
}
.p-brand__list li:nth-of-type(3) h3 {
  color: #00b7e7;
}
.p-brand__list li:nth-of-type(3) .logo-wrap img {
  width: 137px;
}

.p-campaign .ttl-wrap {
  position: relative;
}
.p-campaign .ttl-wrap .bg {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.p-campaign .ttl-wrap .cloud {
  position: absolute;
  left: 0;
  bottom: 0;
}
.p-campaign .ttl-wrap .fruit01 {
  width: 250px;
  right: -35px;
  top: -86px;
}
@media screen and (max-width: 821px) {
  .p-campaign .ttl-wrap .fruit01 {
    width: 156px;
    top: -60px;
  }
}
.p-campaign .ttl-wrap .fruit02 {
  width: 223px;
  left: -60px;
  bottom: 184px;
}
@media screen and (max-width: 821px) {
  .p-campaign .ttl-wrap .fruit02 {
    width: 96px;
    left: -33px;
    bottom: auto;
    top: 30px;
  }
}
.p-campaign .fruit {
  position: absolute;
}
.p-campaign__ttl {
  max-width: 800px;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 9;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 821px) {
  .p-campaign__ttl {
    max-width: 550px;
    width: 92%;
    top: 52%;
  }
}
.p-campaign .vote-wrap {
  position: relative;
  z-index: 99;
}
.p-campaign .container {
  max-width: 1060px;
  position: relative;
  z-index: 99;
  background-color: #fff;
}
@media screen and (max-width: 821px) {
  .p-campaign .container {
    background-color: #e10022;
  }
}
@media screen and (max-width: 821px) {
  .p-campaign .container .inner-bg {
    padding: 0 24px;
    background-color: #fff;
  }
}
.p-campaign .award-wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  position: relative;
  z-index: 99;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap {
    display: block;
    padding-bottom: 60px;
  }
}
.p-campaign .award-wrap .box {
  width: 50%;
  position: relative;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box {
    width: 100%;
  }
}
.p-campaign .award-wrap .box .geinin {
  position: absolute;
}
.p-campaign .award-wrap .box .geinin01 {
  left: 100px;
  bottom: 60px;
  width: 111px;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box .geinin01 {
    width: 58px;
    bottom: auto;
    top: 20px;
    left: 0;
  }
}
.p-campaign .award-wrap .box .geinin02 {
  right: 100px;
  bottom: 60px;
  width: 102px;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box .geinin02 {
    width: 58px;
    bottom: auto;
    top: 20px;
    right: 0;
  }
}
.p-campaign .award-wrap .box .geinin03 {
  width: 94px;
  top: 0;
  right: 30px;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box .geinin03 {
    width: 60px;
    right: 0;
  }
}
.p-campaign .award-wrap .box .geinin04 {
  width: 74px;
  bottom: 20px;
  left: 60px;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box .geinin04 {
    bottom: auto;
    left: 0px;
    top: 0;
    width: 50px;
  }
}
.p-campaign .award-wrap .box.award-a {
  padding-bottom: 56px;
  width: 100%;
  border-bottom: 1px solid #ede7ca;
  margin-bottom: 50px;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box.award-a {
    padding-bottom: 40px;
    margin-bottom: 40px;
  }
}
.p-campaign .award-wrap .box.award-a .ttl-award {
  max-width: 695px;
  margin: 85px auto 0;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box.award-a .ttl-award {
    position: relative;
    margin-top: 20px;
    max-width: 280px;
  }
}
.p-campaign .award-wrap .box.award-a .img {
  max-width: 483px;
  margin: 24px auto 0;
}
.p-campaign .award-wrap .box.award-a .img img {
  -webkit-filter: drop-shadow(0 0 6px rgba(145, 103, 0, 0.2));
          filter: drop-shadow(0 0 6px rgba(145, 103, 0, 0.2));
}
.p-campaign .award-wrap .box.award-b {
  border-right: 1px solid #ede7ca;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box.award-b {
    border-bottom: 1px solid #ede7ca;
    border-right: none;
    padding-bottom: 40px;
    margin-bottom: 40px;
  }
}
.p-campaign .award-wrap .box.award-b .ttl-award {
  max-width: 405px;
  margin: 0 auto;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box.award-b .ttl-award {
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
}
.p-campaign .award-wrap .box.award-b .img {
  max-width: 414px;
  margin: 0 auto;
}
.p-campaign .award-wrap .box.award-c .ttl-award {
  max-width: 341px;
  margin: 0 auto;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box.award-c .ttl-award {
    max-width: 270px;
  }
}
.p-campaign .award-wrap .box.award-c .img {
  max-width: 305px;
  -webkit-transform: translateX(70px);
          transform: translateX(70px);
  margin: 46px auto 0;
}
@media screen and (max-width: 821px) {
  .p-campaign .award-wrap .box.award-c .img {
    max-width: 235px;
    margin-top: 20px;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
.p-campaign .award-wrap .fruit03 {
  width: 201px;
  left: -240px;
  top: 300px;
}
.p-campaign .award-wrap .fruit04 {
  width: 168px;
  right: -250px;
  top: 490px;
}
.p-campaign .award-wrap .fruit05 {
  width: 225px;
  left: -300px;
  bottom: -50px;
}
.p-campaign .award-wrap .fruit06 {
  width: 205px;
  right: -310px;
  bottom: -100px;
}

.p-flow {
  padding: 75px 0 100px 0;
  position: relative;
}
@media screen and (max-width: 821px) {
  .p-flow {
    padding: 60px 0 34px;
    z-index: 99;
  }
}
.p-flow__ttl {
  max-width: 420px;
  margin: 0 auto;
}
@media screen and (max-width: 821px) {
  .p-flow__ttl {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%) translateY(-71%);
            transform: translateX(-50%) translateY(-71%);
    top: 0;
    width: 266px;
  }
}
.p-flow__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 38px;
}
@media screen and (max-width: 821px) {
  .p-flow__list {
    display: block;
  }
}
.p-flow__list li {
  width: 28%;
  height: 571px;
  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-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 821px) {
  .p-flow__list li {
    width: 100% !important;
    display: block;
    height: auto;
  }
}
.p-flow__list li:last-of-type {
  width: 44%;
}
@media screen and (max-width: 821px) {
  .p-flow__list li:last-of-type .img {
    margin-top: 30px;
  }
}
@media screen and (max-width: 821px) {
  .p-flow__list li:not(:last-of-type) {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 821px) {
  .p-flow__list li:nth-of-type(2) .img {
    margin-top: 40px;
  }
}
.p-flow__list li h3 {
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  background-color: #e10022;
  border-radius: 50%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 48px;
  height: 48px;
  margin: 0 auto;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 821px) {
  .p-flow__list li h3 {
    font-size: 20px;
    width: 38px;
    height: 38px;
  }
}
.p-flow__list li .txt {
  text-align: center;
  font-size: 23px;
  letter-spacing: 0.08em;
  line-height: 1.54826087;
  color: #e10022;
  font-weight: bold;
  white-space: nowrap;
  position: relative;
}
@media screen and (max-width: 821px) {
  .p-flow__list li .txt {
    font-size: 20px;
    line-height: 1.35;
    margin-top: 10px;
  }
}
.p-flow__list li .txt img {
  width: 220px;
  vertical-align: middle;
  display: inline-block;
  margin-right: 6px;
}
@media screen and (max-width: 821px) {
  .p-flow__list li .txt img {
    margin-right: 0;
    margin: 6px 0;
    width: 210px;
  }
}
.p-flow__list li .notion {
  position: absolute;
  bottom: -22px;
  letter-spacing: 0.05em;
  font-size: 14px;
  line-height: 1;
  text-align: center;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: block;
}
@media screen and (max-width: 821px) {
  .p-flow__list li .notion {
    font-size: 12px;
    bottom: -22px;
  }
}
.p-flow__list li .img {
  margin-top: 30px;
}
@media screen and (max-width: 821px) {
  .p-flow__list li .img {
    margin-top: 15px;
  }
}
.p-flow__list li .img img {
  display: block;
  width: auto;
  height: 400px;
  margin: 0 auto;
}
@media screen and (max-width: 821px) {
  .p-flow__list li .img img {
    height: 255px;
  }
}
.p-flow__note {
  text-align: center;
  font-size: 16px;
  font-weight: 500;
  text-align: center;
  color: #e10022;
  margin-top: 35px;
  line-height: 1.75;
}
@media screen and (max-width: 821px) {
  .p-flow__note {
    text-align: left;
    line-height: 1.5;
  }
}
.p-flow .fruit {
  position: absolute;
}
.p-flow .fruit01 {
  left: -69px;
  top: 100px;
  width: 192px;
}
@media screen and (max-width: 821px) {
  .p-flow .fruit01 {
    left: -43px;
    top: -117px;
    width: 112px;
  }
}
.p-flow .fruit02 {
  bottom: 120px;
  right: -190px;
  width: 227px;
}
@media screen and (max-width: 821px) {
  .p-flow .fruit02 {
    bottom: auto;
    right: -68px;
    top: -190px;
    width: 143px;
  }
}
.p-flow .fruit03 {
  width: 184px;
  bottom: -100px;
  left: -46px;
}
@media screen and (max-width: 821px) {
  .p-flow .fruit03 {
    width: 94px;
    bottom: -144px;
    left: -30px;
  }
}

.p-check .list-category .show-all {
  display: none;
}
.p-check .area #show-all {
  display: none;
}

@media screen and (min-width: 822px) {
  .p-check .area .ttl-area + .btn-all {
    display: none;
  }
}/*# sourceMappingURL=top.css.map */