@charset "utf-8";


/*

/70th/css/top.css

Update:  2025-07-01 

====================*/
/* ----------------------------------------------------
全端末共通
---------------------------------------------------- */
/* common reset ==== */

/* ----------------------------------------------------
Media query All
---------------------------------------------------- */
/* main h2,#group .title,#main-top p{
  font-family:'Noto Sans JP' ,"メイリオ", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 400;
} */

/* common */

main h2{
  position: relative;
	font-size: clamp(2.4rem, 4.0vw, 4.8rem);
  margin-bottom: 40px;
  text-shadow: 2px  2px 3px #ffffff,-2px  2px 3px #ffffff,2px -2px 3px #ffffff,-2px -2px 3px #ffffff,2px  0px 3px #ffffff,0px  2px 3px #ffffff,-2px  0px 3px #ffffff,0px -2px 3px #ffffff;
  font-weight: 300;
  z-index: 5;
}
main h2 span{
  font-size: 1.4rem;
  color: #5f904e;
  display: block;
}
main h2::before {
  position: absolute;content: "";
  top: -5%;left: -8%; right: 0;
  margin: 0px auto 0;
  background:url("/70th/img/bg_tree.svg") no-repeat;
  width: 650px;height: 65px;
  background-size: 650px 65px;
  z-index: -1;
}
#main {
  position: relative;
}
#main::before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: url("/70th/img/bg01_pc.jpg") center/cover no-repeat;
  z-index:-1;
}
#main a{
  z-index: 9999;
}
.fallback #main::before {
	background: url("/70th/img/bg01_pc.jpg") center/cover no-repeat;
}
.webp #main::before {
	background: url("/70th/img/bg01_pc.webp") center/cover no-repeat;
}
.avif #main::before {
	background: url("/70th/img/bg01_pc.avif") center/cover no-repeat;
}
/* footer */
.site-footer .inr{
	background: none !important;
}
.site-footer .inr {
	padding: 80px 8px 20px;
}

/* メインスライド */
h1{
	animation: fadeIn 2s ease 0s 1 normal;
}

@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}
#main-top{
  position: relative;
  margin: 0 auto 0;
}
#main-top .logo70th{
	max-width:550px;
	position: absolute;
	top: 40%;
  left: 50%;
  transform: translateY(-40%) translateX(-50%);
	z-index: 9999;
}
#main-top::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg,rgba(255, 255, 255, 0) 80%, rgba(255, 255, 255, 1) 100%),url("/70th/img/bg_wave.png") no-repeat;
  background-position: center bottom;
  z-index: 99999;
}
#main-top .slide-main{
  z-index: 100;
  position: relative;
  overflow: hidden;
}
#main-top .slide-main .set{
  /* height: 100vh; */
  height: 1100px;
  position: relative;
}
#main-top .slide-main .set img:not(.no-expansion){
  /* height: 100vh; */
  height: 1100px;
  margin: auto;
  max-height: 100%;
  max-width: 100%;
  object-fit: cover;
  width: 100%;
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.08);
  }
}
@-moz-document url-prefix() {
  #main-top .slide-main{
    /*firefox ぶれ対策*/
    margin: -10px 0 0 0;
    z-index: 0;
  }
}
.add-animation img{
  animation: zoomUp 10s linear 0s normal both;
}
#main-top .slide-main .set a:hover{
  opacity: 1.0 !important;
}
#main-top p{
  font-size:clamp(1.2rem, 1.6vw, 2.0rem);
  color: #FFFFFF;
  margin: 0 auto 28px;
}
/* message */
#message{
  position: relative;
  text-align: center;
	background-color: #FFFFFF;
  padding: 0 10px 0;
  z-index: 5;
}
#message .column{
  max-width: 1920px;
  margin: 0 auto 0;
  flex-wrap:nowrap;
  align-items: center;
}
#message .text{
  text-align: center;
  max-width: 600px;
  margin: 0 auto 0;
  padding: 80px 40px 0;
}
#message .img{
  flex-grow: 1;
}
#message .img.set01{
  padding-top: 100px;
}
#message p{
  font-size: 1.5rem;
  line-height: 2.2;
}
#message p + p{
  margin-top: 30px;
  color: #333333;
}
/* bg_wave */
.bg_wave{
	position: relative;
  margin-top: -150px;
	padding: 360px 15px 120px;
  z-index: 0;
}
.fallback .bg_wave {
	background: url("/70th/img/bg_group.jpg") center top;
  background-size: cover;
}
.webp .bg_wave {
	background: url("/70th/img/bg_group.webp") center top;
  background-size: cover;
}
.avif .bg_wave {
	background: url("/70th/img/bg_group.avif") center top;
  background-size: cover;
}

.bg_wave::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg,rgba(255, 255, 255, 0) 90%, rgba(255, 255, 255, 1) 100%),url("/70th/img/bg_wave.png") no-repeat;
  background-position: center bottom;
  background-size: contain;
  z-index: 10;
}
/* movie */
#movie{
  position: relative;
  text-align: center;
  max-width: 850px;
	margin: 0 auto 70px;
	display: flex;
  flex-direction: column;
}
#movie .movie-wrap {
  width: 100%;
  aspect-ratio: 16 / 9;
	z-index: 20;
}
#movie .movie-wrap iframe {
  width: 100%;
  height: 100%;
}
#movie h2{
  position: relative;
  font-size: clamp(2.4rem, 3.16vw, 3.8rem);
  margin: 25px auto 50px;
	z-index: 20;
}
main #movie h2::before {
  display: none;
}
/* group */
#group{
  position: relative;
  text-align: center;
}
#group .inr{
	max-width: 1400px;
	margin: 0 auto 0;
	padding: 80px 75px 60px;
	border-radius: 8px;
	background-color: #FFFFFF;
}
#group .column{
	width: 100%;
}
#group .column .set{
	width: 30%;
	margin: 0 1.5% 45px;
  text-align: left;
  z-index: 20;
}
#group .title{
	font-size: 1.8rem;
	margin: 26px 0 5px 5px;
	line-height: 1.3;
}
#group .text{
	font-size: 1.4rem;
	margin: 0 0 6px 5px;
	line-height: 1.5;
}
#group a{
	position: relative;
	color: #000000;
	text-decoration: none;
	font-size: 1.4rem;
	text-align: right;
	display: block;
	padding-right: 50px;
}
#group a::after {
  position: absolute;
  bottom: -2px;right: 20px;
  content: "";
  width: 35px;
  height: 7px;
  border-bottom: 1px solid #5f904e;
  border-right: 1px solid #5f904e;
  transform: skew(45deg);
}

/* founding */
#founding{
	position: relative;
	background: rgba(255,255,255,0.8);
	padding: 150px 0 150px;
  z-index: -1;
}
/* #founding::before{
	content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 180px;
	background-color: #FFFFFF;
	background-position: center top;
	z-index: -1;
} */
#founding .column{
	max-width: 1400px;
	margin: 0 auto 0;
	justify-content:space-around;
  align-items: center;
}
#founding .text{
	width: 47%;
	padding: 30px 20px 0 0;
}
#founding .text p{
  font-size: 1.5rem;
}
#founding .text p + p{
	margin-top: 22px;
}
#founding .img{
	width: 22%;
}
#founding .img01{
	padding-top: 120px;
}
/* history */
#history{
  text-align: center;
	background-color: #FFFFFF;
}
main #history h2{
	font-size: clamp(2.4rem, 4.0vw, 4.8rem);
  color: #FFFFFF;
  margin-bottom: 55px;
  text-shadow: 2px  2px 3px #6fb897,-2px  2px 3px #6fb897,2px -2px 3px #6fb897,-2px -2px 3px #6fb897,2px  0px 3px #6fb897,0px  2px 3px #6fb897,-2px  0px 3px #6fb897,0px -2px 3px #6fb897;
  z-index: 5;
}
main #history h2 span{
  font-size: 1.4rem;
  color: #FFFFFF;
}
main #history h2::before {
  position: absolute;content: "";
  top: -5%;left: -5%; right: 0;
  margin: 0px auto 0;
  background:url("/70th/img/bg_tree_white.svg") no-repeat;
  width: 650px;height: 65px;
  background-size: 650px 65px;
  z-index: -1;
}
#history .inr{	
	position: relative;
  padding: 50px 0 30px;
}
#history .inr::after{
	width: 100%;
	height: 100%;
	content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
	background: linear-gradient(112deg,rgba(139, 191, 121, 0.9) 0%, rgba(156, 222, 230, 0.9) 100%);
	z-index: 1;
}
#history .inr .set{
  margin: 0 40px 0;
}
#history .inr .text{
	position: absolute;
  top: 55%;
  left: 50%;
  transform: translateY(-55%) translateX(-50%);
	z-index: 10;
}
#history .inr .text p:not(.btn){
  color: #FFFFFF;
  text-shadow: 2px  2px 3px #6fb897,-2px  2px 3px #6fb897,2px -2px 3px #6fb897,-2px -2px 3px #6fb897,2px  0px 3px #6fb897,0px  2px 3px #6fb897,-2px  0px 3px #6fb897,0px -2px 3px #6fb897;
}
#history .btn a{
  position: relative;
  display: block;
  width: 90%;
  max-width: 400px;
  height: 60px;
  line-height: 60px;
  margin: 45px auto 40px;
  text-align: center;
  color: #333333;
  text-decoration: none;
  border-radius: 30px;
  background-color: #FFFFFF;
  transition: .3s;
}
#history .btn a::after{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 2px #5f904e;
  border-right: solid 2px #5f904e;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 22px;
  margin-top: -4px;
}
/* campaign */
#campaign{
  text-align: center;
  width: 100%;
  background: url("/70th/img/bg_gallery01.jpg") no-repeat center bottom,linear-gradient(180deg,rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 0.6) 28%, rgba(255, 255, 255, 0.6) 62%, rgba(255, 255, 255, 1) 75%);
  padding: 90px 10px 250px;
}
#campaign .column{
  max-width: 1250px;
  margin: 0 auto 0;
  align-items: flex-start;
}
#campaign .column .set{
  width: 46%;
  background-color: #FFFFFF;
  border-radius: 8px;
  margin-bottom: 40px;
  padding: 6px;
  box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 8px;
}
#campaign .column .set:nth-of-type(even){
  margin-top: 70px;
}
#campaign .column .set img{
  border-radius: 8px 8px 0 0;
}
#campaign .column .set .text{
  padding: 28px 24px 16px;
}
#campaign .title{
  font-size: 1.8rem;
  margin-bottom: 10px;
}
#campaign .info{
  font-size: 1.4rem;
  margin-bottom: 6px;
}
#campaign a{
	position: relative;
	color: #000000;
	text-decoration: none;
	font-size: 1.4rem;
	text-align: right;
	display: block;
	padding-right: 50px;
}
#campaign a::after {
  position: absolute;
  bottom: 0px;right: 20px;
  content: "";
  width: 35px;
  height: 7px;
  border-bottom: 1px solid #5f904e;
  border-right: 1px solid #5f904e;
  transform: skew(45deg);
}

/* gallery */
#gallery{
  text-align: center;
  background: url("/70th/img/bg_gallery02") no-repeat center bottom #ddeefa;
  padding: 10px 10px 80px;
}
#gallery .inr{
  max-width: 1120px;
  margin: 0 auto 20px;
}
#gallery .btn a{
  position: relative;
  display: block;
  width: 90%;
  max-width: 400px;
  height: 60px;
  line-height: 60px;
  margin: 0 auto 40px;
  text-align: center;
  color: #333333;
  text-decoration: none;
  border-radius: 30px;
  border: 1px solid #9b9b9b;
  background-color: #FFFFFF;
  transition: .3s;
}
#gallery .btn a::after{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 2px #5f904e;
  border-right: solid 2px #5f904e;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 22px;
  margin-top: -4px;
}
/* site-footer */
.site-footer{
  background-color: #FFFFFF;
}
.site-footer .logo_footer{
  margin: 0 auto 50px;
}
.site-footer .btn a{
  position: relative;
  display: block;
  width: 90%;
  max-width: 400px;
  height: 60px;
  line-height: 60px;
  margin: 0 auto 40px;
  text-align: center;
  color: #FFFFFF;
  text-decoration: none;
  border-radius: 30px;
  background: linear-gradient(112deg,rgba(91, 176, 186, 1) 0%, rgba(139, 191, 121, 1) 100%);
  transition: .3s;
}
.site-footer .btn a::after{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 2px #FFFFFF;
  border-right: solid 2px #FFFFFF;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 22px;
  margin-top: -4px;
}
#sns-area-hotel{
  width: 100%;
  max-width: 344px;
  margin: 0 auto 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
#sns-area-hotel .sns{
  width: 100%;
  margin: 0 auto 20px auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#sns-area-hotel .sns li{
  width: 70px;
  height: 70px;
}
/* remodal */
.remodal .text{
  margin-bottom: 30px;
}
.remodal .img{
  padding-bottom: 30px;
}
.remodal h4{
  font-weight: bold;
}
.remodal{
  z-index: 9999999;
}
/* All END */

/* ----------------------------------------------------
- 520px (Smartphone layout Only)
---------------------------------------------------- */
@media (max-width: 520px) {




/* - 520px (Smartphone layout Only) END */
}

/* ----------------------------------------------------
- 960px (Smartphone Tablet layout Only)
---------------------------------------------------- */
@media (max-width: 960px) {

	.slick-prev {
    left: -12px !important;
    width: 11px !important;
    height: 22px !important;
  }

#main-top .slide-main .set{
  height: 600px;
}
main h2::before {
  position: absolute;content: "";
  top: -5%;left: -5%; right: 0;
  margin: 0px auto 0;
  background:url("/70th/img/bg_tree.svg") no-repeat;
  width: 300px;height: 30px;
  background-size: 300px 30px;
  z-index: -1;
}
/* message */
#message{
  text-align: center;
  padding: 0 10px 40px;
}
#message .text{
  max-width: initial;
  margin: 0 auto 0;
  padding: 50px 0 0;
  text-align: left;
}
#message .img{
  display: none;
}
/* bg_wave */
.bg_wave{
	position: relative;
	padding: 230px 8px 0;
}
.fallback .bg_wave {
	background: url("/70th/img/bg_group.jpg") center top;
  background-size: cover;
}
.webp .bg_wave {
	background: url("/70th/img/bg_group.webp") center top;
  background-size: cover;
}
.avif .bg_wave {
	background: url("/70th/img/bg_group.avif") center top;
  background-size: cover;
}
/* group */
#group{
  position: relative;
  text-align: center;
}
#group .inr{
	max-width: 1400px;
	margin: 0 auto 0;
	padding: 20px 10px 20px;
	border-radius: 8px;
	background-color: #FFFFFF;
}
#group .column{
	width: 100%;
}
#group .column .set{
	width: 48%;
	margin: 0 1% 45px;
  text-align: left;
  z-index: 20;
}
#group .title{
	font-size: 1.6rem;
	margin: 15px 0 5px 5px;
	line-height: 1.3;
}
#group .text{
	font-size: 1.2rem;
	margin: 0 0 6px 5px;
	line-height: 1.5;
}
/* founding */
#founding{
	position: relative;
	background: rgba(255,255,255,0.8);
	padding: 150px 12px 80px;
}

#founding .text{
	width: 100%;
  margin-bottom: 40px;
	padding-top: 0;
}
#founding .text p + p{
	margin-top: 30px;
}
#founding .img{
	width: 40%;
}
#founding .img01{
	padding-top: 60px;
}
/* history */
#history{
  text-align: center;
	background-color: #FFFFFF;
}
main #history h2{
	font-size: clamp(2.4rem, 4.0vw, 4.8rem);
  color: #FFFFFF;
  margin-bottom: 55px;
  text-shadow: 2px  2px 3px #6fb897,-2px  2px 3px #6fb897,2px -2px 3px #6fb897,-2px -2px 3px #6fb897,2px  0px 3px #6fb897,0px  2px 3px #6fb897,-2px  0px 3px #6fb897,0px -2px 3px #6fb897;
  z-index: 5;
}
main #history h2 span{
  font-size: 1.4rem;
  color: #FFFFFF;
}
main #history h2::before {
  position: absolute;content: "";
  top: -5%;left: -5%; right: 0;
  margin: 0px auto 0;
  background:url("/70th/img/bg_tree_white.svg") no-repeat;
  width: 300px;height: 30px;
  background-size: 300px 30px;
  z-index: -1;
}
#history .inr{	
	position: relative;
  padding: 50px 0 30px;
}
#history .inr .set{
  margin: 0 20px 0;
}
#history .inr .text{
  width: 280px !important;
	position: absolute;
  top: 55%;
  left: 50%;
  transform: translateY(-55%) translateX(-50%);
	z-index: 10;
}

/* campaign */
#campaign{
  text-align: center;
  width: 100%;
  background: url("/70th/img/bg_gallery01.jpg") no-repeat center bottom,linear-gradient(180deg,rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 0.6) 28%, rgba(255, 255, 255, 0.6) 62%, rgba(255, 255, 255, 1) 75%);
  padding: 60px 10px 190px;
}
#campaign .column .set{
  width: 100%;
  background-color: #FFFFFF;
  border-radius: 8px;
  margin-bottom: 35px;
  padding: 6px;
  box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 8px;
}
#campaign .column .set:nth-of-type(even){
  margin-top: 0px;
}
#campaign .column .set .text{
  padding: 20px 15px 16px;
}
#campaign .title{
  font-size: 1.8rem;
  margin-bottom: 10px;
}

/* gallery */


/* - 960px (Smartphone Tablet layout Only) END*/
}

/* ----------------------------------------------------
961px- (Pc layout Only)
---------------------------------------------------- */
@media (min-width: 961px) {



/* 961px - END*/
}

/* ----------------------------------------------------
- 1200px (Pc layout Only コンテンツ内 基本幅)
---------------------------------------------------- */
@media (max-width: 1200px) {

	



	/* - 1200px (Pc layout Only) END*/
}

/* ----------------------------------------------------
961px- 1250px (Pc layout Only)
---------------------------------------------------- */

@media (min-width: 961px) and (max-width: 1250px) {


}

/* ----------------------------------------------------
- 1920px (Pc layout Only)
---------------------------------------------------- */
@media (max-width: 1920px) {


/* - 1920px - END*/
}

/* ----------------------------------------------------
1921px- (Pc layout Only Wide)
---------------------------------------------------- */
@media (min-width: 1921px) {
#main-top::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg,rgba(255, 255, 255, 0) 80%, rgba(255, 255, 255, 1) 100%),url("/70th/img/bg_wave.png") no-repeat;
  background-position: center bottom;
  background-size: contain;
  z-index: 99999;
}
.fallback #main::before {
	background: url("/70th/img/bg01_pc.jpg") center top no-repeat;
  background-size: cover;
}
.webp #main::before {
	background: url("/70th/img/bg01_pc.webp") center top no-repeat;
  background-size: cover;
}
.avif #main::before {
	background: url("/70th/img/bg01_pc.avif") center top no-repeat;
  background-size: cover;
}
/* bg_wave */
.bg_wave{
	position: relative;
  margin-top: -150px;
	padding: 360px 15px 80px;
  z-index: 0;
}
.fallback .bg_wave {
	background: url("/70th/img/bg_group.jpg") center top;
  background-size: cover;
}
.webp .bg_wave {
	background: url("/70th/img/bg_group.webp") center top;
  background-size: cover;
}
.avif .bg_wave {
	background: url("/70th/img/bg_group.avif") center top;
  background-size: cover;
}

/* .bg_wave::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg,rgba(255, 255, 255, 0) 90%, rgba(255, 255, 255, 1) 100%),url("/70th/img/bg_wave.png") no-repeat;
  background-position: center bottom;
  background-size: contain;
  z-index: 10;
} */
/* campaign */
#campaign{
  text-align: center;
  width: 100%;
  background: url("/70th/img/bg_gallery01.jpg") no-repeat center bottom,linear-gradient(180deg,rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 0.6) 28%, rgba(255, 255, 255, 0.6) 62%, rgba(255, 255, 255, 1) 75%);
  padding: 60px 10px 190px;
  background-size: contain;
}
/* gallery */
#gallery{
  text-align: center;
  background: url("/70th/img/bg_gallery02") no-repeat center bottom #ddeefa;
  padding: 10px 10px 80px;
  background-size: contain;
}
/* 1921px - END*/
}