@charset "UTF-8";
/*! ALL ***************************************************/
html {
  font-size: 62.5%;
  /* 62.5% 10px 1em */ }

body {
  color: #000;
  font-family: "游ゴシック", YuGothic,"Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.8;
  -webkit-text-size-adjust: none;
  min-width: 1000px;
  background: #a7dd4b;
  text-align: center; }

.sp {
  display: none !important; }

img {
  vertical-align: top;
  max-width: 100%;
  height: auto; }

#wrap {
  position: relative;
  width: 100%;
  overflow: hidden; }
  #wrap:before {
    content: "";
    width: 100%;
    padding-bottom: 68%;
    position: absolute;
    left: 0;
    top: 0;
    background: url(../img/bg1.png) no-repeat center top;
    background-size: 100% auto;
    z-index: -1;
    transform: scale(3) rotate(-180deg);
    opacity: 0;
    transition: all 1s cubic-bezier(1, 0, 0, 1); }
  #wrap.on:before {
    transform: scale(1) rotate(0deg);
    opacity: 1; }
  #wrap article {
    position: relative; }
    #wrap article:before {
      content: "";
      width: 100%;
      height: 100%;
      background: url(../img/bg2.png) no-repeat center top 600px;
      background-size: 963px auto;
      position: absolute;
      left: 0;
      top: 0;
      opacity: 0;
      transition: all 0.2s ease 1.5s;
      backface-visibility: hidden; }
    #wrap article.on:before {
      opacity: 1; }

#lp .head {
  width: 100%; }
  #lp .head .logo {
    display: block;
    padding: 20px;
    text-align: left;
    position: relative;
    z-index: 10; }
  #lp .head #mainTitle {
    padding: 20px 0; }
    #lp .head #mainTitle img {
      transform: scale(10) rotate(1260deg);
      opacity: 0;
      transition: all 1s cubic-bezier(1, 0, 0, 1); }
    #lp .head #mainTitle.on img {
      transform: scale(1) rotate(0deg);
      opacity: 1; }
  #lp .head #titleText {
    font-size: 18px;
    font-weight: bold;
    opacity: 0;
    transition: all 0.2s ease 1s;
    backface-visibility: hidden; }
    #lp .head #titleText span {
      font-size: 1.2em;
      color: #ffff23;
      text-shadow: black 1px 1px 0px, black -1px 1px 0px, black 1px -1px 0px, black -1px -1px 0px; }
    #lp .head #titleText.on {
      opacity: 1; }

#lp .body {
  padding: 120px 0;
  opacity: 0;
  transition: all 0.5s ease 1.2s;
  backface-visibility: hidden;
  position: relative;
  top: 20px; }
  #lp .body.on {
    opacity: 1;
    top: 0; }
  #lp .body .theme {
    width: 650px;
    padding: 40px;
    box-sizing: border-box;
    border: #000 solid 4px;
    background: url(../img/box_bg.png) no-repeat center center;
    background-size: 100% 100%;
    margin: 0 auto 40px;
    position: relative; }
    #lp .body .theme:before {
      content: "";
      width: 102px;
      height: 132px;
      position: absolute;
      right: -40px;
      top: -60px;
      background: url(../img/parts01.png) no-repeat center center;
      background-size: 100% auto; }
    #lp .body .theme:after {
      content: "";
      width: 114px;
      height: 76px;
      position: absolute;
      left: -80px;
      bottom: 60px;
      background: url(../img/parts02.png) no-repeat center center;
      background-size: 100% auto; }
    #lp .body .theme em {
      position: absolute;
      left: 2px;
      top: -47px; }
    #lp .body .theme h2 {
      padding-bottom: 30px; }
    #lp .body .theme p {
      font-weight: bold;
      font-size: 15px; }
  #lp .body .reviewBox {
    width: 650px;
    padding: 40px;
    box-sizing: border-box;
    background: #fff;
    border: #000 solid 4px;
    margin: 0 auto;
    text-align: left;
    font-weight: bold;
    font-feature-settings: "palt";
    text-align: justify;
    line-height: 2;
    position: relative; }
    #lp .body .reviewBox h2 {
      position: absolute;
      right: -50px;
      top: -70px; }
    #lp .body .reviewBox:before {
      content: "";
      width: 145px;
      height: 148px;
      background: url(../img/text04.png) no-repeat center center;
      background-size: 100% auto;
      position: absolute;
      right: -23px;
      bottom: -67px; }
  #lp .body .medal {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    width: 650px;
    margin: 150px auto 0;
    position: relative; }
    #lp .body .medal h2 {
      position: absolute;
      left: -60px;
      top: -80px; }
    #lp .body .medal h3 {
      margin-left: auto; }
    #lp .body .medal .movie {
      width: 100%;
      background: #ccc;
      padding: 10px;
      border: #000 solid 10px;
      box-sizing: border-box;
      margin: 20px 0 10px; }
      #lp .body .medal .movie a {
        display: block;
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        text-decoration: none; }
        #lp .body .medal .movie a:before {
          content: "\e900";
          font-family: "icomoon";
          position: absolute;
          color: #fff;
          font-size: 60px;
          z-index: 10;
          transition: all 0.2s ease;
          backface-visibility: hidden;
          line-height: 1;
          left: calc(50% - 30px);
          top: calc(50% - 30px); }
        #lp .body .medal .movie a:after {
          content: "";
          position: absolute;
          left: 0;
          top: 0;
          width: 100%;
          height: 100%;
          background: #000;
          opacity: 0.3;
          transition: all 0.2s ease;
          backface-visibility: hidden; }
      #lp .body .medal .movie a:hover:after {
        opacity: 0; }
      #lp .body .medal .movie a:hover:before {
        transform: scale(1.2); }
      #lp .body .medal .movie.gold {
        background: #f1ca46; }
      #lp .body .medal .movie.silver {
        background: #bee1f0; }
      #lp .body .medal .movie.bronze {
        background: #e07838; }
      #lp .body .medal .movie.performance {
        background: #00c179; }
    #lp .body .medal .copy {
      display: block;
      text-align: right;
      font-size: 10px;
      width: 100%;
      margin-bottom: 10px; }
    #lp .body .medal .review {
      width: 395px;
      height: 166px;
      border: #000 solid 4px;
      background: #fff url(../img/review_bg.png) no-repeat center center;
      background-size: 100% 100%;
      display: flex;
      justify-content: center;
      align-items: center;
      font-weight: bold;
      font-size: 15px;
      padding: 0 20px;
      box-sizing: border-box;
      text-align: left;
      line-height: 1.65;
      font-feature-settings: "palt";
      text-align: justify;
      position: relative; }
      #lp .body .medal .review:before {
        content: "";
        width: 77px;
        height: 36px;
        background: url(../img/review.png) no-repeat center center;
        background-size: 100% auto;
        position: absolute;
        left: 8px;
        top: -15px; }
      #lp .body .medal .review small {
        display: block;
        width: 100%;
        font-size: 13px; }
      #lp .body .medal .review.nopalt {
        font-feature-settings: initial; }
        #lp .body .medal .review.nopalt p, #lp .body .medal .review.nopalt small {
          letter-spacing: -0.06em; }
      #lp .body .medal .review.high {
        height: 192px; }
  #lp .body .otherBox {
    width: 650px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 100px auto 50px; }
    #lp .body .otherBox .item {
      width: 190px;
      margin-bottom: 40px; }
      #lp .body .otherBox .item.seven {
        position: relative; }
        #lp .body .otherBox .item.seven span {
          position: absolute;
          left: -25px;
          top: -30px; }
      #lp .body .otherBox .item .mini_movie a {
        border: #000 solid 5px;
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        text-decoration: none; }
        #lp .body .otherBox .item .mini_movie a:before {
          content: "\e900";
          font-family: "icomoon";
          position: absolute;
          color: #fff;
          font-size: 30px;
          z-index: 10;
          transition: all 0.2s ease;
          backface-visibility: hidden;
          line-height: 1;
          left: calc(50% - 15px);
          top: calc(50% - 15px); }
        #lp .body .otherBox .item .mini_movie a:after {
          content: "";
          position: absolute;
          left: 0;
          top: 0;
          width: 100%;
          height: 100%;
          background: #000;
          opacity: 0.3;
          transition: all 0.2s ease;
          backface-visibility: hidden; }
      #lp .body .otherBox .item .mini_movie a:hover:after {
        opacity: 0; }
      #lp .body .otherBox .item .mini_movie a:hover:before {
        transform: scale(1.2); }
      #lp .body .otherBox .item small.copy {
        font-size: 10px;
        transform: scale(0.9);
        transform-origin: center;
        white-space: nowrap;
        display: block;
        font-feature-settings: "palt";
        text-align: justify; }
      #lp .body .otherBox .item dl {
        padding-top: 10px; }
        #lp .body .otherBox .item dl dt {
          height: 9px; }
        #lp .body .otherBox .item dl dd:nth-child(2) {
          font-weight: bold;
          line-height: 1.5;
          font-size: 14px;
          height: 70px;
          display: flex;
          justify-content: center;
          align-items: center;
          position: relative;
          font-feature-settings: "palt"; }
          #lp .body .otherBox .item dl dd:nth-child(2).narrow {
            line-height: 1; }
          #lp .body .otherBox .item dl dd:nth-child(2):before {
            content: "『";
            font-family: "メイリオ", Meiryo, sans-serif;
            position: absolute;
            left: -0.5em;
            top: 5px;
            font-weight: bold;
            font-size: 20px; }
          #lp .body .otherBox .item dl dd:nth-child(2):after {
            content: "』";
            font-family: "メイリオ", Meiryo, sans-serif;
            position: absolute;
            right: -0.5em;
            bottom: 5px;
            font-weight: bold;
            font-size: 20px; }
        #lp .body .otherBox .item dl dd:nth-child(4) {
          font-size: 12px;
          font-weight: bold; }
    #lp .body .otherBox > p {
      width: 100%;
      text-align: center;
      font-weight: bold;
      font-size: 15px; }
  #lp .body .before_gp {
    padding-bottom: 80px; }
    #lp .body .before_gp a {
      display: inline-block;
      border-bottom: #000 solid 5px; }
      #lp .body .before_gp a:hover {
        margin-top: 5px;
        border-bottom-width: 0px; }
  #lp .body .contact h2 {
    display: flex;
    justify-content: center;
    align-items: center; }
    #lp .body .contact h2 em {
      font-weight: bold;
      font-size: 20px;
      padding: 0 20px;
      letter-spacing: 2px; }
    #lp .body .contact h2 span {
      font-size: 30px;
      color: #ffff23;
      text-shadow: black 2px 2px 0px, black -2px 2px 0px, black 2px -2px 0px, black -2px -2px 0px; }
  #lp .body .contact .btnBox {
    width: 100%;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center; }
    #lp .body .contact .btnBox .btn {
      width: 270px;
      height: 52px;
      display: flex;
      justify-content: center;
      align-items: center;
      background: #ffff23;
      border-bottom: #000 solid 5px;
      text-decoration: none;
      position: relative;
      top: 0; }
      #lp .body .contact .btnBox .btn span {
        color: #000;
        font-weight: bold;
        font-size: 17px;
        padding-left: 10px; }
      #lp .body .contact .btnBox .btn:hover {
        margin-top: 5px;
        border-bottom-width: 0px; }
  #lp .body .contact .tel {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 20px; }
    #lp .body .contact .tel em {
      font-size: 16px;
      font-weight: bold;
      padding-right: 20px; }
    #lp .body .contact .tel p {
      position: relative;
      width: 100%;
      text-align: center;
      font-weight: bold;
      font-size: 14px;
      padding-top: 10px;
      margin-top: 10px; }
      #lp .body .contact .tel p:before {
        content: "";
        position: absolute;
        left: calc(50% - 270px);
        top: 0;
        width: 540px;
        height: 2px;
        background: #000; }

#lp .modal {
  display: none;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 1000; }
  #lp .modal .youtube {
    width: 700px;
    max-width: 100%;
    padding-bottom: 56.2%;
    background: #000;
    overflow: hidden;
    position: relative; }
    #lp .modal .youtube iframe {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%; }
  #lp .modal .closeBtn {
    color: #fff;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-weight: bold;
    margin-top: 20px; }
    #lp .modal .closeBtn i {
      font-size: 30px;
      font-weight: bold;
      margin-right: 10px; }
    #lp .modal .closeBtn:hover {
      color: #ffff23; }

#lp #modalBackground {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.8;
  z-index: 10; }

#lp footer {
  background: #fff;
  width: 100%; }
  #lp footer .footerContent {
    width: 780px;
    height: 100px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center; }
  #lp footer .youtubeIcon {
    width: 50px;
    height: 50%;
    border-radius: 50%;
    background: #fff;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 18px;
    color: #ff0000;
    border: #c2c2c2 solid 1px;
    box-sizing: border-box; }

/*! SP ***************************************************/
@media screen and (max-width: 640px) {
  body {
    min-width: 320px; }
  img {
    max-width: 100%;
    height: auto; }
  .pc {
    display: none !important; }
  .sp {
    display: block !important; }
  #wrap {
    position: relative;
    width: 100%;
    overflow: hidden; }
  #lp article:before {
    width: 100%;
    height: 100%;
    background: none;
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0; }
  #lp article.on:before {
    opacity: 1; }
  #lp .head {
    width: 100%; }
    #lp .head .logo {
      padding: 10px;
      width: 150px; }
    #lp .head #mainTitle {
      padding: 0px 10px 10px; }
    #lp .head #titleText {
      font-size: 13px;
      font-weight: bold;
      font-feature-settings: "palt"; }
      #lp .head #titleText span {
        font-size: 1.1em; }
  #lp .body {
    padding: 40px 20px; }
    #lp .body .theme {
      width: 100%;
      padding: 30px 20px;
      margin: 0 auto 20px;
      position: relative; }
      #lp .body .theme:before {
        width: 51px;
        height: 66px;
        right: -20px;
        top: -33px; }
      #lp .body .theme:after {
        content: "";
        width: 40px;
        height: 26px;
        position: absolute;
        left: -20px;
        top: 40px;
        bottom: auto;
        background: url(../img/parts02.png) no-repeat center center;
        background-size: 100% 100%; }
      #lp .body .theme em {
        position: absolute;
        left: -3px;
        top: -29px; }
        #lp .body .theme em img {
          width: 88px; }
      #lp .body .theme h2 {
        padding-bottom: 10px;
        width: 143px;
        margin: 0 auto; }
      #lp .body .theme p {
        font-size: 10px;
        font-feature-settings: "palt";
        text-align: center; }
    #lp .body .reviewBox {
      width: 100%;
      padding: 20px 20px;
      border: #000 solid 4px; }
      #lp .body .reviewBox h2 {
        right: -20px;
        top: -40px;
        width: 120px; }
      #lp .body .reviewBox p {
        font-size: 10px; }
      #lp .body .reviewBox:before {
        content: "";
        width: 56px;
        height: 56px;
        background: url(../img/text04.png) no-repeat center center;
        background-size: 100% auto;
        position: absolute;
        right: -13px;
        bottom: -17px; }
    #lp .body .medal {
      display: flex;
      justify-content: space-between;
      align-items: stretch;
      flex-wrap: wrap;
      width: 100%;
      margin: 50px auto 0;
      position: relative; }
      #lp .body .medal h2 {
        position: absolute;
        left: -20px;
        top: -8%;
        width: 48%;
        z-index: 20; }
      #lp .body .medal h3 {
        width: 60%;
        margin-left: auto; }
      #lp .body .medal .movie {
        width: 100%;
        background: #ccc;
        padding: 4px;
        border: #000 solid 4px;
        box-sizing: border-box;
        margin: 10px 0 10px;
        z-index: 10; }
        #lp .body .medal .movie a {
          display: block;
          position: relative;
          display: flex;
          justify-content: center;
          align-items: center; }
          #lp .body .medal .movie a:before {
            font-size: 50px;
            line-height: 1;
            left: calc(50% - 25px);
            top: calc(50% - 25px); }
      #lp .body .medal h4 {
        width: calc(32% - 10px); }
        #lp .body .medal h4 img {
          width: 100%; }
      #lp .body .medal .copy {
        word-break: break-all; }
        #lp .body .medal .copy br {
          display: none; }
      #lp .body .medal .review {
        width: 68%;
        height: auto !important;
        border: #000 solid 3px;
        background: #fff url(../img/review_bg.png) no-repeat center center;
        background-size: 100% 100%;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: bold;
        font-size: 11px;
        padding: 15px;
        box-sizing: border-box;
        text-align: left;
        line-height: 1.65;
        font-feature-settings: "palt";
        text-align: justify;
        position: relative; }
        #lp .body .medal .review:before {
          content: "";
          width: calc(100vw / 10 );
          height: calc(100vw / 16);
          background: url(../img/review.png) no-repeat center center;
          background-size: 100% auto;
          position: absolute;
          left: 2px;
          top: -8px; }
        #lp .body .medal .review small {
          display: block;
          width: 100%;
          font-size: 10px; }
    #lp .body .otherBox {
      width: 100%;
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      margin: 50px auto 25px; }
      #lp .body .otherBox .item {
        width: 46%;
        margin-bottom: 30px; }
        #lp .body .otherBox .item figure img {
          width: 100%; }
        #lp .body .otherBox .item.seven {
          position: relative; }
          #lp .body .otherBox .item.seven span {
            width: 56px;
            position: absolute;
            left: -20px;
            top: -20px; }
        #lp .body .otherBox .item .mini_movie a {
          border: #000 solid 3px; }
          #lp .body .otherBox .item .mini_movie a:before {
            font-size: 30px;
            line-height: 1;
            left: calc(50% - 15px);
            top: calc(50% - 15px); }
        #lp .body .otherBox .item .mini_movie a:hover:after {
          opacity: 0; }
        #lp .body .otherBox .item .mini_movie a:hover:before {
          transform: scale(1.2); }
        #lp .body .otherBox .item small.copy {
          transform: scale(0.6); }
        #lp .body .otherBox .item dl {
          padding-top: 10px; }
          #lp .body .otherBox .item dl dt img {
            width: 100%;
            height: auto; }
          #lp .body .otherBox .item dl dd:nth-child(2) {
            font-weight: bold;
            line-height: 1.2;
            font-size: 12px;
            height: 70px;
            display: flex;
            justify-content: center;
            align-items: center;
            position: relative;
            font-feature-settings: "palt";
            white-space: nowrap; }
            #lp .body .otherBox .item dl dd:nth-child(2):before {
              content: "『";
              position: absolute;
              font-family: "游ゴシック", YuGothic,"Hiragino Kaku Gothic ProN","メイリオ", Meiryo,"Helvetica Neue", Helvetica, Arial, sans-serif;
              left: 0;
              top: 5px;
              font-weight: bold;
              font-size: 15px; }
            #lp .body .otherBox .item dl dd:nth-child(2):after {
              content: "』";
              position: absolute;
              font-family: "游ゴシック", YuGothic,"Hiragino Kaku Gothic ProN","メイリオ", Meiryo,"Helvetica Neue", Helvetica, Arial, sans-serif;
              right: 0;
              bottom: 5px;
              font-weight: bold;
              font-size: 15px; }
          #lp .body .otherBox .item dl dd:nth-child(4) {
            font-size: 12px;
            font-weight: bold; }
      #lp .body .otherBox > p {
        font-size: 11px;
        line-height: 1.35;
        font-feature-settings: "palt"; }
    #lp .body .before_gp {
      padding-bottom: 40px; }
    #lp .body .contact h2 {
      display: flex;
      justify-content: center;
      align-items: center; }
      #lp .body .contact h2 em {
        font-weight: bold;
        font-size: 18px;
        padding: 0 20px;
        letter-spacing: 0px;
        font-feature-settings: "palt";
        line-height: 1.35; }
      #lp .body .contact h2 span {
        font-size: 30px;
        color: #ffff23;
        text-shadow: black 2px 2px 0px, black -2px 2px 0px, black 2px -2px 0px, black -2px -2px 0px; }
    #lp .body .contact .btnBox {
      width: 100%;
      height: 80px;
      display: flex;
      justify-content: center;
      align-items: center;
      text-align: center; }
      #lp .body .contact .btnBox .btn {
        width: 270px;
        height: 52px;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #ffff23;
        border-bottom: #000 solid 3px;
        text-decoration: none;
        position: relative;
        top: 0; }
        #lp .body .contact .btnBox .btn span {
          color: #000;
          font-weight: bold;
          font-size: 17px;
          padding-left: 10px; }
        #lp .body .contact .btnBox .btn:hover {
          margin-top: 3px;
          border-bottom-width: 0px; }
    #lp .body .contact .tel {
      display: block;
      justify-content: center;
      align-items: center;
      flex-wrap: wrap;
      margin-top: 20px; }
      #lp .body .contact .tel em {
        font-size: 12px;
        font-weight: bold;
        padding-right: 0px;
        position: relative; }
        #lp .body .contact .tel em:before {
          content: "";
          width: 20px;
          height: 1px;
          background: #000;
          position: absolute;
          right: 105%;
          top: 50%; }
        #lp .body .contact .tel em:after {
          content: "";
          width: 20px;
          height: 1px;
          background: #000;
          position: absolute;
          left: 105%;
          top: 50%; }
      #lp .body .contact .tel figure {
        padding: 0 20px;
        max-width: 260px;
        margin: 10px auto; }
      #lp .body .contact .tel p {
        position: relative;
        width: 100%;
        text-align: center;
        font-weight: bold;
        font-size: 10px;
        padding-top: 10px;
        margin-top: 10px;
        font-feature-settings: "palt"; }
        #lp .body .contact .tel p:before {
          content: "";
          position: absolute;
          left: 0;
          top: 0;
          width: 100%;
          height: 1px;
          background: #000; }
  #lp footer {
    padding: 15px 0;
    box-sizing: border-box; }
    #lp footer .footerContent {
      width: 300px;
      padding: 0;
      box-sizing: border-box;
      height: auto;
      margin: 0 auto;
      display: block;
      position: relative; }
    #lp footer .f-logo {
      width: 240px;
      display: block; }
    #lp footer p {
      font-size: 10px;
      text-align: left;
      font-feature-settings: "palt";
      line-height: 1;
      padding-top: 5px; }
    #lp footer .youtubeIcon {
      width: 38px;
      height: 38px;
      font-size: 12px;
      position: absolute;
      right: 0;
      top: calc(50% - 19px); }
  #lp .modal {
    width: 100%; }
    #lp .modal .youtube {
      margin: 0px auto;
      width: 90%;
      max-width: 90%;
      padding-bottom: 56.2%; }
    #lp .modal .closeBtn {
      font-size: 14px;
      margin-top: 10px; }
      #lp .modal .closeBtn i {
        font-size: 20px;
        margin-right: 6px; }
  #lp #modalBackground {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0.8;
    z-index: 20; }
  /*! SP /subpage ***************************************************/ }

/*! PC ***************************************************/
