@charset "UTF-8";
/*
	@include sc(pc) {
		width: 100%;
	}
	@include sc(sp) {
		width: 50%;
	}
*/
/*
	@include hover() {
		opacity: 0.6;
	}
*/
/*
	$line:イラレの行の値
	$size:イラレの文字の値

	@include lh(38, 15);
*/
/*
	$size:object-fitの値

	@include objectfit();
	@include objectfit('contain');
*/
/*
	@include taJ();
*/
/*
	@extend %rightarr;
*/
/*
Robotoフォント設定
300：Light
400：Regular
500：Medium（デフォルト）
700：Bold
*/
/*
Notoフォント設定
400：Regular
500：Medium（デフォルト）
700：Bold
*/
/*
	$weight:フォントの太さ

	@include f_min();
	@include f_min(500);
	@include f_min(600);
*/
/*
	$color:色指定
	$stripe:線サイズ
	$spacing:線の空きサイズ
	$height:太さ

	@include dotted(#e6e1d2, 4,4,2);
*/
/*
example
@include dotted-y(#COLOR, WidthPX,SpaceingPX,LengthPX,); 横破線
@include dotted-y(#e6e1d2, 4,4,2,10);
*/
@media print, screen and (min-width: 641px) {
  .mod_header {
    display: none;
  }
}

@media print, screen and (min-width: 641px) {
  .top_header .link {
    position: fixed;
    top: 50%;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    left: 55px;
  }
  .top_header .one a {
    position: relative;
    display: inline-block;
    padding: 0.12rem 0;
  }
  .no-touchevents .top_header .one a.active:hover .jp:after {
    -webkit-transform: scaleX(1);
        -ms-transform: scaleX(1);
            transform: scaleX(1);
  }
  .no-touchevents .top_header .one a.active:hover .en:after {
    -webkit-transform: scaleX(0);
        -ms-transform: scaleX(0);
            transform: scaleX(0);
  }
  .no-touchevents .top_header .one a:hover .jp:after {
    -webkit-transform: scaleX(0);
        -ms-transform: scaleX(0);
            transform: scaleX(0);
  }
  .no-touchevents .top_header .one a:hover .en:after {
    -webkit-transform: scaleX(1);
        -ms-transform: scaleX(1);
            transform: scaleX(1);
  }
  .top_header .one .en,
.top_header .one .jp {
    position: relative;
  }
  .top_header .one .en:after,
.top_header .one .jp:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    -webkit-transform-origin: left top;
        -ms-transform-origin: left top;
            transform-origin: left top;
    -webkit-transition: 0.2s;
    -o-transition: 0.2s;
    transition: 0.2s;
    -webkit-transform: scaleX(0);
        -ms-transform: scaleX(0);
            transform: scaleX(0);
  }
  .top_header .one .en {
    font-family: roboto, "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
    font-display: swap;
    font-weight: 700;
    font-size: 0.15rem;
    letter-spacing: 0.02rem;
    color: #FFF;
  }
  .top_header .one .en:after {
    background-color: #fff;
    bottom: -2px;
  }
  .top_header .one .jp {
    position: absolute;
    left: 0;
    font-size: 0.16rem;
    font-weight: bold;
    color: #9F927F;
    letter-spacing: 0.03rem;
    white-space: pre;
  }
  .top_header .one .jp > span {
    display: inline-block;
    position: relative;
  }
  .top_header .one .jp:after {
    background-color: #9F927F;
  }
}
.top_header .reserbtn {
  position: fixed;
  bottom: 0;
  z-index: 999;
}
@media print, screen and (min-width: 641px) {
  .top_header .reserbtn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    right: 0;
  }
}
@media screen and (max-width: 640px) {
  .top_header .reserbtn {
    left: 0;
    width: 60px;
  }
}
.no-touchevents .top_header .reserbtn:hover .txt {
  text-decoration: underline;
}
@media screen and (max-width: 640px) {
  .state_nomainvisual .top_header .reserbtn .right {
    -webkit-transform: none;
        -ms-transform: none;
            transform: none;
  }
}
.top_header .reserbtn .left {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 60px;
  height: 60px;
  background-color: #9F927F;
}
.top_header .reserbtn svg {
  fill: #FFF;
}
.top_header .reserbtn .right {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 60px;
  background-color: #28283C;
}
@media print, screen and (min-width: 641px) {
  .top_header .reserbtn .right {
    position: relative;
    padding: 0 40px 0 20px;
  }
}
@media screen and (max-width: 640px) {
  .top_header .reserbtn .right {
    position: absolute;
    top: 0;
    right: 0;
    width: calc(100vw - 60px);
    -webkit-transition: -webkit-transform 1s;
    transition: -webkit-transform 1s;
    -o-transition: transform 1s;
    transition: transform 1s;
    transition: transform 1s, -webkit-transform 1s;
  }
}
.top_header .reserbtn .right:after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-top: 1px solid #FFF;
  border-right: 1px solid #FFF;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.top_header .reserbtn .txt {
  font-family: roboto, "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
  font-display: swap;
  font-weight: 700;
  color: #FFF;
  font-size: 14px;
  letter-spacing: 3px;
}

.mvArea {
  position: relative;
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
  overflow: hidden;
  background-color: #000;
}
@media print, screen and (min-width: 641px) {
  .mvArea {
    height: 100vh;
  }
}
@media screen and (max-width: 640px) {
  .mvArea {
    height: calc(100vh - 60px);
  }
}
.mvArea.kurokusuru .phwrap {
  opacity: 0.3;
}
.mvArea.kurokusuru .txt {
  opacity: 0;
}
.mvArea .phwrap {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: opacity 1s;
  -o-transition: opacity 1s;
  transition: opacity 1s;
}
.mvArea .ph {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.mvArea .ph img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: right center;
     object-position: right center;
}
.mvArea .txt {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: 1s;
  -o-transition: 1s;
  transition: 1s;
}
.mvArea .lead {
  position: relative;
  color: #9F927F;
  font-weight: 900;
}
@media print, screen and (min-width: 641px) {
  .mvArea .lead {
    font-size: 0.28rem;
    letter-spacing: 0.04rem;
  }
}
@media screen and (max-width: 640px) {
  .mvArea .lead {
    font-size: 0.16rem;
    letter-spacing: 0.03rem;
  }
}
.mvArea .lead span {
  display: inline-block;
  position: relative;
  -webkit-clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
          clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
}
.mvArea .lead:after {
  content: "";
  display: block;
  width: 100%;
  background-color: #9F927F;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  -webkit-transform-origin: right top;
      -ms-transform-origin: right top;
          transform-origin: right top;
  -webkit-clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
          clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
}
@media print, screen and (min-width: 641px) {
  .mvArea .lead:after {
    height: 2px;
  }
}
@media screen and (max-width: 640px) {
  .mvArea .lead:after {
    height: 1px;
  }
}
.mvArea .lead.active:after {
  -webkit-transition: -webkit-clip-path 0.6s ease, -webkit-transform 0.6s ease 0.4s;
  transition: -webkit-clip-path 0.6s ease, -webkit-transform 0.6s ease 0.4s;
  -o-transition: clip-path 0.6s ease, transform 0.6s ease 0.4s;
  transition: clip-path 0.6s ease, transform 0.6s ease 0.4s;
  transition: clip-path 0.6s ease, transform 0.6s ease 0.4s, -webkit-clip-path 0.6s ease, -webkit-transform 0.6s ease 0.4s;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
          clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  -webkit-transform: scaleX(0);
      -ms-transform: scaleX(0);
          transform: scaleX(0);
}
.mvArea .lead.active span {
  -webkit-transition: 0.6s ease 0.5s;
  -o-transition: 0.6s ease 0.5s;
  transition: 0.6s ease 0.5s;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
          clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
.mvArea .logo {
  overflow: visible;
}
@media print, screen and (min-width: 641px) {
  .mvArea .logo {
    margin-top: 0.5rem;
  }
}
@media screen and (max-width: 640px) {
  .mvArea .logo {
    margin-top: 0.2rem;
    width: 85vw;
    height: auto;
  }
}
.mvArea .logo .st0 {
  fill: #FFF;
}
.mvArea .logo .st0.type01 {
  -webkit-clip-path: circle(0% at 10px 10px);
          clip-path: circle(0% at 10px 10px);
}
.mvArea .logo .st0.type01.active {
  -webkit-clip-path: circle(110% at 10px 10px);
          clip-path: circle(110% at 10px 10px);
}
.mvArea .logo .st0.type02 {
  -webkit-clip-path: circle(0% at 10px 100%);
          clip-path: circle(0% at 10px 100%);
}
.mvArea .logo .st0.type02.active {
  -webkit-clip-path: circle(120% at 10px 100%);
          clip-path: circle(120% at 10px 100%);
}
.mvArea .logo .st0.type03 {
  -webkit-clip-path: circle(0% at 90% 90%);
          clip-path: circle(0% at 90% 90%);
}
.mvArea .logo .st0.type03.active {
  -webkit-clip-path: circle(100% at 90% 90%);
          clip-path: circle(100% at 90% 90%);
}
.mvArea .logo .st0.type04 {
  -webkit-clip-path: circle(0% at 10px 90%);
          clip-path: circle(0% at 10px 90%);
}
.mvArea .logo .st0.type04.active {
  -webkit-clip-path: circle(130% at 10px 90%);
          clip-path: circle(130% at 10px 90%);
}
.mvArea .logo .st0.type05 {
  -webkit-clip-path: circle(0% at 10px 10px);
          clip-path: circle(0% at 10px 10px);
}
.mvArea .logo .st0.type05.active {
  -webkit-clip-path: circle(130% at 10px 10px);
          clip-path: circle(130% at 10px 10px);
}
.mvArea .logo .st0.active {
  -webkit-transition: 1s;
  -o-transition: 1s;
  transition: 1s;
}
.mvArea .logo .st2 {
  fill: none;
  stroke: #FFF;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.mvArea .logo .st2.type01 {
  stroke-dashoffset: 241px;
  stroke-dasharray: 241px;
}
.mvArea .logo .st2.type02 {
  stroke-dashoffset: 371px;
  stroke-dasharray: 371px;
}
.mvArea .logo .st2.type03 {
  stroke-dashoffset: 283px;
  stroke-dasharray: 283px;
}
.mvArea .logo .st2.type04 {
  stroke-dashoffset: 382px;
  stroke-dasharray: 382px;
}
.mvArea .logo .st2.type05 {
  stroke-dashoffset: 366px;
  stroke-dasharray: 366px;
}
.mvArea .logo .st2.active {
  stroke-dashoffset: 0px;
  -webkit-transition: 1s;
  -o-transition: 1s;
  transition: 1s;
}
.mvArea .logo .st1 {
  fill: #FFF;
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
}
.mvArea .logo .st1.type01 {
  -webkit-transform-origin: 10px 10px;
      -ms-transform-origin: 10px 10px;
          transform-origin: 10px 10px;
}
.mvArea .logo .st1.type02 {
  -webkit-transform-origin: 160px 91px;
      -ms-transform-origin: 160px 91px;
          transform-origin: 160px 91px;
}
.mvArea .logo .st1.type03 {
  -webkit-transform-origin: 390px 91px;
      -ms-transform-origin: 390px 91px;
          transform-origin: 390px 91px;
}
.mvArea .logo .st1.type04 {
  -webkit-transform-origin: 490px 91px;
      -ms-transform-origin: 490px 91px;
          transform-origin: 490px 91px;
}
.mvArea .logo .st1.type05 {
  -webkit-transform-origin: 651px 10px;
      -ms-transform-origin: 651px 10px;
          transform-origin: 651px 10px;
}
.mvArea .logo .st1.active {
  -webkit-transition: 1s cubic-bezier(0.755, 0.05, 0.855, 0.06);
  -o-transition: 1s cubic-bezier(0.755, 0.05, 0.855, 0.06);
  transition: 1s cubic-bezier(0.755, 0.05, 0.855, 0.06);
  -webkit-transform: none;
      -ms-transform: none;
          transform: none;
}
.mvArea .logo .st3 {
  fill: #9F927F;
  opacity: 0;
}
.mvArea .logo .st3.active {
  opacity: 1;
  -webkit-transition: 1s;
  -o-transition: 1s;
  transition: 1s;
}
@media print, screen and (min-width: 641px) {
  .mvArea .copyright {
    position: fixed;
    top: 50%;
    right: 0.1rem;
    -webkit-transform: rotate(90deg) translateX(50%);
        -ms-transform: rotate(90deg) translateX(50%);
            transform: rotate(90deg) translateX(50%);
    -webkit-transform-origin: right top;
        -ms-transform-origin: right top;
            transform-origin: right top;
    font-family: roboto, "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
    font-display: swap;
    font-weight: 300;
    color: #FFF;
    font-size: 0.1rem;
    letter-spacing: 0.01rem;
  }
}
.mvArea .scrollbtn {
  color: #FFF;
  font-family: roboto, "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
  font-display: swap;
  font-weight: 400;
  position: absolute;
  bottom: 0;
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transform-origin: right bottom;
      -ms-transform-origin: right bottom;
          transform-origin: right bottom;
}
@media print, screen and (min-width: 641px) {
  .mvArea .scrollbtn {
    font-size: 0.12rem;
    letter-spacing: 0.02rem;
    width: 1rem;
    padding-bottom: 0.1rem;
    left: -0.8rem;
  }
}
@media screen and (max-width: 640px) {
  .mvArea .scrollbtn {
    font-size: 0.11rem;
    letter-spacing: 0.02rem;
    width: 1rem;
    padding-bottom: 0.1rem;
    left: -0.6rem;
  }
}
.mvArea .scrollbtn:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  bottom: 0;
  left: 0;
}
.mvArea .reserbtn {
  position: absolute;
}
@media print, screen and (min-width: 641px) {
  .mvArea .reserbtn {
    bottom: 0.8rem;
    right: 0.2rem;
  }
}
@media screen and (max-width: 640px) {
  .mvArea .reserbtn {
    bottom: 0;
    right: 0.15rem;
    -webkit-transform: scale(0.65);
        -ms-transform: scale(0.65);
            transform: scale(0.65);
  }
}
.mvArea .reserbtn .reserbtn_01 {
  position: absolute;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  width: 2.5rem;
  height: 2.5rem;
  bottom: 0;
  right: 1.5rem;
}
.mvArea .reserbtn .reserbtn_02 {
  position: absolute;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  width: 2.5rem;
  height: 2.5rem;
  bottom: 0;
  right: 1.5rem;
  -webkit-animation: 10s linear reserbtnAnim infinite;
          animation: 10s linear reserbtnAnim infinite;
}
@-webkit-keyframes reserbtnAnim {
  0% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
@keyframes reserbtnAnim {
  0% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
.mvArea .reserbtn a {
  display: block;
  position: absolute;
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s;
  bottom: 0.2rem;
  right: 0;
}
.no-touchevents .mvArea .reserbtn a:hover {
  opacity: 0.6;
}
.mvArea .reserbtn .reserbtn_03 {
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  width: 2rem;
  height: 2rem;
}