@charset "UTF-8";

/*--------------------------------------------------------------------
index.html	(トップページ)
top.css
--------------------------------------------------------------------*/

/*------------#title---------------------------------------------------------------*/
#title {
	height: 700px;
	margin-bottom: 0;
	background: inherit !important;
}
#title::before { display: none; }
#title div.Anima {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	filter: alpha(opacity=0);
	-moz-opacity: 0;
	opacity: 0;
	z-index: 0;
}
#title div#Anima01 { background-image: url("../img/mv_p01.jpg"); }
#title div#Anima02 { background-image: url("../img/mv_p02.jpg"); }
#title div#Anima03 { background-image: url("../img/mv_p03.jpg"); }
#title div#Anima04 { background-image: url("../img/mv_p04.jpg"); }
#title div#Anima05 { background-image: url("../img/mv_p05.jpg"); }
#title #InTitle {
	position: absolute;
	width: 100%;
	top: 55%;
	transform: var(--transformY);
}
#title #InTitle h2 {
	position: relative;
	top: 0;
	left: 0;
	transform: none;
}
#title #InTitle dl {
	padding: 0 1em;
	text-align: center;
	font-family: var(--mincho);
	font-feature-settings: "palt" 1;
	font-weight: bold;
	text-shadow: 
		 3px  3px 3px var(--co-white),
		-3px  3px 3px var(--co-white),
		 3px -3px 3px var(--co-white),
		-3px -3px 3px var(--co-white),
		 3px  0px 3px var(--co-white),
		 0px  3px 3px var(--co-white),
		-3px  0px 3px var(--co-white),
		 0px -3px 3px var(--co-white);
}
#title #InTitle dl dt {
	margin-bottom: 0.5em;
	font-size: 1.625em;
	font-weight: bold;
	color: var(--co-green);
}

@media (max-width: 480px) {
	#title { height: 80vh; }
}


/*------------article-------------------------*/
article { padding-bottom: 0; }
main article:not(:last-of-type) { margin-bottom: 0; }
article::after { display: none; }
#contact { display: none; }


/*------------TopTxt-------------------------*/
#TopTxt {
	width: 100%;
	max-width: inherit;
	padding: 60px 1em;
}
#TopTxt h2 {
	width: 100%;
	text-align: center;
	font-family: var(--mincho);
	font-feature-settings: "palt" 1;
	font-size: 2.25em;
	font-weight: bold;
	color: var(--co-pink);
}
#TopTxt p {
	margin-top: 30px;
	text-align: center;
	line-height: 2;
}


/*------------content-------------------------*/
#content {
	position: relative;
	width: 100%;
	max-width: inherit;
	margin-top: 30px;
	padding: 150px 0;
	background: linear-gradient(to bottom,  rgba(127,128,128,1) 0%,rgba(170,170,170,1) 100%);
}
#content::before,
#content::after {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	height: 140px;
	background-color: var(--co-white);
	z-index: 0;
}
#content::before {
	clip-path: polygon(100% 0, 0 0, 0 100%);
	top: -1px;
	left: 0;
}
#content::after {
	clip-path: polygon(100% 0, 100% 100%, 0 100%);
	bottom: -1px;
	left: 0;
}
#content h2 {
	position: relative;
	margin-bottom: 40px;
	padding-bottom: 0;
	text-align: center;
	font-family: var(--mincho);
	font-feature-settings: "palt" 1;
	font-size: 2.25em;
	font-weight: bold;
	color: var(--co-white);
	z-index: 1;
}
#content ul {
	display: flex;
	flex-direction: column;
	gap: 40px;
	width: 100%;
	margin: 0 auto;
}
#content ul li {
	position: relative;
	width: 100%;
	margin-left: 0;
}
#content ul li a {
	position: relative;
	display: flex;
	justify-content: space-between;
}
#content ul li:nth-of-type(2n) a {
	flex-direction: row-reverse;
}
#content ul li .worPho {
	position: relative;
	width: 75%;
	clip-path: polygon(0 0, 100% 0, 90% 100%, 0% 100%);
}
#content ul li:nth-of-type(2n) .worPho {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 10% 100%);
	margin-left: auto;
}
#content ul li .worPho img {
	width: 100%;
	height: 400px;
}
#content ul li dl {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 25%;
	min-width: 340px;
	text-align: center;
}
#content ul li dl dt {
	line-height: 1.2;
	font-family: var(--mincho);
	font-feature-settings: "palt" 1;
	font-size: 2.25em;
	font-weight: bold;
	color: var(--co-white);
}
#content ul li dl dt span {
	position: relative;
	display: block;
	text-align: center;
	font-size: 0.69em;
}
#content ul li dl dt span::before,
#content ul li dl dt span::after {
	display: inline-block;
	content: "-";
	margin: 0 0.5em;
}
#content ul li dl dd {
	margin-top: 1em;
	padding-bottom: 50px;
	background-position: center bottom;
	background-repeat: no-repeat;
	text-align: center;
	color: var(--co-white);
}
#content ul li:nth-of-type(1) dl dd { background-image: url("../img/arrow_r.png"); }
#content ul li:nth-of-type(2) dl dd { background-image: url("../img/arrow_b.png"); }
#content ul li:nth-of-type(3) dl dd { background-image: url("../img/arrow_g.png"); }

@media (max-width: 800px) {
	#content ul li dl { min-width: 230px; }
}
@media (max-width: 650px) {
	#content ul li .worPho {
		width: 100%;
		z-index: 0;
	}
	#content ul li .worPho img {
		height: 250px;
	}
	#content ul li dl {
		position: absolute;
		padding: 1em;
		background-color: rgb(from var(--co-black) r g b / 0.6);
		top: 50%;
		left: 50%;
		transform: var(--transformXY);
		z-index: 1;
	}
}


/*------------info------------------------*/
#news {
	position: relative;
	width: 100%;
	max-width: inherit;
	margin-top: 30px;
}
#news h2 {
	margin-bottom: 10px;
	text-align: center;
	line-height: 1.2;
	font-family: var(--mincho);
	font-feature-settings: "palt" 1;
	font-size: 2.25em;
	font-weight: bold;
	color: var(--co-green);
}
#news section {
	width: 100%;
	max-width: inherit;
	padding: 1em;
	background-color: #d4d5d5;
}
#news div {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
}
#news iframe {
	display: block;
	width: 100%;
	height: 210px;
	border: none;
	background-color: transparent;
}


/*------------water------------------------*/
#water {
	position: relative;
	width: 100%;
	max-width: inherit;
	margin-top: 40px;
}
#water a {
	position: relative;
	width: 100%;
}
#water div img {
	width: 100%;
	height: 400px;
	object-position: center left;
}
#water dl {
	position: absolute;
	top: 50%;
	right: 5%;
	transform: var(--transformY);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 42%;
	max-width: 580px;
}
#water dl dt {
	filter: drop-shadow(0 0 2px rgba(255,255,255,1));
	transform: translateZ(0);
}
#water dl dd {
	max-width: 420px;
	margin-top: 1.5em;
	padding-bottom: 50px;
	background: url("../img/arrow_b.png") center bottom no-repeat;
	text-shadow: 
		 3px  3px 3px var(--co-white),
		-3px  3px 3px var(--co-white),
		 3px -3px 3px var(--co-white),
		-3px -3px 3px var(--co-white),
		 3px  0px 3px var(--co-white),
		 0px  3px 3px var(--co-white),
		-3px  0px 3px var(--co-white),
		 0px -3px 3px var(--co-white);
}
@media (max-width: 580px) {
	#water dl {
		width: 96%;
		top: 50%;
		left: 50%;
		right: auto;
		transform: var(--transformXY);
	}
	#water dl dd {
		width: 90%;
	}
}