@charset "utf-8";
/* CSS Document */
a{
	text-decoration: none;
}

.main_visualbox{
	width: 100%;
	height: calc(100vh - 92px);
	overflow: hidden;
	margin: 93px auto 0;
	position: relative;
	background: url(../img/park/item01.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.main_visualbox .text-box{
	position: absolute;
	bottom: 0%;
	left: 0%;
	background: #ffffff;
	padding: 30px 40px;
	border-radius: 0 20px 0 0;
}
.main_visualbox h1{
	z-index: 20;
	font-size: 150%;
	letter-spacing: 2px;
	line-height: 2;
	margin-bottom: 10px;
	text-indent: -10px;
}
.main_visualbox h1 span{
	font-size: 220%;
	color: #5dac81;
}
.main_visualbox .sub-title{
	font-size: 140%;
	letter-spacing: 1px;
	font-weight: bold;
}
.main_visualbox .sub-title span{
	color: #F0A986;
}
.main_visualbox .deco-01{
	display: block;
	width: 20%;
	height: auto;
	position: absolute;
	bottom: 0;
	left: 2.5%;
}

#dropmenu{
	width: 100vw;
	position: fixed;
	background: #fff;
	z-index: 99;
}

.hero-area{
	margin: 60px auto;
	position: relative;
}
.hero-area h2{
	background: #5dac81;
	color: #fff;
	padding: 15px;
	letter-spacing: 1px;
}
.hero-area h2 span{
	display: block;
	width: 95%;
	max-width: 1100px;
	margin: 0 auto;
}
.hero-content{
	position: relative;
}
.hero-bg-image{
	width: 60%;
	height: auto;
	aspect-ratio: 16/9;
	background: #cdcdcd;
	overflow: hidden;
	position: relative;
}
.hero-bg-image::before{
	content: "";
	height: 100%;
	width: 80%;
	position: absolute;
	top: 0;
	right: 0;
	background: linear-gradient(90deg,rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 90%);
	z-index: 5;
}
.hero-bg-image img{
	display: block;
	width: 100%;
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 0;
}
.hero-lead{
	width: 95%;
	max-width: 1100px;
	height: fit-content;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: 10;
	margin: auto;
}
.hero-lead p{
	width: fit-content;
	font-size: 150%;
	letter-spacing: 1px;
	line-height: 2;
	margin: 0 0 0 auto;
}

.section-about{
	overflow: hidden;
}
.section-about .container{
	width: 95%;
	max-width: 1100px;
	margin: 0 auto 60px;
	display: flex;
	align-items: flex-start;
}
.section-about .text-box{
	width: 50%;
	padding: 0 20px 0 0;
}
.section-about h2{
	font-size: 200%;
	background: #F0A986;
	color: #fff;
	line-height: 2;
	padding: 20px;
	margin-bottom: 30px;
	border-radius: 10px;
}
.section-about p{
	padding: 0 10px;
	text-align: justify;
	letter-spacing: 1px;
	line-height: 1.7;
}
.section-about .image-box{
	width: 50%;
	position: relative;
}
.section-about .image-box img{
	display: block;
	width: auto;
	height: 100%;
	border-radius: 10px;
}
.section-about .gallery{
	width: 90%;
	max-width: 1100px;
	margin: 0 auto 40px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}
.section-about .gallery li{
	position: relative;
	width: 100%;
	height: auto;
	aspect-ratio: 16/9;
	overflow: hidden;
	border-radius: 20px;
}
.section-about .gallery li img{
	display: block;
	width: auto;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border-radius: 20px;
}

.section-play{
	width: 95%;
	max-width: 1100px;
	margin: 0 auto 60px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.section-play h2{
	font-size: 200%;
	letter-spacing: 1px;
	margin-bottom: 10px;
}
.section-play h2 span{
	color: #F0A986;
}
.section-play img{
	width: 40%;
	height: auto;
}
.section-play .box{
	width: 55%;
}
.section-play .box p{
	letter-spacing: 1px;
	line-height: 1.8;
}
.section-play .box p span{
	background: linear-gradient(transparent 70%, #f88b516b 70% 85%, transparent 85%);
}


.section-philosophy{
	width: 95%;
	max-width: 1100px;
	margin: 0 auto 60px;
}
.section-philosophy h2{
	font-size: 200%;
	letter-spacing: 1px;
}
.section-philosophy h2 span{
	color: #F0A986;
}
.philosophy-content{
	display: flex;
	align-items: center;
}
.philosophy-content img{
	width: 45%;
	max-width: 800px;
	height: auto;
}
.philosophy-content p{
	text-align: justify;
	letter-spacing: 1px;
	line-height: 1.7;
	padding: 30px;
}
.philosophy-content p span{
	background: linear-gradient(transparent 70%, #f88b516b 70% 85%, transparent 85%);
}

.section-education{
	width: 95%;
	max-width: 1100px;
	margin: 0 auto 60px;
}
.section-education .grid-box{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-bottom: 30px;
}
.section-education .grid-box h2{
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 200%;
	text-align: center;
	background: #fcede5;
}
.section-education .grid-box img{
	display: block;
	width: 100%;
	height: auto;
}
.section-education .grid-box blockquote{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #edf6f1;
	letter-spacing: 1px;
}
.section-education .grid-box blockquote p{
	font-size: 116%;
}
.section-education .grid-box blockquote cite{
	font-size: 80%;
}
.section-education .text-box p{
	letter-spacing: 1px;
	line-height: 1.8;
	text-align: justify;
	font-size: 108%;
	margin-bottom: 30px;
}
.section-education .text-box .green{
	color: #5dac81;
	font-weight: bold;
}
.section-education .text-box .marker{
	background: linear-gradient(transparent 70%, #f88b516b 70% 85%, transparent 85%);;
}
.section-education .image-box{
	position: relative;
}
.section-education .image-box img{
	width: 50%;
	height: auto;
}
.section-education .image-box p{
	height: fit-content;
	position: absolute;
	bottom: 0;
	right: 10%;
	margin: auto;
	background: #fcede5;
	padding: 20px;
	border-radius: 20px;
	letter-spacing: 1px;
	line-height: 1.8;
}
.section-education .img{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-top: -60px;
}
.section-education .img img{
	width: 45%;
	height: auto;
}
.section-education .img img:first-of-type{
	margin-top: 120px;
}

/* カレンダーセクション */
.section-season {
	padding: 50px 0;
	margin-bottom: 50px;
	background-color: #f4f4f4;
}
.section-season .container {
	width: 95%;
	max-width: 1100px;
	margin: 0 auto
}
.section-season .section-header{
	margin-bottom: 15px;
}
.section-season h2{
	font-size: 200%;
	letter-spacing: 2px;
}
.section-season h2 span{
	color: #5dac81;
	font-size: 130%;
}
.section-season .season-grid{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}
.section-season .season-item{
	position: relative;
}
.section-season .season-img{
	width: 100%;
	height: auto;
	aspect-ratio: 16/9;
	overflow: hidden;
	position: relative;
	border-radius: 20px;
}
.section-season .season-img img{
	display: block;
	width: 100%;
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.section-season .season-img span{
	position: absolute;
	top: 0;
	background: var(--color);
	color: #fff;
	padding: 10px 20px;
}
.section-season .season-item:nth-of-type(odd) .season-img span{
	left: 0;
	border-radius: 0 0 20px 0;
}
.section-season .season-item:nth-of-type(even) .season-img span{
	right: 0;
	border-radius: 0 0 0 20px;
}
.section-season .season-text h3{
	color: var(--color);
	font-size: 120%;
	letter-spacing: 1px;
}
.section-season .season-text p{
	letter-spacing: 1px;
	line-height: 1.8;
}

.section-gallery{
	width: 95%;
	max-width: 1100px;
	margin: 0 auto;
	position: relative;
	z-index: 0;
}
.section-gallery .section-header{
	width: fit-content;
	position: relative;
	padding: 30px 20px 30px 0;
	margin-bottom: 40px;
	z-index: 0;
	color: #fff;
}
.section-gallery .section-header::before{
	content: '';
	width: 100vw;
	height: 100%;
	background: #5dac81;
	position: absolute;
	top: 0;
	right: 0%;
	z-index: -1;
	border-radius: 20px;
}
.section-gallery h2{
	font-size: 200%;
	letter-spacing: 1px;
	margin-bottom: 10px;
}

.gallery-item{
	display: flex;
	align-items: center;
}
.gallery-item.right{
	justify-content: flex-end;
}
.gallery-item > img{
	display: auto;
	width: 35%;
	height: auto;
}
.gallery-item figure{
	width: 70%;
	position: relative;
}
.gallery-item figure img{
	display: block;
	width: 80%;
	height: auto;
	margin: 0 0 0 auto;
}
.gallery-item figure figcaption{
	width: fit-content;
	position: absolute;
	bottom: 5%;
	left: 0;
	background: #fcede5;
	padding: 20px;
	border-radius: 30px;
}
.gallery-item figure figcaption h3{
	font-size: 150%;
}
.gallery-item figure figcaption p{
	font-size: 108%;
}

/*------------------------------------------

		SVG

--------------------------------------------*/
.svg_ornament{
	position: absolute;
	top: 7%;
	right: 0;
	left: 0;
	margin: auto;
	width: 350px;
	transform: rotate(-40deg);
}

.svg_ornament02{
	position: absolute;
	top: 32.5%;
	right: 0%;
	width: 450px;
	transform: rotate(-40deg);
}

.svg_ornament03{
	position: absolute;
	top: 60%;
	left: 0%;
	width: 350px;
	transform: rotate(-40deg);
}
/*------------------------------------------

		SVG

--------------------------------------------*/

.section-last{
	margin: 60px auto;
}
.section-last .img-box{
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	margin-bottom: 10px;
}
.section-last img{
	width: 48%;
	height: auto;
	margin-bottom: 10px;
	border-radius: 20px;
}
.section-last p{
	text-align: center;
	font-weight: bold;
	font-size: 116%;
	letter-spacing: 1px;
	line-height: 1.8;
}