
.data-scroll-container {
  overflow-x: hidden;
  min-height: 100vh;
}

/*ファーストビュー*/
.gsap {
  height: 100vh;
  text-align: center;
  padding-top: 40vh;
}
.gsap h2 {
  font-size: 2rem;
  font-weight: 500;
  overflow: hidden;
}
.gsap h1 {
  font-size: 4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  overflow: hidden;
}

/*タイトル表示*/
.mb {
 /* margin-bottom: 40%;*/
}
@media screen and (max-width:760px) {
  .mb {
    /*margin-bottom: 5%;*/
  }
}
.mb h2 {
  color: #fff;
}
.mb span {
  background-color: #fff;
}

.ttl {
	/*
  display: table;
  margin-left: 5%;
	*/
  position: relative;
}
.ttl__clip {
  position: relative;
  display: inline-block;
  /*font-size: clamp(3rem, 4vw ,7rem);*/
  transition: clip-path 2s cubic-bezier(0.18, 0.06, 0.23, 1) 0.2s;
  clip-path: inset(0 100% 0 0);
  /*padding: 0 12px 8px 0;*/
}
.ttl__clip__line {
  height: 2px;
  background-color: #000;
  width: 0;
  display: block;
  opacity: 0;
  position: absolute;
  bottom: 0;
  left: 0;
}
.ttl__clip__line.slid__open {
  width: 100%;
  opacity: 1;
  transition: all 0.4s cubic-bezier(0.18, 0.06, 0.23, 1) 0s;
}
.ttl__clip.slid__open {
  clip-path: inset(0);
}


/*背景テキスト*/
.scroll {
  overflow: hidden;
  padding-top: 10%;
  padding-bottom: 10%;
}
.scroll__wrap p {
  font-size: clamp(8rem, 10vw, 16rem);
  font-weight: 900;
  color: #1f356e;
  opacity: 0.1;
  -webkit-text-stroke: 1px #1f356e;
}
.scroll__wrap p i {font-size: 15px;}

/*背景徐々に表示*/
.scroll__bg {
  position: relative;
  padding: 2% 0 3% 0;
  /*display: flex;*/
  justify-content: space-between;
}
@media screen and (max-width:760px) {
	/*
  .scroll__bg {
    display: block;
    padding: 15% 0;
  }
	*/
}
.scroll__bg .scroll__cover {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  /*background: linear-gradient(133deg, #464646 0%, #131313 50%, black 100%);*/
	background: #1f356e;
  transform-origin: left;
  width: 100%;
  height: 100%;
}
.scroll__bg .fade__img {
  width: 50%;
  margin-right: 5%;
  margin-top: 10%;
}
@media screen and (max-width:760px) {
  .scroll__bg .fade__img {
    margin-left: 5%;
    margin-right: 0;
    width: 90%;
  }
}
.scroll__bg .fade__img img {
  width: 100%;
  height: auto;
}

.text__up {
  display: flex;
  /*justify-content: center;*/
  /*margin: 15% auto 16px;*/
  overflow: hidden;
}
.text__up span {
  display: block;
  font-size: 3.5rem;
  font-weight: bold;
  letter-spacing: 0.04em;
}
.text__up__02 {
  /*margin: 0 auto 25%;*/
}
.text__up__02 span {
  font-size: 1.8rem;
}

/*画像が下から表示される*/
.flower {
  padding: 22% 0;
  background-color: #fff;
}
.flower__img {
  width: 58.04688%;
  position: relative;
}
.flower__img:nth-child(even) {
  margin: 15% 0 15% auto;
}
.flower__img__02 {
  width: 41.25%;
}
.flower__img__03 {
  width: 48.125%;
  margin-left: 8%;
}

.grid__img {
  position: relative;
  display: block;
  background-color: #fff;
  padding-top: 50%;
  padding-bottom: 20%;
}
.grid__img__item {
  position: absolute;
  display: block;
  overflow: hidden;
}
.grid__img__item::after {
  content: "";
  width: 100%;
  height: 102%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  transition: transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transform: translate3d(0, 0%, 0);
}
.grid__img__item.js-after::after {
  transform: translate3d(0, -102%, 0);
}
.grid__img__item.js-after img {
  opacity: 1;
  transform: scale(1);
}
.grid__img__item img {
  width: 100%;
  height: 100%;
  display: block;
  opacity: 0;
  transform: scale(1.3);
  transition: transform 1.8s cubic-bezier(0.215, 0.61, 0.355, 1) 1s, opacity 1.2s cubic-bezier(0.473, 0.427, 0, 0.993) 0.8s;
  object-fit: cover;
}
.grid__img__item__01 {
  top: 0;
  left: 8.28125%;
  width: 25.46875%;
}
.grid__img__item__02 {
  width: 42.8125%;
  left: -9.0625%;
  top: 26.25%;
  height: 35%;
}
.grid__img__item__03 {
  width: 27.5%;
  left: 35%;
  top: 0;
  height: 74%;
}
.grid__img__item__04 {
  width: 25.46875%;
  right: 10.78125%;
  top: 6.58824%;
}
.grid__img__item__05 {
  width: 36.4%;
  right: 0;
  top: 33.17647%;
}

.js-fadeup {
  position: relative;
  overflow: hidden;
}
.js-fadeup::after {
  content: "";
  width: 100%;
  height: 102%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  transition: transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transform: translate3d(0, 0%, 0);
}
#mainimage .js-fadeup::after {
  background: none;
}
.js-fadeup.js-after::after {
  transform: translate3d(0, -102%, 0);
}
.js-fadeup.js-after img {
  opacity: 1;
  transform: scale(1);
}
.js-fadeup img {
  width: 100%;
  height: auto;
  display: block;
  opacity: 0;
  transform: scale(1.3);
  transition: transform 1.8s cubic-bezier(0.215, 0.61, 0.355, 1) 1s, opacity 1.2s cubic-bezier(0.473, 0.427, 0, 0.993) 0.8s;
}


@media print {
	.ttl__clip {
		 opacity: 1 !important;
		 clip-path: inset(0)!important;
	}
	
	.scroll__bg .scroll__cover{
     opacity: 1 !important;
     transform: none !important;
	}
	
	.js-fadeup::after {
		opacity: 1 !important;
	  transform: none !important;
		background: none;
	}
	.js-fadeup.js-after img {
	 opacity: 1 !important;
     transform: none !important;
	}
	.js-fadeup img {
     opacity: 1 !important;
     transform: none !important;
	}
	
	.text__up__js{
     opacity: 1 !important;
     transform: none !important;
	}
	.js-fadeup.js-after::after {
     transform: none !important;
		opacity: 1 !important;
		background: none;
	}
}

