@charset "UTF-8";

/* common class
---------------------------------------------------------------------------- */

body {
  color: #fff;
	font-family: YuGothic,'Yu Gothic','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
	width: 100%;
  background: #000;
  min-width: 1240px;
}
@media screen and (max-width:768px) {
  body {
    min-width: 0;
    width: 100%;
  }
}
img{height: auto}

.fnt-f-LM{font-family: le-monde-livre-std, serif;font-style: normal;font-weight: 300;}
.fnt-w-BK{font-weight: 400;}
.fnt-w-DM{font-weight: 500;}
.fnt-w-BLD{font-weight: 700;}
@media screen and (min-width:769px) { .pc-none{ display: none; } }
@media screen and (max-width:768px) {	.sp-none{ display: none; } }
a{
	color: inherit;
	font-size: inherit;
	text-decoration: none;
	transition: .3s;
}
.hover-opa{ transition: .3s; }
.hover-opa:hover{
	cursor: pointer;
	opacity: .6;
	transition: .3s;
}

.main-cont-wrap{
  display: none;
}

.lity-active,
.open-anime{
    overflow: hidden;
}

/*.lity-active .main-cont-wrap{
  position: fixed;
  overflow: hidden;
  width: 100%;
  height: 100vh;
  top:-200px;
}*/

/* loading
---------------------------------------------------------------------------- */
.loading-wrap{
  align-items: center;
  background: #000;
  display: flex;
  justify-content: center;
  height: 100vh;
  left: 0;
  min-width: 1240px;
  position: fixed;
  top:0;
  width: 100%;
  z-index: 1100;
}
@media screen and (max-width:768px) {
  .loading-wrap{
    min-width: 0;
  }
}

.loading-wrap .loading-inner{
  display: block;
  overflow: hidden;
  position: relative;
  text-align: center;
  width: 100%;
}
@media screen and (max-width:768px) {
  .loading-wrap .loading-inner{
    margin-bottom: 17vh;
  }
}

.loading-wrap .loading-inner::before{
  border-top: 1px solid rgba(255,255,255,.4);
  content: "";
  display: block;
  height: 0;
  position: absolute;
  right: 0;
  top:15px;
  width: 100vw;
  
  -webkit-animation: ldBdrTop 1s linear 0s li;
  animation: ldBdrTop 1s linear 0s;
}
@media screen and (max-width:768px) {
  .loading-wrap .loading-inner::before{
    top:2.2vw;
  }
}

@-webkit-keyframes ldBdrTop {
    0% { right: 100vw; }
  100% { right: 0;}
}
.loading-wrap .loading-inner.loaded::before{
  right: -100vw;
  -webkit-animation: ldBdrTop-ldd 1s linear 0s li;
  animation: ldBdrTop-ldd 1s linear 0s;
}
@-webkit-keyframes ldBdrTop-ldd {
    0% { right: 0; }
  100% { right: -100vw;}
}

.loading-wrap .loading-inner::after{
  border-top: 1px solid rgba(255,255,255,.4);
  bottom:16px;
  content: "";
  display: block;
  height: 0;
  left: 0;
  position: absolute;
  width: 100vw;
  
  -webkit-animation: ldBdrBtm 1s linear 0s li;
  animation: ldBdrBtm 1s linear 0s;
}
@media screen and (max-width:768px) {
  .loading-wrap .loading-inner::after{
    bottom:2.7vw;
  }
}

@-webkit-keyframes ldBdrBtm {
    0% {left: 100vw;}
  100% {left: 0;}
}
.loading-wrap .loading-inner.loaded::after{
  left: -100vw;
  -webkit-animation: ldBdrBtm-ldd 1s linear 0s li;
  animation: ldBdrBtm-ldd 1s linear 0s;
}
@-webkit-keyframes ldBdrBtm-ldd {
    0% {left: 0;}
  100% {left: -100vw;}
}

.loading-wrap .loading-inner svg{
  height: auto;
  width: 600px;
}
@media screen and (max-width:768px) {
  .loading-wrap .loading-inner svg{
    min-width: 0;
    margin: 0 1.6vw;
    width: auto;
  }
}

.loading-wrap .cls-3{
fill:#000;
stroke-dasharray: 1000;
stroke-dashoffset: 0;
stroke-width: 1;
stroke:#999;
  -webkit-animation: titlAnm 2.5s ease-in 0s;
  animation: titlAnm 2.5s ease-in 0s;
}
@-webkit-keyframes titlAnm {
    0% {
      stroke-dashoffset: 1000;
      fill:transparent;
        }
   60% {
      fill:transparent;
        }
  100% {
      stroke-dashoffset: 0;
      fill:transparent;
        }
}
.loading-wrap .cls-3.anmFo{
  fill:#fffee4;
  transition: 1s;
}


/* movie
---------------------------------------------------------------------------- */
.top-movie-wrap{
  background: #000;
  align-items: center;
  display: flex;
  justify-content: center;
  height: 100vh;
  position: fixed;
  width: 100%;
  min-width: 1240px;
  z-index: 1000;
    overflow: hidden;
}
@media screen and (max-width:768px) {
  .top-movie-wrap{
    min-width: 0;
    width: 100%;
  }
}

.top-movie{
  height: 100%;
  position: relative;
  width: 100%;
}
@media screen and (max-width:768px) {
  .top-movie{
    min-width: 0;
    width: 100%;
  }
}

.top-movie .yt-wrap{
  align-items: center;
  display: flex;
  justify-content: center;
  height: 100%;
  padding: 0 10vw;
  width: 100%;
}

.top-movie .yt-full-width{
  position: relative;
  height: 0;
  width: 100%;
  padding-top: 56.25%;
}
@media screen and (max-width:480px) {
  .top-movie .yt-full-width{
    margin-bottom: 16vh;
  }
}

.top-movie .yt-full-width iframe{
  position: absolute;
  top:0;
  left:0;
  width: 100%;
  height: 100%;
}

.top-movie .btn-video-close{
  color: #fff;
  display: inline-block;
  font-size: 14px;
  letter-spacing: .1em;
  position: absolute;
  right: 40px;
  top: 40px;
  text-align: center;
  z-index: 1;
}
@media screen and (max-width:768px) {
  .top-movie .btn-video-close{
    font-size: 2.98vw;
    right: 3.2vw;
    top: 5.33vw;
    width: 16vw;
    z-index: 1;
  }
}

.top-movie .btn-video-close.visible{
  opacity: 1;
  transition: 1s;
}
.top-movie .btn-video-close img{
  display: block;
}

/* contents
---------------------------------------------------------------------------- */
.contents-wrap{
  overflow: hidden;
  position: relative;
  width: 100%;
  z-index: 1;
  display: none;
}

.contents-wrap .cont-shadow-box{
  -webkit-box-shadow: inset 0px 0px 80px 52px rgba(0,0,0,0.4);
  -moz-box-shadow: inset 0px 0px 80px 52px rgba(0,0,0,0.4);
  box-shadow: inset 0px 0px 80px 52px rgba(0,0,0,0.4);
  height: 100vh;
  left:0;
  padding: 3.22vw;
  position: fixed;
  top:0;
  width: 100%;
  z-index: 800;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-shadow-box{
    -webkit-box-shadow: inset 0px 0px 72vw 30px rgba(0,0,0,1);
    -moz-box-shadow: inset 0px 0px 72vw 30px rgba(0,0,0,1);
    box-shadow: inset 0px 0px 72vw 110px rgba(0,0,0,1);
    height: 240vh;
    left: auto;
    right:-140px;
    padding: 3.22vw;
    position: fixed;
    top: -140vh;
    width: 300vw;
    z-index: 800;
  }
}

.contents-wrap .title-box{
  display: block;
  height: auto;
  left:0;
  opacity: 0;
  padding: 0;
  position: absolute;
  top:21.48vw;
  text-align: center;
  width: 100%;
  z-index: 2;
}
@media screen and (max-width:768px) {
  .contents-wrap .title-box{
    top:51.93vw;
  }
}

.contents-wrap .title-box.show{
  opacity: 1;
  transition: 2s;
}
.contents-wrap .title-box img{
  width: 48.62%;
}
@media screen and (max-width:768px) {
  .contents-wrap .title-box img{
    width: 80vw;
  }
}

.contents-wrap .img-ss-box{
  padding-top:110vh;
  position: relative;
  z-index: 3;
}
@media screen and (max-width:768px) {
  .contents-wrap .img-ss-box{
    left: calc(50% - 85vw);
    width: 170vw;
  }
}

.contents-wrap .img-ss-box img{
    width: 100%;
}

.contents-wrap .img-ss-box.move{
  transition: .3s;
  padding-top:27.58vw;
  
  -webkit-animation: ssMov 1.5s ease-in-out 0s;
  animation: ssMov 1.5s ease-in-out 0s;
}
@-webkit-keyframes ssMov {
    0% { padding-top:100vh;}
  100% { padding-top:27.58vw;}
}

@media screen and (max-width:768px) {
  .contents-wrap .img-ss-box.move{
    transition: .3s;
    padding-top:64.53vw;

    -webkit-animation: ssMov 1.5s ease-in-out 0s;
    animation: ssMov 1.5s ease-in-out 0s;
  }
  @-webkit-keyframes ssMov {
      0% { padding-top:100vh;}
    100% { padding-top:64.53vw;}
  }
}

.contents-wrap .img-ss-box.off{
  opacity: 0;
  transition: .5s;
}

.contents-wrap .cont-box{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100vh;
  left:0;
  padding: 3.22vw;
  position: fixed;
  transition: 1.5s;
  top:0;
  width: 100%;
  z-index: 850;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box{
    position: absolute;
  }
}
@media screen and (max-width:480px) {
  .contents-wrap .cont-box{
    padding: 5.33vw 3.2vw 23.22vw;
  }
}

.contents-wrap .cont-box .upper{
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.contents-wrap .cont-box .upper p.auth{
  font-size: 14px;
  line-height: 2em;
  letter-spacing: .2em;
  margin-top: 33px;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .upper p.auth{
    font-size: 2.66vw;
    margin-top: 5.33vw;
  }
}

.contents-wrap .cont-box .upper.bdrTop::before{
  border-top: 1px solid #666;
  content: "";
  display: block;
  height: 0;
  left: 0;
  position: absolute;
  top:0;
  width: 100%;
  
  -webkit-animation: cntBtop .5s linear 0s li;
  animation: cntBtop .5s linear 0s;
}
@-webkit-keyframes cntBtop {
    0% {left:-100%;}
  100% {left:0;}
}

.contents-wrap .cont-box .lower{
  align-items: flex-end;
  display: flex;
  justify-content: space-between;
  position: relative;
}

@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower dl{
    width: 56vw;
  }
}

.contents-wrap .cont-box .lower dl dt{
  background: #fff;
  color: #222;
  font-size: 14px;
  letter-spacing: .2em;
  margin-bottom: 16px;
  text-align: center;
  width: 60px;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower dl dt{
    font-size: 3.2vw;
    letter-spacing: .2em;
    margin-bottom: 4.26vw;
    width: 16vw;
  }
}

.contents-wrap .cont-box .lower dl dd{
  display: flex;
  font-size: 14px;
  line-height: 2;
  text-shadow:0px 2px 2px #000000;
  width: 434px;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower dl dd{
    display: block;
    font-size: 3.2vw;
    margin-bottom: 4.4vw;
    text-shadow:0px 2px 4px #000000;
    width: auto;
  }
}

.contents-wrap .cont-box .lower dl dd span.date{
  margin-right: 16px;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower dl dd span.date{
    display: block;
  }
}

.contents-wrap .cont-box .lower .yt-box{
  align-items: center;
  background: url("../img/top_sub_yt_thumb.jpg") center center /cover no-repeat;
  border: 1px solid #666;
  display: flex;
  height: 56.25%;
  
  position: relative;
  width: 240px;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower .yt-box{
    background: url("../img/top_sub_yt_thumb.jpg") center center /cover no-repeat;
    display: block;
    height: 18vw;
    position: relative;
    width: 32vw;
  }
}

.contents-wrap .cont-box .lower .yt-box a{
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  width: 100%;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower .yt-box a img{
    width: 8.26vw;
  }
}

.contents-wrap .cont-box .lower .icn-scroll{
  position: absolute;
}

.contents-wrap .cont-box .lower.bdrBtm::before{
  border-bottom: 1px solid #666;
  bottom:0;
  content: "";
  display: block;
  height: 0;
  position: absolute;
  right: 0;
  width: calc(100% - 56px);
  
  -webkit-animation: cntBbtm .5s linear 0s li;
  animation: cntBbtm .5s linear 0s;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower.bdrBtm::before{
    width: 100%;
  }
}
@-webkit-keyframes cntBbtm {
    0% {width: 0;}
  100% {width: calc(100% - 56px);}
}

.contents-wrap .cont-box .upper .upper-move{
  opacity: 0;
  position: relative;
  transition: 1s ease;
  top: -3.22vw;
}
.contents-wrap .cont-box .upper .upper-move.move{
  opacity: 1;
  top: 0;
}
.contents-wrap .cont-box .lower .lower-move{
  bottom: -3.22vw;
  opacity: 0;
  position: relative;
  transition: 1s ease;
}
.contents-wrap .cont-box .lower .lower-move.move{
  bottom: 0;
  opacity: 1;
  min-height: 135px;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower .lower-move.move{
    bottom: 0;
    opacity: 1;
    min-height: 18vw;
  }
}

.contents-wrap .cont-box .lower .icn-scroll{
  bottom: -32px;
  display: none;
  left: 0;
  position: absolute;
}
.contents-wrap .cont-box .lower .icn-scroll.move{
  display: block;

  -webkit-animation: scrl 2s ease-in 0s;
  animation: scrl 2s ease-in 0s;
  animation-iteration-count:infinite;
}
@media screen and (max-width:768px) {
  .contents-wrap .cont-box .lower .icn-scroll.move{
    display: none;
  }
}
@-webkit-keyframes scrl {
    0% {
      opacity: 0;
      bottom: 0;
        }
   40% {
      opacity: .7;
        }
  80% {
      opacity: 0;
    bottom: -42px;
    
        }
  100% {
      opacity: 0;
    
        }
}

.lower-block-wrap{
  position: fixed;
  top:0;
  width: 100%;
}


/* detail
---------------------------------------------------------------------------- */
.detail-wrap{
  background: rgba(0,0,0,.2) /*url("../img/detail-bg.png") center top /contain repeat-y*/;
  display: none;
  opacity: 0;
  padding: 200px 0 0;
  position: relative;
  text-align: center;
}
@media screen and (max-width:768px) {
  .detail-wrap{
    /*background-image: url("../img/detail-bg_sp.png") ;
      background-size: 100% 100%;
      background-repeat: repeat-y;
      background-position: center top;*/
    padding: 21.33vw 3.2vw 0;
  }
}
.detail-wrap svg{
  height: 80px;
  margin: 0 auto 96px;
  width: 100%;
}
@media screen and (max-width:768px) {
  .detail-wrap svg{
    height: 6.66vw;
    margin: 0 auto 10.66vw;
    width: auto;
  }
}

.detail-wrap .title-box02{
  position: relative;
  z-index: 1;
}

.detail-wrap .cls-int{
  fill:transparent;
  letter-spacing: .16em;
  stroke: transparent;
  stroke-linejoin: round;
  stroke-width: 1px;
  stroke-dasharray: 1000;
  stroke-dashoffset: 0;
  text-anchor: middle;
}
.detail-wrap .cls-int.draw{
  stroke: #fff;
  
  -webkit-animation: intAnm 2.5s ease-in 0s;
  animation: intAnm 2.5s ease-in 0s;  
}
@-webkit-keyframes intAnm {
    0% {
      stroke-dashoffset: 1000;
      fill:transparent;
        }
   60% {
      fill:transparent;
        }
  100% {
      stroke-dashoffset: 0;
      fill:transparent;
        }
}
.detail-wrap .txt-box{
  margin: 0 auto;
  position: relative;
  width: 760px;
  z-index: 1;
}
@media screen and (max-width:768px) {
  .detail-wrap .txt-box{
    margin: 0 auto;
    position: relative;
    width: auto;
    z-index: 1;
  }
}

.detail-wrap .txt-box p{
  font-size: 16px;
  line-height: 4em;
  letter-spacing: .2em;
  margin-bottom: 72px;
}
@media screen and (max-width:768px) {
  .detail-wrap .txt-box p{
    font-size: 3.2vw;
    margin-bottom: 10.66vw;
  }
}

.detail-wrap .link-box{
  border: 1px solid #666;
  display: inline-block;
  height: 50px;
  line-height: 50px;
  width: 280px;
}
@media screen and (max-width:768px) {
  .detail-wrap .link-box{
    font-size: 3.2vw;
    height: 8.53vw;
    line-height: 8.53vw;
    width: 48vw;
  }
}


/* footer
---------------------------------------------------------------------------- */

footer{
  /*background: url("../img/detail-bg.png") center top /contain repeat-y;*/
  display: none;
  padding: 112px 3.22vw;
  position: relative;
  text-align: center;
  z-index: 890;
}
@media screen and (max-width:768px) {
  footer{
    /*background-image: url("../img/detail-bg_sp.png") ;
      background-size: 100% 100%;
      background-repeat: repeat-y;
      background-position: center top;*/
    display: none;
    padding: 21.33vw 3.2vw;
  }
}

footer .upper-box{
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
}
@media screen and (max-width:768px) {
  footer .upper-box{
    position: relative;
    margin-bottom: 26.66vw;
  }
}

footer .upper-box .logo-box{
  width: 442px;
}
@media screen and (max-width:768px) {
  footer .upper-box .logo-box{
    position: absolute;
    top:35.33vw;
    width: 100%;
    text-align: center;
  }
  footer .upper-box .logo-box img{
    width: 58.66vw;
  }
}

footer .logo-sunrise{
  margin: 0 auto 36px;
  width: 200px;
}
@media screen and (max-width:768px) {
  footer .logo-sunrise{
    margin: 0 auto 5.33vw;
    width: 26.66vw;
  }
}

footer p.notice{
  font-size: 12px;
  letter-spacing: .2em;
  line-height: 1;
  margin-bottom: 80px;
}
@media screen and (max-width:768px) {
  footer p.notice{
    font-size: 2.66vw;
    line-height: 2;
    margin-bottom: 10.13vw;
  }
}

footer p.notice a{
  color: #d80000;
}
footer small{
  font-size: 12px;
  letter-spacing: .2em;
  line-height: 1;
}
@media screen and (max-width:768px) {
  footer small{
    font-size: 2.66vw;
  }
}

/* comment
---------------------------------------------------------------------------- */
#comment{
  padding: 0;
  position: relative;
}
#comment .comment-wrap{
  height: 80vh;
  margin-top: 40px;
  margin: 0 auto;
  overflow: hidden;
  width: 810px;
}
@media screen and (max-width:768px) {
  #comment .comment-wrap{
    height: 80vh;
    margin-top: 40px;
    margin: 0 auto;
    overflow: hidden;
    width: auto;
  }
}

#comment .comment-wrap .comment-inner{
  height: 100%;
  overflow-y: scroll;
  padding-right: 20px;
  width: calc(100% + 20px);
}
#comment .comment-wrap .cls-comm{
  fill:transparent;
  letter-spacing: .16em;
  stroke-linejoin: round;
  stroke-width: 1px;
  stroke-dasharray: 1000;
  stroke-dashoffset: 0;
  stroke: #fff;
  text-anchor: middle;
  
  -webkit-animation: commAnm 2.5s ease-in 0s;
  animation: commAnm 2.5s ease-in 0s;
  
}
@-webkit-keyframes commAnm {
    0% {
      stroke-dashoffset: 1000;
      fill:transparent;
        }
   60% {
      fill:transparent;
        }
  100% {
      stroke-dashoffset: 0;
      fill:transparent;
        }
}
#comment .comment-wrap svg{
  display: block;
  margin: 0 auto 80px;
  height: 80px;
}
@media screen and (max-width:768px) {
  #comment .comment-wrap svg{
    height: 6.93vw;
    margin: 0 auto 10.66vw;
    text-align: center;
  }
}

#comment p.sub-lead{
  font-size: 14px;
  letter-spacing: .2em;
  line-height: 4em;
  margin-bottom: 64px;
  text-align: center;
}
@media screen and (max-width:768px) {
  #comment p.sub-lead{
    font-size: 3.2vw;
    margin-bottom: 17.06vw;
    padding: 0 3.2vw;
  }
}

@media screen and (max-width:768px) {
  #comment .detail-box{
    padding: 0 3.2vw;
  }
}

#comment .detail-box p.name{
  margin-bottom: 32px;
}
@media screen and (max-width:768px) {
  #comment .detail-box p.name{
    margin-bottom: 4.26vw;
  }
}

#comment .detail-box p.name span{
  display: block;
  font-size: 12px;
  margin-top: 16px;
}
@media screen and (max-width:768px) {
  #comment .detail-box p.name span{
    display: block;
    font-size: 2.66vw;
    margin-top: 8px;
  }
}

#comment .detail-box p.prof-box{
  font-size: 14px;
  line-height: 2em;
  margin-bottom: 32px;
}
@media screen and (max-width:768px) {
  #comment .detail-box p.prof-box{
    font-size: 3.2vw;
    margin-bottom: 10.66vw;
  }
}

@media screen and (max-width:768px) {
  #comment .hist-box{
    padding: 0 3.2vw;
  }
}

#comment .hist-box p.label{
  background: #fff;
  color: #222;
  display: inline-block;
  font-size: 12px;
  line-height: 1;
  margin-bottom: 12px;
  padding: .1em .5em;
}
@media screen and (max-width:768px) {
  #comment .hist-box p.label{
    font-size: 3.2vw;
    margin-bottom: 2.66vw;
  }
}

#comment .hist-box table th,
#comment .hist-box table td{
  font-weight: normal;
  font-size: 14px;
  line-height: 1.5;
  padding: .5em .2em;
  vertical-align: top;
}
@media screen and (max-width:768px) {
  #comment .hist-box table th,
  #comment .hist-box table td{
    font-size: 3.2vw;
    padding: .5em .2em;
  }
}

#comment .hist-box table th{
  width: 6em;
}
@media screen and (max-width:768px) {
  #comment .hist-box table th{
    width: 5em;
  }
}
#ytMovie{
  width: 100%;
    height: 0;
    overflow: hidden;
    padding-top: 56.25%;
}
#ytMovie iframe{
      position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #000;
}

.lity-close,
.lity-close:hover{
  background: url("../img/btn_movie_close.png") center center /contain no-repeat;
  color: transparent;
  height: 34px;
  right: 40px;
  top: 40px;
  transition: .3s;
  width: 120px;
}
@media screen and (max-width:768px) {
  .lity-close,
  .lity-close:hover{
    background: url("../img/btn_movie_close.png") center center /contain no-repeat;
    color: transparent;
    font-size: 0;
    height: 5vw;
    line-height: 1;
    right: 3.2vw;
    top: 5.33vw;
    transition: .3s;
    width: 16vw;
  }
}

.lity-close:hover{
  opacity: .7;
  transition: .3s;
}
.lity-close::after{
  content: "CLOSE";
  color: #fff;
  display: block;
  font-family: le-monde-livre-std, serif;font-style: normal;font-weight: 300;
  font-size: 14px;
  letter-spacing: .1em;
  line-height: 1;
  position: absolute;
  right: 40px;
  top: 40px;
  text-align: center;
  z-index: 1;
}
@media screen and (max-width:768px) {
  .lity-close::after{
    font-size: 2.98vw;;
    right: 2.8vw;
    padding-top: 3.43vw;
    top:3.43vw;
  }
  .lity-close img{
    margin-bottom: 1.33vw;
  }
}

/* parts
---------------------------------------------------------------------------- */
.sns-box{
  text-align: left;
  width: 130px;
}
@media screen and (max-width:768px) {
  .sns-box{
    width: auto;
  }
}

.sns-box p{
  background: #fff;
  color: #222;
  display: inline-block;
  font-size: 12px!important;
  line-height: 1;
  letter-spacing: .2em;
  margin-bottom: 12px!important;
  padding: .1em .5em .1em .6em!important;
}
@media screen and (max-width:768px) {
  .sns-box p{
    font-size: 3.2vw!important;
    margin-bottom: 3.2vw!important;
  }
}

.sns-box ul{
  align-items: center;
  display: flex;
}
.sns-box ul li{
  margin-right: 19px;
}
@media screen and (max-width:768px) {
  .sns-box ul li{
    margin-right: 5.33vw;
    
  }
  .sns-box ul li img{
    height: 10.33vw;
  }
}

.totop{
  text-align: right;
  width: 130px;
}
.totop img{
  width: 41px;
}
@media screen and (max-width:768px) {
  .totop{
    text-align: right;
    width: 4.8vw;
  }
}


.lang-slct{
  display: flex;
  justify-content: flex-end;
}
.lang-slct p{
  background: #000;
  border: 1px solid #666;
  font-size: 14px;
  height: 32px;
  line-height: 32px;
  letter-spacing: .2em;
  text-align: center;
  width: 50px;
}
@media screen and (max-width:768px) {
  .lang-slct p{
    font-size: 3.73vw;
    height: 7.66vw;
    line-height: 7.66vw;
    width: 13.33vw;
  }
}

.lang-slct p.current{
  border: none;
  background: #fff;
  color: #000;
}
.btn-tw{
  align-items: center;
  display: flex;
  font-size: 12px;
  justify-content: center;
  letter-spacing: .2em;
  position: fixed;
  right: 5px;
  top:calc(50% - 50px);
  transform: rotate(90deg);
  opacity: 0;
  z-index: 1000;
}
@media screen and (max-width:768px) {
  .btn-tw{
    align-items: center;
    display: flex;
    font-size: 12px;
    justify-content: center;
    letter-spacing: .2em;
    position: absolute;
    right: -6.4vw;
    top:50%;
  }
}

.btn-tw.move{
  opacity: 1;
}

.btn-tw img{
  transform: rotate(-90deg);
  margin-left: 16px;
  width: 26px;
}

.img-earth-box{
  display: block;
  height: auto;
  left:0;
  min-width: 1240px;
  position: fixed;
  top:calc(50vh - 5.75%);
  text-align: center;
  width: 100%;
  z-index: 0;
}
@media screen and (max-width:768px) {
  .img-earth-box{
    min-width: 0;
    }
}

.img-earth-box img{
  width: 21.29%;
}
@media screen and (max-width:768px) {
  .img-earth-box img{
    width: 35.2vw;
  }
}

.img-earth-box.move{
  top:4.22vw;
  -webkit-animation: earthMov 1.5s ease-in-out 0s;
  animation: earthMov 1.5s ease-in-out 0s;
}
@-webkit-keyframes earthMov {
    0% {
      top:calc(50vh - 6%);
        }
  100% {
      top:4.22vw;
        }
}
@media screen and (max-width:768px) {
  .img-earth-box.move{
    top:22.4vw;
    -webkit-animation: earthMov_sp 1.5s ease-in-out 0s;
    animation: earthMov_sp 1.5s ease-in-out 0s;
  }
  @-webkit-keyframes earthMov_sp {
      0% {
        top:calc(50vh - 6%);
          }
    100% {
        top:22.4vw;
          }
  }
}

/* news
---------------------------------------------------------------------------- */
#news header{
  padding: 3.22vw 3.22vw 0;
}
@media screen and (max-width:768px) {
  #news header{
    background: #000;
    padding: 5.33vw 3.22vw 0;
  }
}

#news header .lang-slct{
    position: relative;
  margin-bottom: 16px;
}
@media screen and (max-width:768px) {
  #news header .lang-slct{
    margin-bottom: 0;
  }
}

#news header .lang-slct::before{
  border-top: 1px solid #666;
  content: "";
  display: block;
  height: 0;
  left: 0;
  position: absolute;
  top:0;
  width: 100%;
    z-index: 20;

}
@-webkit-keyframes cntBtopN {
    0% {left:-100%;}
  100% {left:0;}
}

#news header h1{
  margin-bottom: 20px;
  width: 360px;
}
@media screen and (max-width:768px) {
  #news header h1{
    margin-bottom: 0;
    width: 48vw;
  }
}

#news header .title-box{
  align-items: center;
  background: url("../img/block01_img01.png") center center /contain no-repeat;
  display: flex;
  height: 264px;
  margin-bottom: 136px;
  position: relative;
    padding-bottom: 24px;
}
@media screen and (max-width:768px) {
  #news header .title-box{
    height: 35.46vw;
    margin-bottom: 18.66vw;
  }
}

#news header .title-box::before{
  border-bottom: 1px solid #666;
  bottom:0;
  content: "";
  display: block;
  height: 0;
  position: absolute;
  right: 0;
  width: calc(100% - 56px);
  

}

#news header .title-box::before{
  content: "";
  background: rgba(0,0,0,.7);
  height: 100%;
  position: absolute;
  top:0;
  right:0;
  width: 100%;
}
#news header .title-box svg{
  display: block;
  position: relative;
  height: 80px;
  margin: 0 auto 4.44vw;
  z-index: 1;
  width: 100%;
}
@media screen and (max-width:768px) {
  #news header .title-box svg{
    height: 6.66vw;
  }
}

#news header .title-box .cls-news{
  fill:transparent;
  letter-spacing: .16em;
  stroke-linejoin: round;
  stroke-width: 1px;
  stroke: #fff;
  stroke-dasharray: 1000;
  stroke-dashoffset: 0;
  text-anchor: middle;
  -webkit-animation: commAnm 2.5s ease-in 0s;
  animation: commAnm 2.5s ease-in 0s;
  
}
@-webkit-keyframes commAnm {
    0% {
      stroke-dashoffset: 1000;
      fill:transparent;
        }
   60% {
      fill:transparent;
        }
  100% {
      stroke-dashoffset: 0;
      fill:transparent;
        }
}

#news .contents-wrap{
  border-bottom: 1px solid #666;
  display: block;
  margin: 0 auto 60px;
  padding-bottom: 60px;
  width: 760px;
}
@media screen and (max-width:768px) {
  #news .contents-wrap{
    margin: 0 0 5.66vw;
    padding: 0 3.2vw;
    width: auto;
  }
}

#news .contents-wrap .nc-title-box{
  margin-bottom: 40px;
}
@media screen and (max-width:768px) {
#news .contents-wrap .nc-title-box{
  margin-bottom: 5.66vw;
}
}

#news .contents-wrap p{
  font-size: 16px;
  letter-spacing: .2em;
  line-height: 1.75;
  margin-bottom: 32px;
}
@media screen and (max-width:768px) {
#news .contents-wrap p{
  font-size: 3.2vw;
  letter-spacing: .2em;
  line-height: 1.75;
  margin-bottom: 32px;
}
}

#news .contents-wrap .sns-box p {
  background: #fff;
  color: #222;
  display: inline-block;
  font-size: 12px!important;
  line-height: 1;
  margin-bottom: 12px!important;
  padding: .1em .5em!important;
}
#news .contents-wrap .nc-title-box p.date{
  background: #fff;
  color: #222;
  display: inline-block;
  font-size: 14px;
  line-height: 1;
  margin-bottom: 12px;
  padding: .1em .5em;
}
@media screen and (max-width:768px) {
#news .contents-wrap .nc-title-box p.date{
  background: #fff;
  color: #222;
  display: inline-block;
  font-size: 3.2vw;
  line-height: 1;
  margin-bottom: 12px;
  padding: .1em .5em;
}  
}

#news .contents-wrap .nc-title-box h2{
  font-size: 16px;
  font-weight: normal;
  letter-spacing: .2em;
  line-height: 1.75;
}
@media screen and (max-width:768px) {
#news .contents-wrap .nc-title-box h2{
  font-size: 3.2vw;
  font-weight: normal;
  letter-spacing: .2em;
  line-height: 1.75;
}
    
}

figure.image{
  margin-bottom: 56px;
}
#news p.indent{
  padding: 0 32px;
}
#news .contents-wrap a{
  color:#d80000;
    transition: 0s;
}
#news .contents-wrap a:hover{
  opacity: .7;
}
#news .contents-wrap a.txt-link{
  line-height: 2;
}
#news .sns-box{
  margin-top: 60px;
}
@media screen and (max-width:768px) {
#news .sns-box{
  margin: 5.66vw 0;
}
}

#news .btn-tw{
  top:calc(30% - 50px);
}
#news footer{
  display: block;
}
#news footer .sns-box{
  margin-top: 0;
}
#news .btn-tw{
  opacity: 1;
}
#news .backnext-wrap{
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  width: 900px;
}
@media screen and (max-width:768px) {
  #news .backnext-wrap{
    width: auto;
    padding:0 3.2vw;
  }
}
#news .backnext-wrap.tolist{
  justify-content: center;
  margin-top: 2em;
  width: auto;
}

#news .backnext-wrap a,
#news .backnext-wrap span{
    background: #fff;
    font-family: le-monde-livre-std, serif;font-style: normal;font-weight: 300;
    font-size: 14px;
    color: #222;
    line-height: 1.5;
    padding: 0 1em;
    transition: .3s;
}
#news .backnext-wrap span{
    opacity: .2;
}
#news .backnext-wrap a:hover{
    opacity: .7;
    transition: .3s;
}
