@charset "UTF-8";
/* CSS Document */

/* ---------------------------------------------------------
common
----------------------------------------------------------*/
html,
body {
  height: 100%;
  font-size: 62.5%;
}
body {
	width: 100%;
  min-width: 1366px;
	font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","游ゴシック体","Yu Gothic Medium",YuGothic,"メイリオ",Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
	font-size: 1.3rem;
	-webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
	line-height: 1;
	color: #000;
	background-color: #fff;
	-webkit-text-size-adjust: 100%;
}
body.is-fixed {
  position: fixed;
}
#white {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  z-index: 10;
}

img {
  vertical-align: bottom;
}
a {
  color: #000; 
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}
.show-sp {
  display: none;
}

a.is-false {
  pointer-events: none;
}

/* ---------------------------------------------------------
animation
----------------------------------------------------------*/
.animeBefore {
	visibility: hidden;
}
.fadeAnime {
	visibility: visible;
	animation-name: fadeAnime;
	animation-duration: 600ms;
}
.fixAnime {
	visibility: visible;
}
@keyframes fadeAnime {
  from {
	  opacity: 0;
	  transform: translateY(20px);
  }
  to {
	  opacity: 1;
	  transform: translateY(0px);
  }
}

/* ---------------------------------------------------------
main
----------------------------------------------------------*/
main {
  position: relative;
  display: block;
  padding-top: calc(683 / 1366 * 100%);
  margin-bottom: 140px;
}
.kv_01 main {
  background: url("../img/main_01.jpg") no-repeat center top;
  background-size: 100% auto;
}
.kv_02 main {
  background: url("../img/main_02.jpg") no-repeat center top;
  background-size: 100% auto;
}
main .logo {
  position: absolute;
  top: 27px;
  left: 31px;
  width: 112px;
}
main .logo img {
  width: 112px;
}
main h1 {
  position: absolute;
  top: 0;
  left: 50%;
  width: 925px;
  padding-top: calc(254 / 1366 * 100%);
  margin-left: -462px;
}

/* ---------------------------------------------------------
article
----------------------------------------------------------*/
article .logo-side.is-show {
  opacity: 1;
}
article .logo-side {
  position: fixed;
  top: 50%;
  left: 30px;
  margin-top: -120px;
  opacity: 0;
  transition: opacity .3s;
  z-index: 2;
}
article .logo-side img {
  width: 9px;
  height: 241px;
}
/* ---------------------------------------------------------
.block
----------------------------------------------------------*/
.block {
  position: relative;
  width: 960px;
  padding-bottom: 135px;
  margin: 0 auto;
}
.block.w1366 {
  width: 1366px;
  margin: 0 auto;
}
.block .pic img {
  width: 100%;
  height: auto;
}
.block .col2 {
  display: flex;
  align-items: center;
}
.block li {
  list-style: none;
}
.block .link-area {
  width: 330px;
}
.block .link-area p {
  font-family: Helvetica,Arial;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: -.018em;
  line-height: 2.4;
}
.block .link-area li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: Helvetica,Arial;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: -.018em;
  line-height: 2.4;
}
.block .link-area .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 18px;
  font-weight: bold;
  line-height: 16px;
  border: 1px solid #000;
  box-sizing: border-box;
  transition: background .3s,color .3s;
}
.block .link-area li a:hover .btn {
  background: #000;
  color: #fff;
}

/* ---------------------------------------------------------
#block1
----------------------------------------------------------*/
#block1 .pic1 {
  width: 180px;
  margin-left: auto;
}
#block1 .col2 {
  margin: -110px 0 15px 0;
}
#block1 .pic2,
#block1 .pic3 {
  width: 330px;
}
#block1 .pic2 {
  margin-right: 10px;
}
#block1 .num {
  position: absolute;
  top: 203px;
  right: 231px;
  width: 73px;
}
#block1 .num img {
  width: 73px;
}

/* ---------------------------------------------------------
#block2
----------------------------------------------------------*/
#block2 {
  padding-bottom: 107px;
}
#block2 h2 {
  position: absolute;
  top: 67px;
  left: 155px;
  width: 654px;
  z-index: 2;
}
#block2 h2 img {
  width: 654px;
}
#block2 .num {
  position: absolute;
  top: 441px;
  left: 66px;
  width: 199px;
  z-index: 2;
}
#block2 .num img {
  width: 199px;
}
#block2 .col2 {
  margin: -350px 0 15px 0;
}
#block2 .pic1 {
  width: 550px;
  margin-left: auto;
}
#block2 .pic2,
#block2 .pic3 {
  width: 330px;
}
#block2 .pic2 {
  margin-right: 10px;
}

/* ---------------------------------------------------------
#block3
----------------------------------------------------------*/
#block3 h2 {
  position: absolute;
  top: 322px;
  left: 61px;
  width: 567px;
  z-index: 2;
}
#block3 .num {
  position: absolute;
  top: 213px;
  left: 60px;
  width: 198px;
}
#block3 .num img {
  width: 198px;
}
#block3 .pic {
  width: 550px;
  margin: 0 0 15px auto;
}
#block3 .link-area {
  margin-left: 410px;
}

/* ---------------------------------------------------------
#block4
----------------------------------------------------------*/
#block4 .pic {
  width: 496px;
  margin: 0 auto 15px;
}
#block4 .link-area {
  margin-left: 232px;
}

/* ---------------------------------------------------------
#block5
----------------------------------------------------------*/
#block5 .num {
  position: absolute;
  top: -74px;
  right: 42px;
  width: 73px;
  z-index: 2;
}
#block5 .num img {
  width: 73px;
}
#block5 .col2 {
  flex-direction: row-reverse;
  justify-content: center;
  margin-bottom: 15px;
}
#block5 .pic {
  width: 330px;
}
#block5 .pic1 {
  margin-left: 130px;
}
#block5 .link-area {
  margin-left: 545px;
}

/* ---------------------------------------------------------
#block6
----------------------------------------------------------*/
#block6 {
  padding-bottom: 132px;
}
#block6 .num {
  position: absolute;
  top: -35px;
  left: 25px;
  width: 199px;
}
#block6 .num img {
  width: 199px;
}
#block6 .pic {
  width: 677px;
  margin-bottom: 15px;
}

/* ---------------------------------------------------------
#block7
----------------------------------------------------------*/
#block7 h2 {
  position: relative;
  width: 720px;
  margin-left: 283px;
  z-index: 2;
}
#block7 h2 img {
  width: 720px;
}
#block7 .col2 {
  flex-direction: row-reverse;
  align-items: flex-start;
  width: 680px;
  margin: -36px 0 0 auto;
}
#block7 .txt-block {
  padding-top: 295px;
}
#block7 .num {
  width: 200px;
  margin-bottom: 23px;
}
#block7 .num img {
  width: 200px;
}
#block7 .pic {
  width: 330px;
  margin: 0 0 0 auto;
}

/* ---------------------------------------------------------
#block8
----------------------------------------------------------*/
#block8 {
  padding-bottom: 170px;
}
#block8 .num {
  position: absolute;
  top: 233px;
  right: 252px;
  width: 235px;
  z-index: 2;
}
#block8 .num img {
  width: 235px;
}
#block8 .pic {
  width: 1013px;
  margin: 0 0 15px auto;
}
#block8 .link-area {
  margin-left: 354px;
}

/* ---------------------------------------------------------
#block9
----------------------------------------------------------*/
#block9 {
  padding-bottom: 155px;
}
#block9 .col2 {
  align-items: flex-start;
  justify-content: space-between;
  width: 1021px;
  margin: 0 0 138px 203px;
}
#block9 .left-col .pic {
  width: 330px;
}
#block9 .left-col .pic1 {
  margin-bottom: 37px;
}
#block9 .left-col .pic2 {
  margin-bottom: 61px;
}
#block9 .left-col .num {
  width: 200px;
  margin-bottom: 23px;
}
#block9 .left-col .num img {
  width: 200px;
}
#block9 .right-col .pic {
  width: 497px;
}
#block9 h2 {
  width: 853px;
  margin-left: 206px;
}
#block9 h2 img {
  width: 853px;
}
#block9 .movie {
  width: 497px;
  height: 355px;
  margin: 0 auto 71px;
}
.inline-YTPlayer {
  max-width: 100% !important;
}
#background_video1,
#background_video2 {
  padding-bottom: 355px !important;
  pointer-events: none;
}

#block9 .movie iframe,
#block17 .movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
}
/*
#block9 .movie .inner {
  position: relative;
  padding-top: 330px;
}
*/

/* ---------------------------------------------------------
#block10
----------------------------------------------------------*/
#block10 {
  padding-bottom: 258px;
}
#block10 .pic1 {
  width: 330px;
  padding-left: 80px;
}
#block10 .pic2 {
  position: absolute;
  top: 183px;
  right: 9px;
  width: 390px;
}
#block10 .txt-block {
  width: 330px;
  padding: 129px 0 0 235px;
}
#block10 .num {
  width: 199px;
  margin-bottom: 32px;
}
#block10 .num img {
  width: 199px;
}

/* ---------------------------------------------------------
#block11
----------------------------------------------------------*/
#block11 {
  padding-bottom: 142px;
}
#block11 .col2 {
  align-items: flex-start;
  padding-left: 159px;
  margin-bottom: 40px;
}
#block11 .pic {
  width: 209px;
  margin-right: 79px;
}
#block11 .txt-block {
  padding-top: 118px;
}
#block11 .num {
  width: 189px;
  margin-bottom: 38px;
}
#block11 .num img {
  width: 189px;
}
#block11 h2 {
  width: 962px;
  margin-left: -3px;
}

/* ---------------------------------------------------------
#block12
----------------------------------------------------------*/
#block12 .num {
  position: absolute;
  top: 156px;
  right: 43px;
  width: 73px;
  z-index: 2;
}
#block12 .num img {
  width: 73px;
}
#block12 .col2 {
  flex-direction: row-reverse;
  justify-content: center;
  align-items: flex-start;
}
#block12 .col2 .right-col {
  padding-top: 31px;
  margin-right: 130px;
}
#block12 .col2 .pic {
  width: 330px;
  margin-bottom: 15px;
}
#block12 .col2 .right-col .pic {
  margin-bottom: 53px;
}

/* ---------------------------------------------------------
#block13
----------------------------------------------------------*/
#block13 .num {
  position: absolute;
  top: 155px;
  left: 42px;
  width: 73px;
  z-index: 2;
}
#block13 .num img {
  width: 73px;
}
#block13 .col2 {
  justify-content: center;
  align-items: flex-start;
}
#block13 .col2 .right-col {
  padding-top: 35px;
  margin-left: 130px;
}
#block13 .col2 .pic {
  width: 330px;
  margin-bottom: 15px;
}
#block13 .col2 .right-col .pic {
  margin-bottom: 51px;
}

/* ---------------------------------------------------------
#block14
----------------------------------------------------------*/
#block14 .num {
  position: absolute;
  top: 173px;
  left: 113px;
  width: 197px;
  z-index: 2;
}
#block14 .num img {
  width: 197px;
}
#block14 .pic {
  width: 450px;
  margin: 0 auto 15px;
}
#block14 .link-area {
  margin-left: 255px;
}

/* ---------------------------------------------------------
#block15
----------------------------------------------------------*/
#block15 {
  width: 100%;
  background: url(../img/pic_17_05.jpg) no-repeat center top;
  background-size: 100% auto;
  padding: 1473px 0 0;
  margin-bottom: 496px;
}
#block15 h2 {
  position: absolute;
  top: 171px;
  left: 50%;
  width: 747px;
  margin-left: -267px;
}
#block15 h2 img {
  width: 747px;
}
#block15 .col2 {
  position: absolute;
  top: 512px;
  left: 50%;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 695px;
  margin-left: -480px;
}
#block15 .block-inner {
  position: relative;
  width: 330px;
}
#block15 .block-inner:nth-child(even) {
  margin-left: 35px;
}
#block15 .block-inner:nth-child(1) {
  margin-bottom: 123px;
}
#block15 .block-inner:nth-child(2) {
  margin-bottom: 95px;
}
#block15 .block-inner .num {
  position: absolute;
  top: 24px;
  left: 23px;
  width: 39px;
  z-index: 2;
}
#block15 .block-inner .num img {
  width: 39px;
}
#block15 .block-inner .pic {
  margin-bottom: 15px;
}
#block15 .block-inner:nth-child(1) .link-area a,
#block15 .block-inner:nth-child(2) .link-area a {
  color: #fff;
}
#block15 .block-inner:nth-child(1) .link-area .btn,
#block15 .block-inner:nth-child(2) .link-area .btn {
  border: 1px solid #fff;
}
#block15 .block-inner:nth-child(1) li a:hover .btn,
#block15 .block-inner:nth-child(2) li a:hover .btn {
  background: #fff;
  color: #000;
}

/* ---------------------------------------------------------
#block16
----------------------------------------------------------*/
#block16 {
  padding-bottom: 170px;
}
#block16 .pic1 {
  width: 753px;
  margin-left: auto;
}
#block16 h2 {
  position: absolute;
  top: 252px;
  left: 342px;
  width: 470px;
}
#block16 h2 img {
  width: 470px;
}
#block16 .col2 {
  align-items: flex-start;
  flex-wrap: wrap;
  width: 695px;
  margin: -448px 0 0 203px;
}
#block16 .block-inner {
  position: relative;
  width: 330px;
}
#block16 .block-inner:nth-child(even) {
  margin-left: 35px;
}
#block16 .block-inner:nth-child(1) {
  margin-bottom: 95px;
}
#block16 .block-inner:nth-child(2) {
  margin-bottom: 123px;
}
#block16 .block-inner .num {
  position: absolute;
  top: 24px;
  left: 23px;
  width: 39px;
  z-index: 2;
}
#block16 .block-inner .num img {
  width: 39px;
}
#block16 .block-inner .pic {
  margin-bottom: 15px;
}

/* ---------------------------------------------------------
#block17
----------------------------------------------------------*/
#block17 {
  padding-bottom: 211px;
}
#block17 h2 {
  width: 900px;
  margin: 0 0 119px 74px;
}
#block17 h2 img {
  width: 900px;
}
#block17 .movie {
  width: 497px;
  height: 330px;
  margin: 0 auto;
}
#block17 .movie .inner {
  position: relative;
  padding-top: 330px;
}
#block17 .movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ---------------------------------------------------------
#block18
----------------------------------------------------------*/
#block18 .num {
  position: absolute;
  top: -67px;
  right: 117px;
  width: 73px;
  z-index: 2;
}
#block18 .num img {
  width: 73px;
}
#block18 .col2 {
  justify-content: center;
  margin-bottom: 15px;
}
#block18 .pic {
  width: 330px;
}
#block18 .pic1 {
  margin-right: 10px;
}
#block18 .link-area {
  margin-left: 145px;
}

/* ---------------------------------------------------------
#block19
----------------------------------------------------------*/
#block19 .col2 {
  align-items: flex-start; 
}
#block19 .num {
  width: 235px;
  padding-top: 32px;
  padding-left: 142px;
  margin-right: 109px;
}
#block19 .num img {
  width: 235px;
}
#block19 .pic {
  width: 330px;
  margin-bottom: 15px;
}

/* ---------------------------------------------------------
#block20
----------------------------------------------------------*/
#block20 {
  padding-bottom: 205px;
}
#block20 .pic {
  width: 670px;
  margin: 0 auto 15px;
}
#block20 .num {
  position: absolute;
  top: 669px;
  right: 240px;
  width: 73px;
}
#block20 .num img {
  width: 73px;
}
#block20 .link-area {
  margin-left: 145px;
}

/* ---------------------------------------------------------
#block21
----------------------------------------------------------*/
#block21 {
  padding-bottom: 0;
  z-index: 2;
}
#block21 .pic {
  width: 330px;
  margin: 0 0 15px;
}
#block21 .num {
  position: absolute;
  top: -68px;
  left: 288px;
  width: 73px;
}
#block21 .num img {
  width: 73px;
}

/* ---------------------------------------------------------
#block22
----------------------------------------------------------*/
#block22 {
  padding-bottom: 140px;
  margin-top: -218px;
}
#block22 .pic {
  width: 180px;
  margin: 0 0 0 auto;
}
#block22 h2 {
  width: 424px;
  margin: -108px 0 0 511px;
}
#block22 h2 img {
  width: 424px;
}

/* ---------------------------------------------------------
#block23
----------------------------------------------------------*/
#block23 {
  padding-bottom: 125px;
}
#block23 .pic {
  width: 450px;
  margin: 0 auto 15px;
}
#block23 .num {
  position: absolute;
  top: -69px;
  left: 213px;
  width: 73px;
}
#block23 .num img {
  width: 73px;
}
#block23 .link-area {
  margin-left: 256px;
}

/* ---------------------------------------------------------
.bottom
----------------------------------------------------------*/
.bottom {
  padding: 0 0 0;
}
.bottom .btn-all {
  margin-bottom: 211px;
}
.bottom .btn-all a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 240px;
  height: 45px;
  font-family: Helvetica, Arial, "sans-serif";
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: .117em;
  background: #000;
  border: 1px solid #000;
  margin: 0 auto;
  box-sizing: border-box;
  transition: background .3s, color .3s;
}
.bottom .btn-all a:hover {
  background: #fff;
  color: #000;
}
.bottom .pic {
  width: 160px;
  margin: 0 auto 74px;
}
.bottom .pic img {
  width: 100%;
  height: auto;
}
.bottom h3 {
  width: 400px;
  margin: 0 auto 24px;
}
.bottom .txt {
  width: 400px;
  font-size: 12px;
  line-height: 2.1;
  letter-spacing: .005em;
  margin: 0 auto 125px;
}
.bottom .staff {
  font-family: Helvetica, Arial, "sans-serif";
  font-size: 10px;
  line-height: 1.9;
  letter-spacing: .015em;
  text-align: center;
}

/* ---------------------------------------------------------
footer
----------------------------------------------------------*/
footer {
  position: relative;
  padding: 120px 0 58px;
}
footer .logo {
  width: 110px;
  margin: 0 auto 30px;
}
footer ul {
  display: flex;
  justify-content: center;
  margin-bottom: 120px;
}
footer li {
  list-style: none;
  font-family: Helvetica, Arial, "sans-serif";
  font-size: 12px;
  font-weight: bold;
  letter-spacing: .030em;
  margin-right: 13px;
}
footer li:last-child {
  margin-right: 0;
}
footer li::after {
  content: "/";
  margin-left: 13px;
}
footer li:last-child::after {
  content: none;
}
footer p {
  font-family: Helvetica, Arial, "sans-serif";
  font-size: 10px;
  font-weight: bold;
  letter-spacing: .036em;
  text-align: center;
}
footer .pagetop {
  position: absolute;
  bottom: 58px;
  right: 60px;
  width: 34px;
}

/* ---------------------------------------------------------
media queries
----------------------------------------------------------*/
@media screen and (max-width:768px) {
  /* ---------------------------------------------------------
  common
  ----------------------------------------------------------*/
  body {
    min-width: 100%;
  }
  .show-pc {
    display: none;
  }
  .show-sp {
    display: block;
  }
  
/* ---------------------------------------------------------
main sp
----------------------------------------------------------*/
  main {
    padding-top: calc(750 / 750 * 100%);
    margin-bottom: calc(180 / 750 * 100vw);
  }
  .kv_01 main {
    background: url("../img/main_01_sp.jpg") no-repeat center top;
    background-size: 100% auto;
  }
  .kv_02 main {
    background: url("../img/main_02_sp.jpg") no-repeat center top;
    background-size: 100% auto;
  }
  main .logo {
    top: calc(33 / 750 * 100vw);
    left: calc(32 / 750 * 100vw);
    width: calc(152 / 750 * 100vw);
  }
  main .logo img {
    width: 100%;
  }
  main h1 {
    left: 0;
    width: calc(624 / 750 * 100vw);
    padding-top: calc(199 / 750 * 100%);
    margin: 0 0 0 calc(60 / 750 * 100%);
  }
  main h1 img {
    width: calc(624 / 750 * 100vw);
  }
  
/* ---------------------------------------------------------
article sp
----------------------------------------------------------*/
  article .logo-side {
    display: none;
  }
/* ---------------------------------------------------------
.block sp
----------------------------------------------------------*/
  .block {
    width: 100%;
    padding: 0 8vw calc(183 / 750 * 100vw);
    box-sizing: border-box;
  }
  .block.w1366 {
    width: 100%;
  }
  .block .col2 {
    display: block;
  }
  .block .link-area {
    width: calc(570 / 750 * 100vw);
  }
  .block .link-area p {
    font-size: 2.93vw;
    line-height: 2.3;
    letter-spacing: -.03em;
  }
  .block .link-area li a {
    font-size: 2.93vw;
    line-height: 2.3;
    letter-spacing: -.03em;
  }
  .block .link-area .btn {
    width: 12.26vw;
    height: 4.4vw;
    line-height: calc(4.4vw - 2px);
  }

/* ---------------------------------------------------------
#block1 sp
----------------------------------------------------------*/
  #block1 .pic1 {
    width: calc(360 / 750 * 100vw);
    margin: 0 auto calc(184 / 750 * 100vw);
  }
  #block1 .col2 {
    margin: 0 0 calc(20 / 750 * 100vw) 0;
  }
  #block1 .pic2,
  #block1 .pic3 {
    width: calc(630 / 750 * 100vw);
    width: 100%;
  }
  #block1 .pic2 {
    margin: 0 0 calc(10 / 750 * 100vw) 0;
  }
  #block1 .num {
    top: calc(624 / 750 * 100vw);
    right: calc(28 / 750 * 100vw);
    width: calc(118 / 750 * 100vw);
  }
  #block1 .num img {
    width: 100%;
  }

/* ---------------------------------------------------------
#block2 sp
----------------------------------------------------------*/
  #block2.block {
    padding: 0 0 calc(158 / 750 * 100vw);
  }
  #block2 h2 {
    position: relative;
    top: auto;
    left: auto;
    width: calc(558 / 750 * 100vw);
    margin-left: calc(64 / 750 * 100vw);
  }
  #block2 h2 img {
    width: 100%;
  }
  #block2 .num {
    top: calc(1031 / 750 * 100vw);
    left: calc(215 / 750 * 100vw);
    width: calc(322 / 750 * 100vw);
  }
  #block2 .num img {
    width: 100%;
  }
  #block2 .col2 {
    margin: calc(-204 / 750 * 100vw) 0 calc(20 / 750 * 100vw);
  }
  #block2 .pic1 {
    width: 100%;
    margin: calc(-48 / 750 * 100vw) 0 0 0;
  }
  #block2 .pic2,
  #block2 .pic3 {
    width: calc(630 / 750 * 100vw);
    margin: 0 auto;
  }
  #block2 .pic2 {
    margin: 0 auto calc(10 / 750 * 100vw);
  }
  #block2 .link-area {
    margin-left: calc(61 / 750 * 100vw);
  }
  
/* ---------------------------------------------------------
#block3 sp
----------------------------------------------------------*/
  #block3.block {
    padding: 0 0 calc(170 / 750 * 100vw);
  }
  #block3 h2 {
    position: relative;
    top: auto;
    left: auto;
    width: calc(520 / 750 * 100vw);
    margin: 0 0 calc(89 / 750 * 100vw) calc(64 / 750 * 100vw);
  }
  #block3 h2 img {
    width: calc(520 / 750 * 100vw);
  }
  #block3 .num {
    position: relative;
    top: auto;
    left: auto;
    width: calc(322 / 750 * 100vw);
    margin: 0 0 calc(51 / 750 * 100vw) calc(64 / 750 * 100vw);
  }
  #block3 .num img {
    width: 100%;
  }
  #block3 .pic {
    width: 100%;
    margin: 0 0 calc(20 / 750 * 100vw) 0;
  }
  #block3 .link-area {
    margin-left: calc(61 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block4 sp
----------------------------------------------------------*/
  #block4 {
    padding-bottom: calc(173 / 750 * 100vw);
  }
  #block4 .pic {
    width: calc(630 / 750 * 100vw);
    width: 100%;
    margin: 0 auto calc(20 / 750 * 100vw);
  }
  #block4 .link-area {
    margin-left: 0;
  }

/* ---------------------------------------------------------
#block5 sp
----------------------------------------------------------*/
  #block5 {
    padding-bottom: calc(171 / 750 * 100vw);
  }
  #block5 .num {
    position: absolute;
    top: calc(-98 / 750 * 100vw);
    right: calc(28 / 750 * 100vw);
    width: calc(118 / 750 * 100vw);
  }
  #block5 .num img {
    width: 100%;
  }
  #block5 .col2 {
    margin-bottom: calc(50 / 750 * 100vw);
  }
  #block5 .pic {
    width: calc(630 / 750 * 100vw);
    width: 100%;
  }
  #block5 .pic1 {
    margin: 0 0 calc(76 / 750 * 100vw) 0;
  }
  #block5 .link-area {
    margin-left: 0;
  }

/* ---------------------------------------------------------
#block6 sp
----------------------------------------------------------*/
  #block6 {
    padding: 0 0 calc(171 / 750 * 100vw);
  }
  #block6 .num {
    position: relative;
    top: auto;
    left: auto;
    width: calc(322 / 750 * 100vw);
    margin: 0 0 calc(54 / 750 * 100vw) calc(64 / 750 * 100vw);
  }
  #block6 .num img {
    width: 100%;
  }
  #block6 .pic {
    width: 100%;
    margin-bottom: calc(59 / 750 * 100vw);
  }
  #block6 .link-area {
    margin-left: calc(62 / 750 * 100vw);
  }
  

/* ---------------------------------------------------------
#block7 sp
----------------------------------------------------------*/
  #block7 {
    padding-bottom: calc(170 / 750 * 100vw);
  }
  #block7 h2 {
    width: calc(620 / 750 * 100vw);
    margin: 0 0 calc(64 / 750 * 100vw) calc(4 / 750 * 100vw);
  }
  #block7 h2 img {
    width: 100%;
  }
  #block7 .col2 {
    width: 100%;
    margin: 0;
  }
  #block7 .txt-block {
    padding-top: calc(59 / 750 * 100vw);
  }
  #block7 .num {
    width: calc(322 / 750 * 100vw);
    margin-bottom: calc(51 / 750 * 100vw);
  }
  #block7 .num img {
    width: 100%;
  }
  #block7 .pic {
    width: 100%;
    margin: 0 0 0 auto;
  }
  
/* ---------------------------------------------------------
#block8 sp
----------------------------------------------------------*/
  #block8 {
    padding: 0 0 calc(170 / 750 * 100vw) 0;
  }
  #block8 .num {
    top: calc(489 / 750 * 100vw);
    right: calc(71 / 750 * 100vw);
    width: calc(235 / 750 * 100vw);
  }
  #block8 .num img {
    width: 100%;
  }
  #block8 .pic {
    width: 100%;
    margin: 0 0 calc(20 / 750 * 100vw) 0;
  }
  #block8 .link-area {
    margin-left: calc(61 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block9 sp
----------------------------------------------------------*/
  #block9 {
    padding: 0 0 calc(180 / 750 * 100vw);
  }
  #block9 .col2 {
    width: 100%;
    margin: 0 0 calc(75 / 750 * 100vw) 0;
  }
  #block9 .left-col {
    margin-bottom: calc(80 / 750 * 100vw);
  }
  #block9 .left-col .pic {
    width: calc(630 / 750 * 100vw);
    margin: 0 auto;
  }
  #block9 .left-col .pic1 {
    margin-bottom: calc(76 / 750 * 100vw);
  }
  #block9 .left-col .pic2 {
    margin-bottom: calc(54 / 750 * 100vw);
  }
 #block9 .txt-block {
    margin-left: calc(61 / 750 * 100vw);
  }
  #block9 .left-col .num {
    width: calc(322 / 750 * 100vw);
    margin-bottom: calc(51 / 750 * 100vw);
  }
  #block9 .left-col .num img {
    width: 100%;
  }
  #block9 .right-col .pic {
    width: 100%;
  }
  #block9 h2 {
    width: calc(513 / 750 * 100vw);
    margin-left: calc(61 / 750 * 100vw);
  }
  #block9 h2 img {
    width: 100%;
  }
  #block9 .movie {
    width: 100%;
    height: auto;
    margin: 0 auto calc(90 / 750 * 100vw);
  }
  #block9 .movie .inner {
    padding-top: calc(500 / 750 * 100vw);
  }
  #background_video1,
  #background_video2 {
    padding-bottom: 71.25vw !important;
    pointer-events: none;
  }

/* ---------------------------------------------------------
#block10 sp
----------------------------------------------------------*/
  #block10 {
    padding: 0 0 calc(171 / 750 * 100vw);
  }
  #block10 .pic1 {
    width: calc(360 / 750 * 100vw);
    padding-left: 0;
  }
  #block10 .pic2 {
    position: relative;
    top: 0;
    right: 0;
    width: calc(598 / 750 * 100vw);
    margin: calc(-265 / 750 * 100vw) 0 0 calc(80 / 750 * 100vw);
  }
  #block10 .txt-block {
    width: calc(570 / 750 * 100vw);
    padding: calc(90 / 750 * 100vw) 0 0 calc(61 / 750 * 100vw);
  }
  #block10 .num {
    width: calc(322 / 750 * 100vw);
    margin-bottom: calc(51 / 750 * 100vw);
  }
  #block10 .num img {
    width: 100%;
  }

/* ---------------------------------------------------------
#block11 sp
----------------------------------------------------------*/
  #block11 {
    padding-bottom: calc(87 / 750 * 100vw);;
  }
  #block11 .col2 {
    padding-left: 0;
    margin-bottom: 0;
  }
  #block11 .pic {
    width: calc(338 / 750 * 100vw);
    margin: 0 0 calc(48 / 750 * 100vw) calc(148 / 750 * 100vw);
  }
  #block11 .txt-block {
    padding-top: 0;
    margin-bottom: calc(175 / 750 * 100vw);
  }
  #block11 .num {
    width: calc(320 / 750 * 100vw);
    margin: 0 0 calc(51 / 750 * 100vw) auto;
  }
  #block11 .num img {
    width: 100%;
  }
  #block11 h2 {
    width: calc(549 / 750 * 100vw);
    margin-left: 0;
  }

/* ---------------------------------------------------------
#block12 sp
----------------------------------------------------------*/
  #block12 {
    padding-bottom: calc(70 / 750 * 100vw);
  }
  #block12 .num {
    position: relative;
    top: auto;
    right: auto;
    width: calc(120 / 750 * 100vw);
    margin-left: calc(-34 / 750 * 100vw);
  }
  #block12 .num img {
    width: 100%;
  }
  #block12 .col2 {
    margin-top: calc(-183 / 750 * 100vw);
  }
  #block12 .col2 .right-col {
    padding-top: 0;
    margin-right: 0;
  }
  #block12 .col2 .left-col {
    margin-bottom: calc(107 / 750 * 100vw);
  }
  #block12 .col2 .pic {
    width: 100%;
    margin-bottom: calc(20 / 750 * 100vw);
  }
  #block12 .col2 .right-col .pic {
    margin-bottom: calc(50 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block13 sp
----------------------------------------------------------*/
  #block13 {
    padding-bottom: calc(159 / 750 * 100vw);
  }
  #block13 .num {
    position: relative;
    top: auto;
    left: auto;
    width: calc(118 / 750 * 100vw);
    margin: 0 calc(-33 / 750 * 100vw) 0 auto
  }
  #block13 .num img {
    width: 100%;
  }
  #block13 .col2 {
    margin-top: calc(-184 / 750 * 100vw);
  }
  #block13 .col2 .right-col {
    padding-top: 0;
    margin-left: 0;
  }
  #block13 .col2 .left-col {
    margin-bottom: calc(107 / 750 * 100vw);
  }
  #block13 .col2 .pic {
    width: 100%;
    margin-bottom: calc(20 / 750 * 100vw);
  }
  #block13 .col2 .right-col .pic {
    margin-bottom: calc(50 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block14 sp
----------------------------------------------------------*/
  #block14 {
    padding: 0 0 calc(171 / 750 * 100vw);
  }
  #block14 .num {
    position: relative;
    top: auto;
    left: auto;
    width: calc(319 / 750 * 100vw);
    margin-left: calc(66 / 750 * 100vw);
  }
  #block14 .num img {
    width: 100%;
  }
  #block14 .pic {
    width: 100%;
    margin: calc(-40 / 750 * 100vw) auto calc(20 / 750 * 100vw);
  }
  #block14 .link-area {
    margin-left: calc(61 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block15 sp
----------------------------------------------------------*/
#block15 {
  width: 100%;
  background: url(../img/pic_17_05_sp.jpg) no-repeat center top;
  background-size: 100% auto;
  padding: calc(76 / 750 * 100vw) 0 0 0;
  margin-bottom: calc(170 / 750 * 100vw);
}
  #block15 h2 {
    position: relative;
    top: auto;
    left: auto;
    width: calc(494 / 750 * 100vw);
    margin: 0 0 calc(80 / 750 * 100vw) calc(210 / 750 * 100vw);
  }
  #block15 h2 img {
    width: 100%;
  }
  #block15 .col2 {
    position: relative;
    top: auto;
    left: auto;;
    width: calc(630 / 750 * 100vw);
    margin: 0 auto;
  }
  #block15 .block-inner {
    position: relative;
    width: 100%;
  }
  #block15 .block-inner:nth-child(even) {
    margin-left: 0;
  }
  #block15 .block-inner:nth-child(1),
  #block15 .block-inner:nth-child(2),
  #block15 .block-inner:nth-child(3) {
    margin-bottom: calc(170 / 750 * 100vw);
  }
  #block15 .block-inner .num {
    top: calc(30 / 750 * 100vw);
    left: calc(35 / 750 * 100vw);
    width: calc(72 / 750 * 100vw);
  }
  #block15 .block-inner .num img {
    width: 100%;
  }
  #block15 .block-inner .pic {
    margin-bottom: calc(20 / 750 * 100vw);
  }
  #block15 .block-inner:nth-child(1) .link-area a,
  #block15 .block-inner:nth-child(2) .link-area a {
    color: #000;
  }
  #block15 .block-inner:nth-child(1) .link-area .btn,
  #block15 .block-inner:nth-child(2) .link-area .btn {
    border: 1px solid #000;
  }
  #block15 .block-inner:nth-child(1) li a:hover .btn,
  #block15 .block-inner:nth-child(2) li a:hover .btn {
    background: #000;
    color: #fff;
  }

/* ---------------------------------------------------------
#block16 sp
----------------------------------------------------------*/
  #block16 {
    padding: 0 0 calc(172 / 750 * 100vw);
  }
  #block16 .pic1 {
    width: 100%;
    margin: 0;
  }
  #block16 h2 {
    position: absolute;
    top: calc(65 / 750 * 100vw);
    left: calc(61 / 750 * 100vw);
    width: calc(506 / 750 * 100vw);
  }
  #block16 h2 img {
    width: 100%;
  }
  #block16 .col2 {
    width: calc(630 / 750 * 100vw);
    margin: calc(-408 / 750 * 100vw) auto 0;
  }
  #block16 .block-inner {
    width: 100%;
  }
  #block16 .block-inner:nth-child(even) {
    margin-left: 0;
  }
  #block16 .block-inner:nth-child(1),
  #block16 .block-inner:nth-child(2),
  #block16 .block-inner:nth-child(3) {
    margin-bottom: calc(170 / 750 * 100vw);
  }
  #block16 .block-inner .num {
    top: calc(30 / 750 * 100vw);
    left: calc(35 / 750 * 100vw);
    width: calc(72 / 750 * 100vw);
  }
  #block16 .block-inner .num img {
    width: 100%;
  }
  #block16 .block-inner .pic {
    margin-bottom: calc(20 / 750 * 100vw);
  }
  
/* ---------------------------------------------------------
#block17 sp
----------------------------------------------------------*/
  #block17 {
    padding: 0 0 calc(79 / 750 * 100vw);
  }
  #block17 h2 {
    width: calc(518 / 750 * 100vw);
    margin: 0 0 calc(91 / 750 * 100vw) calc(61 / 750 * 100vw);
  }
  #block17 h2 img {
    width: 100%;
  }
  #block17 .movie {
    width: 100%;
    height: auto;
  }
  #block17 .movie .inner {
    padding-top: calc(500 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block18 sp
----------------------------------------------------------*/
  #block18 .num {
    position: relative;
    top: auto;
    right: auto;
    width: calc(119 / 750 * 100vw);
    margin: 0 calc(-32 / 750 * 100vw) 0 auto;
  }
  #block18 .num img {
    width: 100%;
  }
  #block18 .col2 {
    margin: calc(-181 / 750 * 100vw) 0 calc(20 / 750 * 100vw);
  }
  #block18 .pic {
    width: 100%;
    margin: 0 auto;
  }
  #block18 .pic1 {
    margin: 0 0 calc(10 / 750 * 100vw);
  }
  #block18 .link-area {
    margin-left: 0;
  }

/* ---------------------------------------------------------
#block19 sp
----------------------------------------------------------*/
  #block19 {
    padding-bottom: calc(170 / 750 * 100vw);
  }
  #block19 .num {
    width: calc(235 / 750 * 100vw);
    padding: 0;
    margin: 0 auto calc(60 / 750 * 100vw);;
  }
  #block19 .num img {
    width: 100%;
  }
  #block19 .pic {
    width: 100%;
    margin-bottom: calc(20 / 750 * 100vw);
  }
  
/* ---------------------------------------------------------
#block20 sp
----------------------------------------------------------*/
  #block20 {
    padding: 0 0 calc(170 / 750 * 100vw);
  }
  #block20 .pic {
    width: 100%;
    margin: 0 auto calc(20 / 750 * 100vw);
  }
  #block20 .num {
    top: calc(711 / 750 * 100vw);
    right: calc(107 / 750 * 100vw);
    width: calc(119 / 750 * 100vw);
  }
  #block20 .num img {
    width: 100%;
  }
  #block20 .link-area {
    margin-left: calc(61 / 750 * 100vw);
  }

/* ---------------------------------------------------------
#block21 sp
----------------------------------------------------------*/
  #block21 {
    padding-bottom: calc(170 / 750 * 100vw);
  }
  #block21 .pic {
    width: 100%;
    margin: 0 auto calc(20 / 750 * 100vw);
  }
  #block21 .num {
    top: calc(-99 / 750 * 100vw);
    left: calc(26 / 750 * 100vw);
    width: calc(118 / 750 * 100vw);
  }
  #block21 .num img {
    width: 100%;
  }

/* ---------------------------------------------------------
#block22 sp
----------------------------------------------------------*/
  #block22 {
    padding-bottom: calc(178 / 750 * 100vw);
    margin-top: 0;
  }
  #block22 .pic {
    width: calc(300 / 750 * 100vw);
    margin: 0 0 0 auto;
  }
  #block22 h2 {
    width: calc(501 / 750 * 100vw);
    margin: calc(-423 / 750 * 100vw) 0 0;
  }
  #block22 h2 img {
    width: 100%;
  }

/* ---------------------------------------------------------
#block23 sp
----------------------------------------------------------*/
  #block23 {
    padding-bottom: 0;
  }
  #block23 .pic {
    width: 100%;
    margin: 0 auto calc(20 / 750 * 100vw);
  }
  #block23 .num {
    position: absolute;
    top: calc(-99 / 750 * 100vw);
    left: auto;
    right: calc(28 / 750 * 100vw);
    width: calc(118 / 750 * 100vw);
  }
  #block23 .num img {
    width: 100%;
  }
  #block23 .link-area {
    margin-left: 0;
  }
  
/* ---------------------------------------------------------
.bottom sp
----------------------------------------------------------*/
  .bottom {
    padding: calc(140 / 750 * 100vw) 0 0;
  }
  .bottom .btn-all {
    margin-bottom: calc(270 / 750 * 100vw);
  }
  .bottom .btn-all a {
    width: calc(420 / 750 * 100vw);
    height: calc(74 / 750 * 100vw);
    font-size: calc(28 / 750 * 100vw);
  }
  .bottom .pic {
    width: calc(280 / 750 * 100vw);
    margin: 0 auto calc(120 / 750 * 100vw);
  }
  .bottom h3 {
    width: calc(625 / 750 * 100vw);
    margin: 0 auto calc(50 / 750 * 100vw);
  }
  .bottom h3 img {
    width: calc(625 / 750 * 100vw);
  }
  .bottom .txt {
    width: 84vw;
    font-size: 2.93vw;
    line-height: 2.27;
    letter-spacing: 0;
    word-break: break-all;
    margin: 0 auto 20vw;
  }
  .bottom .staff {
    font-size: 2.66vw;
    letter-spacing: 0;
  }
  
/* ---------------------------------------------------------
footer sp
----------------------------------------------------------*/
  footer {
    padding: calc(180 / 750 * 100vw) 0 8vw;
  }
  footer .logo {
    width: 26.66vw;
    margin: 0 auto 12.8vw;
  }
  footer ul {
    display: block;
    margin-bottom: 17.46vw;
  }
  footer li {
    font-size: 3.73vw;
    letter-spacing: .030em;
    text-align: center;
    margin: 0 0 7vw 0;
  }
  footer li:last-child {
    margin: 0;
  }
  footer li::after {
    content: none;
    margin-left: 0;
  }
  footer p {
    font-size: 2.66vw;
    letter-spacing: .033em;
  }
  footer .pagetop {
    bottom: 8vw;
    right: 8.26vw;
    width: 8.26vw;
  }
  footer .pagetop img {
    width: 8.26vw;
  }

  
}