@charset "utf-8";

/* common */
:root {
  --media_sp: 750;
  --media_tb: 1024;
  --media_pc: 1680;
  /* --inner_pc: min( 76.190%, 1280px); */
  --inner_pc: min( 1280px, calc(( 1280 / var(--media_pc)) * 100vw ));
  --inner_tb: 92.1875%;
  --inner_sp: 84%;
}

@media (min-width: 1025px) {
  .tb, .sp {display: none;}
  .pc {display: block;}
}
@media (min-width: 620px) and (max-width: 1024px) {
  .pc, .sp {display: none;}
  .tb {display: block;}
}
@media (max-width: 619px) {
  .pc, .tb {display: none;}
  .sp {display: block;}
}

figure {position: relative;}

.img_cap {
  position: absolute;
  inline-size: fit-content;
  block-size: fit-content;
  bottom: 5px;
  right: 5px;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.08em;
  color: #fff;
  line-height: 1.2;
  text-align: right;
}

.img_cap.bk {color: #333333;}
@media (min-width: 1025px) {
  .img_cap {
    font-size: 12px;
  }
}
@media (min-width: 620px) and (max-width: 1024px) {
  .img_cap {
    /*! font-size: calc(( 10 / var(--media_tb)) * 100vw ); */
    font-size: 12px;
  }
}
@media (max-width: 619px) {
  .img_cap {
    font-size: calc(( 20 / var(--media_sp)) * 100vw );
  }
}

/* animation
 * ========================================================================== */
 .basicFade,
 .delayFade {
	opacity: 0;
	transition: all 0.8s;
} 
.basicFade.morph,
.delayFade.morph {
	opacity: 1;
	transition: all 0.8s;
	transition-timing-function: ease-out;
}

.pinsFade {
	opacity: 0;
	transition: all 0.8s;
} 
.pinsFade.morph {
	opacity: 1;
	transition: all 0.8s;
	transition-timing-function: ease-out;
}
 
.blurFade {
	opacity: 0;
	transition: all 0.8s;
} 
.blurFade.morph {
	opacity: 1;
	transition: all 1.5s;
filter: blur(100px);
	animation: blurAnimation 2s ease-out forwards;
}

@keyframes blurAnimation{
	100% { filter: blur(0px); }
}

/* plan
 * ========================================================================== */

.contentsWrap {
	position: relative;
  width: 100%;
  padding: 0;
  overflow: hidden;
}

.mv-wrap {
  background-color: #ede3da;
  position: relative;
  width: 100%;
  overflow: hidden;
}

@media (min-width: 1025px) {
  .mv-wrap  {
    height: min(840px, calc(( 840 / var(--media_pc)) * 100vw ));
  }
}

@media (min-width: 620px) and (max-width: 1024px) {
  .mv-wrap {
    height: calc(( 670 / var(--media_tb)) * 100vw );
  }
}

@media (max-width: 619px) {
  .mv-wrap {
    max-height: calc(( 1336 / var(--media_sp)) * 100vw );
    height: 100svh;
  }
}

.mv-wrap .mv_img-wrap {
  width: 100%;
  height: 100%;
}

.mv-wrap .mv_img-wrap img {
  min-width: auto;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.contents_title {
	position: absolute;
	translate: -50% -50%;
	z-index: 1;
  font-size: 0;
  height: auto;
	width: 545px;
}



@media screen and (min-width: 1025px) {
	.contents_title {
		width: 545px;
    top: 50%;
	  left: 50%;
		/*! transform: translate(-50%,-50%); */
	}
}
@media screen and (min-width: 620px) and (max-width: 1024px) {
	.contents_title{
		width: calc(( 334 / var(--media_tb)) * 100vw );
    top: 50%;
    left: 50%;
	}
}
@media screen and (max-width: 619px) {
  .contents_title{
    width: calc(( 393 / var(--media_sp)) * 100vw );
    top: 50%;
    left: 50%;
    translate: -50% -50%;
  }
}

.contents p {
  font-family: YakuHanMP, "Noto Serif JP", "Times New Roman", Times, A1 Mincho, YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}


.linkBlk {
  text-align: center;
  background-color: #322a22;
  padding-top: 96px;
  padding-bottom: 235px;
}
.linkBlk .title {
  margin-bottom: 108px;
}
.linkBlk .title p {
  color: #fff;
  font-size: 19px;
  line-height: calc(57/19);
  letter-spacing: 0.04em;
}
.linkBlk .bnrsWrap {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  gap: 40px;
}
.linkBlk .bnrsWrap a {
  opacity: 1;
  transition: opacity 0.3s;
}
.linkBlk .bnrsWrap a:hover {
  opacity: 0.8;
  transition: opacity 0.3s;
}
@media screen and (max-width: 1024px) {
  .linkBlk {
    padding-top: calc(( 55 / var(--media_tb)) * 100vw);
    padding-bottom: calc(( 101 / var(--media_tb)) * 100vw);
  }
  .linkBlk .title {
    margin-bottom: calc(( 55 / var(--media_tb)) * 100vw);
  }
  .linkBlk .title p {
    color: #fff;
    font-size: calc(( 16 / var(--media_tb)) * 100vw);
    line-height: calc(48/16);
  }
  .linkBlk .bnrsWrap {
    max-width: calc(( 865 / var(--media_tb)) * 100vw);
    gap: calc(( 30 / var(--media_tb)) * 100vw);
  }
}
@media screen and (max-width: 619px) {
  .linkBlk .title {
    margin-bottom: calc(( 111 / var(--media_tb)) * 100vw);
  }
  .linkBlk .title p {
    color: #fff;
    font-size: calc(( 12 * 2 / var(--media_sp)) * 100vw);
    line-height: calc(36/12);
  }
  .linkBlk {
    padding-top: calc(( 104 / var(--media_tb)) * 100vw);
    padding-bottom: calc(( 137 / var(--media_tb)) * 100vw);
  }
  .linkBlk .bnrsWrap {
    max-width: calc(( 670 / var(--media_sp)) * 100vw);
    gap: calc(( 40 / var(--media_sp)) * 100vw);
  }
}

/**
/* freeArea
 * ========================================================================== */
#freeArea {
    padding: 50px 0;
    max-width: none;
    background: #dbdbdb;
    text-align: center;
}

/* @media
 * ========================================================================== */
@media screen and (min-width: 620px) and (max-width: 1024px) {}
@media screen and (max-width: 619px) {}
@media screen and (max-width: 320px) {}

