@charset "utf-8";
/* CSS Document */
/* メイン
-------------------------------------------- */
#main-wrap {
  width: 100%;
  height: 50vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
  padding-top: 20px;
}
#main-wrap2 {
  width: 100%;
  height: 50vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
  padding-top: 20px;
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
.pc {
  display: none !important;
}
.sp {
  display: block !important;
}
.catch-bg {
  background: #fff;
  padding: 0px 10px;
}
.main-text {
  padding: 0 0px 0 0;
  width: 100%;
  color: #3A3A3A;
  margin: 0px 0 10px 0;
}
.t-wide {
  letter-spacing: 0.3em;
  background: #fff;
  display: inline-block;
  padding: 5px 20px 5px 20px;
  font-weight: 500;
  font-size: 1.4rem;
}
.main-catch {
  font-size: 4rem;
  font-weight: 500;
  margin: 0 0 10px 0;
  line-height: 1.0em;
}
.catch-list {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
  margin: 0 0 0 20px;
}
.catch-list li {
  font-size: 1.4rem;
  line-height: 1.8;
  padding-left: 20px;
  position: relative;
  font-weight: 500;
}
.catch-list li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #333;
  border: 1px solid;
  border-radius: 50%;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 18px;
  width: 18px;
  color: #ffffff;
  font-size: 1.2rem;
  position: absolute;
  top: 4px;
  left: 0;
}
/* News ＆ Information
-------------------------------------------- */
.news-wrap {
  background: #F3F5F8;
  margin: -25px 0 30px 0px;
  padding: 40px 0 60px 0;
}
/* 左上にタイトルをつけた囲み枠② */
.news-new {
  position: relative;
  margin: 0 0 40px 0;
  padding: 0;
  width: 100%;
}
.news-new .box-title {
  position: absolute;
  display: inline-block;
  top: 0px;
  left: 0px;
  z-index: 1;
  padding: 0 28px;
  height: 25px;
  line-height: 25px;
  font-size: 1.7rem;
  background: #FE3061;
  color: #ffffff;
  font-weight: bold;
}
.news-new p {
  font-size: 1.6rem;
}
.news-day {
  margin: 0 0 10px 0;
}
.news-img{
    /* 拡大してはみ出した部分を非表示にする */
    overflow: hidden;
    width: 100%;
    height: auto;
	border-radius: 0px 15px 15px 15px;
  margin: 0 0 10px 0;
}
 
.news-img img{
    /* 拡大するのにかかる時間 */
    transition:all 0.3s;
}
 
.news-img img:hover{
    /* ホバーしたら1.2倍サイズに拡大 */
    transform: scale(1.2);
}
/* --------------- */
.news-box {
  display: flex;
  justify-content: space-between;
	align-items: flex-start;
  flex-wrap: wrap;
	border-bottom: 1px solid #707070;
	padding: 45px 0 35px 0;
}
.news-photo {
	/* 拡大してはみ出した部分を非表示にする */
    overflow: hidden;
	width: 100%;
	height: auto;
	border-radius: 15px;
  margin: 0 0 10px 0;
}
.news-photo img{
    /* 拡大するのにかかる時間 */
    transition:all 0.3s;
}
.news-photo img:hover{
    /* ホバーしたら1.2倍サイズに拡大 */
    transform: scale(1.2);
}
.news-overview {}
.news-overview p {
  font-size: 1.6rem;
}
hr {
  border: none;
  border-bottom: 3px solid #929292;
}
/* Videos
-------------------------------------------- */
.videos-arrow{
	display: none;
}
.channel-wrap{
	margin: 20px 0 0 0;
}
.dream-navi-wrap{
	margin: 20px 0 0 0;
}
.channel-wrap>.videos-box,.dream-navi-wrap>.videos-box{
    padding: 0px;
}
.videos-flexbox {
  display: flex;
  justify-content: flex-start;
  flex-wrap: nowrap;
}
.channel{
	margin: 0 15px 20px 0px;
}
.dream-navi{
	margin: 0 15px 20px 0;
}
.videos-btn{
		padding-bottom: 50px;
		padding-right: 0px;
	}
.videos-btn2{
		margin-top: 50px;
		padding-right: 0px;
	}
/* Pick up
-------------------------------------------- */
	.pick_up_bnr{
		width: 100%;
		margin: 0 0 20px 0;
	}	
/* ボタン
-------------------------------------------- */
a.btn{
  display: block;
  width: 80%;
  height: 66px;
  margin: 50px auto 0 auto;
  color: #000000;
  border: solid 1px #3B3B3B;
	border-radius: 28px;
  box-sizing: border-box;
  line-height: 62px;
  text-align: center;
	letter-spacing: 0.1em;
  font-size: 1.8rem;
  font-weight: 500;
	background: #fff;
  text-decoration: none;
  position: relative;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
a.btn::before,
a.btn::after{
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
a.btn::before{
  right: 22px;
  width: 22px;
  height: 1px;
  background: #3B3B3B;
}
a.btn::after{
  right: 23px;
  width: 16px;
  height: 16px;
  border-top: 1px solid #3B3B3B;
  border-right: 1px solid #3B3B3B;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
a.btn:hover{
  background-color: #3B3B3B;
  color: #ffffff;
}
a.btn:hover::before{
  background: #ffffff;
}
a.btn:hover::after{
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
}

a.btn-oshi{
  display: block;
  width: 80%;
  height: 66px;
  margin: 50px auto 0 auto;
  color: #000000;
  border: solid 1px #3B3B3B;
	border-radius: 28px;
  box-sizing: border-box;
  line-height: 62px;
  text-align: center;
	letter-spacing: 0.1em;
  font-size: 1.8rem;
  font-weight: 500;
	background: #fff;
  text-decoration: none;
  position: relative;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
a.btn-oshi::before,
a.btn-oshi::after{
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
a.btn-oshi::before{
  right: 22px;
  width: 22px;
  height: 1px;
  background: #3B3B3B;
}
a.btn-oshi::after{
  right: 23px;
  width: 16px;
  height: 16px;
  border-top: 1px solid #3B3B3B;
  border-right: 1px solid #3B3B3B;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
a.btn-oshi:hover{
  background-color: #3B3B3B;
  color: #ffffff;
}
a.btn-oshi:hover::before{
  background: #ffffff;
}
a.btn-oshi:hover::after{
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
}

/*メイン画像の桜設定　*/
.sakura {
	position: relative;
	padding: 0;
	margin: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.sakura li {
	width: 18px;
	position: absolute;
	list-style: none;
	top: -50px;
	animation: fall 4s linear infinite, rotate1 2s ease-in-out infinite alternate;
}
@keyframes fall {
	to {
		top: 120%;
	}
}
@keyframes rotate1 {
	from {
		transform: translateX(0px) rotate(0deg);
	}
	to {
		transform: translateX(200px) rotate(-80deg) rotateX(180deg);
	}
}
@keyframes rotate2 {
	from {
		transform: translateX(200px) rotate(-45deg);
	}
	to {
		transform: translateX(0px) rotate(0deg);
	}
}
.sakura li:nth-child(1) {
	left: 0;
	animation: fall 10s linear infinite, rotate1 3s ease-in-out infinite alternate;
}
.sakura li:nth-child(2) {
	left: 5vw;
	animation: fall 15s linear infinite, rotate1 2s ease-in-out infinite alternate;
}
.sakura li:nth-child(3) {
	left: 15vw;
	animation: fall 9s linear infinite, rotate1 3.5s ease-in-out infinite alternate;
}
.sakura li:nth-child(4) {
	left: 30vw;
	animation: fall 8s linear infinite, rotate2 4s ease-in-out infinite alternate;
}
.sakura li:nth-child(5) {
	left: 40vw;
	animation: fall 10s linear infinite, rotate1 4s ease-in-out infinite alternate;
}
.sakura li:nth-child(6) {
	left: 55vw;
	animation: fall 11s linear infinite, rotate2 3s ease-in-out infinite alternate;
}
.sakura li:nth-child(7) {
	left: 65vw;
	animation: fall 7s linear infinite, rotate2 3.5s ease-in-out infinite alternate;
}
.sakura li:nth-child(8) {
	left: 50vw;
	animation: fall 7s linear infinite, rotate1 3s ease-in-out infinite alternate;
}	
	

@media print, screen and (min-width : 768px) {
  /* メイン
-------------------------------------------- */
  #main-wrap {
    width: 100%;
    height: 100vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
    padding: 0px;
    position: relative;

  }
  #main-wrap2 {
    width: 100%;
    height: 100vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
    padding: 0px;
    position: relative;
  }

  .catch-bg {
    padding: 0px 20px;
  }
  .main-text {
    position: absolute;
    left: 2%;
    bottom: -85px;
    padding: 0 20px 0 20px;
    font-weight: 400;
    width: auto;
  }
  /* パソコンで見たときは"pc"のclassがついた画像が表示される */
  .pc {
    display: block !important;
    margin-right: 0px;
  }
  .sp {
    display: none !important;
  }
  .t-wide {
    letter-spacing: 0.3em;
    padding: 10px 40px 0px 40px;
    font-size: 2.4rem;
  }
  .main-catch {
    font-size: 7.0rem;
    font-weight: 500;
    margin: 0 0 0px 0;
    line-height: 1.4em;
  }
  .catch-list {
    padding: 0;
    margin: 0 0 0 20px;
  }
  .catch-list li {
    font-size: 2rem;
    line-height: 2.0;
    padding-left: 35px;
    position: relative;
  }
  .catch-list li:before {
    height: 26px;
    width: 26px;
    font-size: 1.6rem;
    position: absolute;
    top: 7px;
    left: 2px;
  }
  .main-map {
    float: right;
    margin-right: 2%;
  }
  /* News ＆ Information
-------------------------------------------- */
  .news-wrap {
    background: #F3F5F8;
    margin: -55px 0 0px 0px;
    padding: 40px 0 70px 0;
  }
  /* 左上にタイトルをつけた囲み枠② */
  .news-new {
    position: relative;
    margin: 20px 0 20px 0;
    padding: 0;
    width: 31%;
  }
  /* --------------- */
  .news-box {
	  width: 47.8%;
	}
  .news-photo {
	  width: 45%;
	}
  .news-overview {
	  width: 51%;
	}
/* Videos
-------------------------------------------- */	
.videos-arrow{
	display: block;
	margin: 20px 0px 0 0;
}
img.arrow-l{
	margin: 0px 40px 0 0;
}
.videos-btn01,.videos-btn02{
	width: 461px;
	border-radius: 20px;
	text-align: center;
}
	.channel-wrap{
	height: 260px;
    position: relative;
}
.dream-navi-wrap{
    height: 160px;
    position: relative;
}
	.channel-wrap>.videos-box,.dream-navi-wrap>.videos-box{
    position: absolute;
    left: 7%;
    top: 0px;
    padding: 0px;
}
.channel{
	margin: 10px 25px 0 0;
}
.dream-navi{
	margin: 10px 25px 0 0;
}
	.videos-btn{
		padding-bottom: 50px;
		padding-right: 0px;
	}
	.videos-btn2{
		padding-bottom: 0px;
		padding-right: 0px;
	}
/* Pick up
-------------------------------------------- */
	.pick_up_bnr{
		width: 31%;
		margin: 0 30px 0 0;
	}		
/* ボタン
-------------------------------------------- */
a.btn{
  width: 32%;
	font-size: 2.0rem;
	margin: 70px auto 0 auto;
}
	
}
@media print, screen and (min-width : 1600px) {
  /* メイン
-------------------------------------------- */
  #main-wrap {
    margin: 0 auto 0px auto;
	  padding: 0 0 0px 0;
    width: 100%;
    height: 100vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/

  }
  #main-wrap2 {
    margin: 0 auto 0px auto;
	  padding: 0 0 0px 0;
    width: 100%;
    height: 100vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/

  }

  .main-text {
    position: absolute;
    left: 50%;
    bottom: -115px;
    margin-left: -770px;
    padding: 0 20px 0 0;
    width: auto;
  }
  .t-wide {
    letter-spacing: 0.3em;
    padding: 10px 40px 0px 40px;
    font-size: 3rem;
  }
  .main-catch {
    font-size: 10.0rem;
    font-weight: 500;
    margin: 0 0 10px 0px;
    line-height: 1.4em;
  }
  .catch-list {
    padding: 0;
    margin: 0 0 0 40px;
  }
  .catch-list li {
    font-size: 2.8rem;
    line-height: 2.0;
    padding-left: 45px;
    position: relative;
  }
  .catch-list li:before {
    height: 34px;
    width: 34px;
    font-size: 2.8rem;
    position: absolute;
    top: 12px;
    left: 2px;
  }
  .main-map {
    float: right;
    margin-right: 180px;
  }
  /* News ＆ Information
-------------------------------------------- */
  .news-wrap {
    background: #F3F5F8;
    margin: -55px 0 30px 0px;
    padding: 40px 0 70px 0;
  }
  /* --------------- */
  .news-box {
	  width: 47.8%;
	}
  .news-photo {
    width: 260px;
  }
  .news-overview {
    width: 287px;
  }
/* Videos
-------------------------------------------- */	
.channel-wrap{
    height: 240px;
    position: relative;
	margin: 30px 0 100px 0;
}
.dream-navi-wrap{
    height: 170px;
    position: relative;
	margin: 30px 0 0 0;
}
.channel-wrap>.videos-box,.dream-navi-wrap>.videos-box{
    position: absolute;
    left: 19%;
    top: 0px;
    padding: 0px 0 0px 0;
}	
/* Pick up
-------------------------------------------- */
	.pick_up_bnr{
		width: 368px;
	}	
/* ボタン
-------------------------------------------- */
a.btn{
  width: 25%;
	font-size: 2.2rem;
}
	
	
}