@charset "UTF-8";
#content {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  color: #333333;
}
@media (max-width: 767px) {
  #content .pc_only {
    display: none !important;
  }
}
@media (min-width: 768px) {
  #content {
    font-size: 16px;
  }
  #content .sp_only {
    display: none !important;
  }
}
@media (min-width: 768px) and (max-width: 1279px) {
  #content {
    font-size: 1.25vw;
  }
}
#content img {
  max-width: 100%;
}
#content a {
  text-decoration: none;
  transition: opacity 0.3s;
}
#content a:hover {
  opacity: 0.7;
}
@media (min-width: 768px) {
  #content .inner-1120 {
    max-width: 1120px;
    width: calc(100% - 152px);
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 767px) {
  #content .inner-sp {
    padding-left: 15px;
    padding-right: 15px;
  }
}
#content .kv {
  background: url("../img/bg01.png");
  padding: 70px 40px 108px;
}
@media (max-width: 767px) {
  #content .kv {
    background-size: 125px;
    padding: 40px 15px 80px;
  }
}
#content .kv .kv-img {
  display: block;
  margin: 0 auto 52px;
  max-width: 100%;
}
@media (max-width: 767px) {
  #content .kv .kv-img {
    width: 358px;
    margin-bottom: 31px;
  }
}
#content .kv .txt-container {
  width: 840px;
  max-width: 100%;
  background: rgba(255, 255, 255, 0.6);
  margin: 0 auto;
  text-align: center;
  padding: 46px;
  border-radius: 20px;
}
@media (max-width: 767px) {
  #content .kv .txt-container {
    width: 345px;
    border-radius: 10px;
    padding: 23px 10px;
  }
}
#content .kv .txt-container p {
  font-size: 1.125rem;
  line-height: 2;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  #content .kv .txt-container p {
    font-size: 0.875rem;
    line-height: 1.625rem;
    letter-spacing: 0.05em;
  }
}
#content .kv .txt-container p:not(:last-child) {
  margin-bottom: 1.125rem;
}
@media (max-width: 767px) {
  #content .kv .txt-container p:not(:last-child) {
    margin-bottom: 1.625rem;
  }
}
#content .present-section {
  position: relative;
  padding: 50px 0 75px;
}
@media (max-width: 767px) {
  #content .present-section {
    padding: 35px 0 48px;
  }
}
#content .present-section:before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 29px;
  left: 0;
  bottom: 100%;
  background: url("../img/white-wave-top@2x.png");
  background-repeat: repeat-x;
  background-size: 146px;
  background-position: center bottom;
}
@media (max-width: 767px) {
  #content .present-section:before {
    height: 15px;
    background-size: 73px;
  }
}
#content .present-section:after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 29px;
  left: 0;
  top: 100%;
  background: url("../img/white-wave-bottom@2x.png");
  background-repeat: repeat-x;
  background-size: 146px;
  background-position: center top;
}
@media (max-width: 767px) {
  #content .present-section:after {
    height: 15px;
    background-size: 73px;
  }
}
#content .present-section .img-present {
  display: block;
  margin: 0 auto 20px;
}
@media (max-width: 767px) {
  #content .present-section .img-present {
    width: 114px;
    margin-bottom: 24px;
  }
}
#content .present-section p {
  text-align: center;
  font-weight: bold;
  font-size: 1.125rem;
  line-height: 2;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  #content .present-section p {
    font-size: 0.875rem;
    line-height: 1.625rem;
    letter-spacing: 0.05em;
  }
}
#content .present-section p.lrg-txt {
  font-size: 1.875rem;
  margin-top: 10px;
}
@media (max-width: 767px) {
  #content .present-section p.lrg-txt {
    font-size: 1.25rem;
    line-height: 1.875rem;
  }
}
#content .quiz-section {
  background: url("../img/bg02.png");
  padding: 130px 0 113px;
}
@media (max-width: 767px) {
  #content .quiz-section {
    background-size: 125px;
    padding: 78px 0 64px;
  }
}
#content .quiz-section .quiz-section-inner {
  background: #FFF;
  border-radius: 30px;
  position: relative;
  padding: 108px 80px 58px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner {
    padding: 56px 15px 49px;
  }
}
#content .quiz-section .quiz-section-inner .quiz-ttl {
  display: block;
  position: absolute;
  top: -47px;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner .quiz-ttl {
    width: 162px;
    top: -29px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-question {
  display: block;
  margin: 0 auto 39px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-question {
    width: 273px;
    margin-bottom: 30px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-answer {
  display: block;
  margin: 0 auto 50px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-answer {
    width: 193px;
    margin-bottom: 19px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area {
  padding-bottom: 40px;
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .p-1 {
  font-size: 1.125rem;
  line-height: 2;
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-bottom: 56px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .p-1 {
    font-size: 0.875rem;
    line-height: 1.625rem;
    letter-spacing: 0.05em;
    margin-left: -5px;
    margin-right: -5px;
    margin-bottom: 36px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .img05-container {
  border: solid 6px #04b5e3;
  border-radius: 20px;
  padding-top: 56px;
  padding-left: 6.25%;
  padding-right: 3.6458333333%;
  padding-bottom: 43px;
  margin-bottom: 78px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .img05-container {
    border: solid 3px #04b5e3;
    border-radius: 10px;
    padding-top: 26px;
    padding-bottom: 25px;
    padding-left: 2.2653721683%;
    padding-right: 2.9126213592%;
    margin-bottom: 24px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .img05-container img {
  display: block;
  width: 100%;
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 129px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container {
    flex-flow: row wrap;
    margin-bottom: 67px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-left {
  flex: 0 0 auto;
  width: 35.625%;
  margin-left: 3.0208333333%;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-left {
    width: 100%;
    order: 2;
    margin-left: 0;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-left img {
  display: block;
  width: 100%;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-left img {
    width: 266px;
    margin: 0 auto;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-right {
  flex: 0 0 auto;
  width: 57.2916666667%;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-right {
    width: 100%;
    order: 1;
    margin-bottom: 29px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-right p {
  font-size: 1.125rem;
  line-height: 2.125rem;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .flex-container .flex-right p {
    font-size: 0.875rem;
    line-height: 1.625rem;
    letter-spacing: 0.05em;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container {
  border: solid 6px #ff903e;
  border-radius: 20px;
  padding-top: 24px;
  padding-bottom: 20px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container {
    border: solid 3px #ff903e;
    border-radius: 10px;
    padding: 39px 12px 23px;
    display: block;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .orange-container-ttl {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -65px;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .orange-container-ttl {
    width: 72px;
    top: -38px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-left {
  margin-top: 82px;
  flex: 0 0 auto;
  width: 67.5105485232%;
  margin-left: 4.746835443%;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-left {
    width: 100%;
    margin-top: 0;
    margin-bottom: 16px;
    margin-left: 0;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-left p {
  font-size: 1.125rem;
  line-height: 2.125rem;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-left p {
    font-size: 0.875rem;
    line-height: 1.625rem;
    letter-spacing: 0.05em;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-right {
  flex: 0 0 auto;
  width: 21.4135021097%;
  margin-right: 4.746835443%;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-right {
    width: 100%;
    margin-right: 0;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-right img {
  display: block;
  width: 100%;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-area .orange-container .flex-right img {
    width: 148px;
    margin: 0 auto;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-btn {
  display: block;
  width: 266px;
  max-width: 100%;
  border: solid 4px #04b5e3;
  height: 58px;
  margin: 0 auto;
  color: #04b5e3;
  text-align: center;
  line-height: 50px;
  border-radius: 58px;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  font-weight: bold;
  position: relative;
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-btn {
    width: 200px;
    border: solid 2px #04b5e3;
    height: 40px;
    line-height: 36px;
    font-size: 0.875rem;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-btn:after {
  content: "";
  position: absolute;
  display: block;
  width: 12px;
  height: 11px;
  background: url("../img/tri.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  right: 21px;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 767px) {
  #content .quiz-section .quiz-section-inner #quiz-toggle-btn:after {
    width: 10px;
    height: 9px;
    right: 15px;
  }
}
#content .quiz-section .quiz-section-inner #quiz-toggle-btn.is-open:after {
  transform: translateY(-50%) rotate(180deg);
}
#content .campaign-section {
  padding: 120px 0 114px;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.05em;
  position: relative;
}
@media (max-width: 767px) {
  #content .campaign-section {
    padding-top: 60px;
    padding-bottom: 60px;
    font-size: 0.875rem;
  }
}
#content .campaign-section:before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 29px;
  left: 0;
  bottom: 100%;
  background: url("../img/white-wave-top@2x.png");
  background-repeat: repeat-x;
  background-size: 146px;
  background-position: center bottom;
}
@media (max-width: 767px) {
  #content .campaign-section:before {
    height: 15px;
    background-size: 73px;
  }
}
#content .campaign-section section {
  margin-bottom: 55px;
}
@media (max-width: 767px) {
  #content .campaign-section section {
    margin-bottom: 34px;
  }
}
#content .campaign-section p {
  margin-bottom: 1.7em;
}
#content .campaign-section p a, #content .campaign-section li a {
  word-break: break-all;
  color: #ff903e;
  text-decoration: underline;
}
#content .campaign-section .campaign-ttl-img {
  display: block;
  margin: 0 auto 40px;
}
#content .campaign-section .intro-txt {
  text-align: center;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  line-height: 2;
  margin-bottom: 55px;
}
@media (max-width: 767px) {
  #content .campaign-section .intro-txt {
    font-size: 0.875rem;
    margin-bottom: 45px;
    line-height: 1.78;
  }
}
#content .campaign-section .section-ttl {
  text-align: center;
  font-size: 1.875rem;
  margin-bottom: 50px;
}
@media (max-width: 767px) {
  #content .campaign-section .section-ttl {
    font-size: 1.375rem;
    margin-bottom: 36px;
  }
}
#content .campaign-section .section-subttl {
  border-bottom: solid 1px #dce0e3;
  position: relative;
  padding-left: 24px;
  padding-top: 8px;
  padding-bottom: 8px;
  font-size: 1.375rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  #content .campaign-section .section-subttl {
    font-size: 1.0625rem;
    padding-top: 2px;
    padding-bottom: 2px;
    padding-left: 19px;
    margin-bottom: 13px;
  }
}
#content .campaign-section .section-subttl:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 6px;
  height: calc(100% + 1px);
  background: #04b5e3;
}
@media (max-width: 767px) {
  #content .campaign-section .section-subttl:before {
    width: 4px;
  }
}
#content .campaign-section .prize-flex {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
@media (max-width: 767px) {
  #content .campaign-section .prize-flex {
    display: block;
  }
}
#content .campaign-section .prize-flex div {
  flex: 0 0 48%;
}
@media (max-width: 767px) {
  #content .campaign-section .prize-flex div:not(:last-child) {
    margin-bottom: 32px;
  }
}
#content .campaign-section .prize-flex div p {
  font-weight: bold;
  font-size: 1.25rem;
  letter-spacing: 0.05em;
  margin-bottom: 1em;
}
@media (max-width: 767px) {
  #content .campaign-section .prize-flex div p {
    font-size: 1rem;
  }
}
#content .campaign-section .prize-flex div p.footnote {
  font-size: 0.75rem;
  text-align: right;
  margin-bottom: 0;
  min-height: 1.67em;
  margin-top: 4px;
}
@media (max-width: 767px) {
  #content .campaign-section .prize-flex div p.footnote {
    min-height: 0;
    font-size: 0.6875rem;
  }
}
#content .campaign-section .prize-flex div img {
  width: 100%;
  display: block;
}
#content .campaign-section .section-toggle {
  display: flex;
  color: #333333;
  justify-content: space-between;
  align-items: center;
  padding-right: 45px;
  background-image: url("../img/ico-open@2x.png");
  background-repeat: no-repeat;
  background-size: 30px;
  background-position: right center;
}
@media (max-width: 767px) {
  #content .campaign-section .section-toggle {
    padding-right: 28px;
    background-size: 18px;
  }
}
#content .campaign-section .section-toggle .section-subttl-txt {
  font-size: 1.375rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
@media (max-width: 767px) {
  #content .campaign-section .section-toggle .section-subttl-txt {
    font-size: 1.0625rem;
  }
}
#content .campaign-section .section-toggle .click-txt {
  font-size: 1.125rem;
}
@media (max-width: 767px) {
  #content .campaign-section .section-toggle .click-txt {
    font-size: 0.8125rem;
  }
}
#content .campaign-section .section-toggle.active {
  background-image: url("../img/ico-close@2x.png");
}
#content .campaign-section .step-list li {
  list-style-type: none;
  margin-bottom: 1em;
  padding-left: 1em;
  text-indent: -1em;
}
#content .campaign-section .comment-list li {
  list-style-type: none;
  padding-left: 1em;
  text-indent: -1em;
}
#content .campaign-section .footnote-list li {
  list-style-type: none;
  padding-left: 1em;
  text-indent: -1em;
}
#content .campaign-section .agreement-txt {
  letter-spacing: 0.05em;
}
#content .campaign-section .agreement-txt .agreement-subttl {
  font-weight: bold;
}
#content .campaign-section .agreement-txt ul {
  margin-bottom: 1.7em;
}
#content .campaign-section .agreement-txt ul li {
  list-style-type: none;
  padding-left: 1em;
  text-indent: -1em;
}
#content .campaign-section .agreement-txt ul.mb-0 {
  margin-bottom: 0;
}
#content .campaign-section .finished-section {
  text-align: center;
  letter-spacing: 0.1em;
  font-size: 1.875rem;
  line-height: 3.25rem;
  font-weight: bold;
  margin-bottom: 94px;
  border-bottom: solid 3px #dce0e3;
  padding-bottom: 130px;
}
@media (max-width: 767px) {
  #content .campaign-section .finished-section {
    font-size: 1.25rem;
    line-height: 1.875rem;
    letter-spacing: 0;
    border-bottom: solid 2px #dce0e3;
    padding-bottom: 65px;
    margin-bottom: 46px;
  }
}
#content .campaign-section .apply-section {
  text-align: center;
  letter-spacing: 0.05em;
  margin-bottom: 94px;
  border-bottom: solid 3px #dce0e3;
  padding-bottom: 94px;
}
@media (max-width: 767px) {
  #content .campaign-section .apply-section {
    border-bottom: solid 2px #dce0e3;
    padding-bottom: 46px;
    margin-bottom: 46px;
  }
}
#content .campaign-section .apply-section .apply-btn {
  display: block;
  width: 266px;
  border: solid 4px #04b5e3;
  height: 58px;
  margin: 0 auto;
  color: #04b5e3;
  text-align: center;
  line-height: 50px;
  border-radius: 58px;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  font-weight: bold;
  position: relative;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  #content .campaign-section .apply-section .apply-btn {
    width: 200px;
    border: solid 2px #04b5e3;
    height: 40px;
    line-height: 36px;
    font-size: 0.875rem;
  }
}
#content .campaign-section .banner-section .banner-ttl {
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  margin-bottom: 22px;
}
@media (max-width: 767px) {
  #content .campaign-section .banner-section .banner-ttl {
    font-size: 0.875rem;
    margin-bottom: 16px;
  }
}
#content .campaign-section .banner-section .kanki-no-susume-banner {
  display: block;
  max-width: 100%;
  margin: 0 auto;
}
@media (max-width: 767px) {
  #content .campaign-section .banner-section .kanki-no-susume-banner {
    width: 345px;
  }
}
#content .orange-txt {
  color: #ff903e;
}
#content .blue-txt {
  color: #04b5e3;
}
#content .bold-txt {
  font-weight: bold;
}
@media (min-width: 768px) {
  #content .pc-nowrap {
    white-space: nowrap;
  }
}
#content .nowrap {
  white-space: nowrap;
}

/*!* -------------------------------
    pagetop
------------------------------- *!*/
.pagetop {
  visibility: visible;
  opacity: 1;
  position: fixed;
  z-index: 990;
  right: 24px;
  bottom: 24px;
  cursor: pointer;
  -webkit-transition: opacity 0.3s, visibility 0.3s, background 0.3s;
  transition: opacity 0.3s, visibility 0.3s, background 0.3s;
  font-size: 0;
  text-align: right;
}

.pagetop a {
  display: inline-block;
  background: #c00;
}

.pagetop a:hover {
  background: #e60000;
}

.pagetop img {
  width: 50px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}

.pagetop:hover img {
  -webkit-transform: translateY(-4px);
  -ms-transform: translateY(-4px);
  transform: translateY(-4px);
}

.pagetop.is-hidden {
  visibility: hidden;
  opacity: 0;
}

.pagetop.is-absoluted {
  position: absolute;
  bottom: 0;
}

@media (max-width: 767px) {
  .pagetop {
    right: 20px;
  }

  .pagetop img {
    width: 33px;
  }

  .pagetop:hover img {
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
  }
}
