@charset "UTF-8";

/*--------------------------------------------------------------------
index.html	(トップページ)
top.css
--------------------------------------------------------------------*/

/*------------#title---------------------------------------------------------------*/
#title {
	height: 700px;
	margin-bottom: 0;
	background: inherit !important;
}
#title::before { background-color: var(--co-main); }
#title::after {
	position: absolute;
	display: block;
	content: "";
	width: 65%;
	max-width: 910px;
	height: 145px;
	background-color: rgba(42,43,43,0.40);
	clip-path: polygon(0 0, 100% 0%, 90% 100%, 0% 100%);
	top: 50%;
	left: 0;
	transform: var(--transformY);
}
#title h2 {
	position: absolute;
	width: 100%;
	max-width: 1100px;
	top: 50%;
	padding: 0;
	line-height: 1;
	text-align: left;
	font-size: 2.75em;
	text-shadow: 
		 3px  3px 3px var(--co-black),
		-3px  3px 3px var(--co-black),
		 3px -3px 3px var(--co-black),
		-3px -3px 3px var(--co-black),
		 3px  0px 3px var(--co-black),
		 0px  3px 3px var(--co-black),
		-3px  0px 3px var(--co-black),
		 0px -3px 3px var(--co-black);
}
#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"); }

@media (max-width: 1100px) {
	#title h2 {
		width: 80%;
		padding: 0 0.5em;
		left: 0;
		transform: translate(0 , -50%);
		font-size: 1.9em;
	}
}
@media (max-width: 840px) {
	#title::after {
		position: absolute;
		display: block;
		content: "";
		width: 95%;
		max-width: 910px;
		height: 145px;
		background-color: rgba(42,43,43,0.40);
		clip-path: polygon(0 0, 100% 0%, 90% 100%, 0% 100%);
		top: 50%;
		left: 0;
		transform: var(--transformY);
	}
}

@media (max-width: 480px) {
	#title { height: 60vh; }
	#title h2 {
		width: 90%;
	}
}

@media (max-width: 420px) {
}


/*------------article-------------------------*/
article { padding-bottom: 0; }
main article:not(:last-of-type) { margin-bottom: 0; }
article::after { display: none; }


/*------------TopTxt-------------------------*/
#TopTxt {
	width: 100%;
	max-width: inherit;
	padding: 35px 1em;
	background-color: var(--co-main);
	color: var(--co-white);
}
#TopTxt h2 {
	position: relative;
	width: 100%;
	padding-bottom: 25px;
	text-align: center;
	font-size: 2.25em;
	font-weight: bold;
}
#TopTxt h2::before {
	position: absolute;
	display: block;
	content: "";
	width: 20%;
	max-width: 280px;
	height: 6px;
	background-color: var(--co-white);
	bottom: 0;
	left: 50%;
	transform: var(--transformX);
}
#TopTxt p {
	margin-top: 20px;
	text-align: center;
	font-size: 1.125em;
}


/*------------content-------------------------*/
#content {
	position: relative;
	width: 100%;
	max-width: inherit;
	padding: 170px 0 40px;
	background-color: var(--co-gray30);
}
#content::before {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 90px;
	top: 0;
	left: 0;
	background-color: var(--co-main);
	clip-path: polygon(100% 0, 0 0, 0 100%);
	z-index: 1;
}
#content h2 {
	margin-bottom: 20px;
	padding-bottom: 0;
	text-align: center;
	font-size: 2.2em;
	font-weight: bold;
}
#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:nth-of-type(2n) { margin-left: auto; }
#content ul li a { position: relative; }
#content ul li img {
	width: 100%;
	height: 400px;
}
#content ul li p {
	position: absolute;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	width: 25%;
	max-width: 350px;
	height: 170px;
	padding-top: 15px;
	background-color: rgba(0,140,166,0.75);
	bottom: 0;
	left: 50%;
	transform: var(--transformX);
	z-index: 5;
	line-height: 1.2;
	font-size: 1.9em;
	font-weight: bold;
	color: var(--co-white);
}
#content ul li p::after {
	position: absolute;
	display: block;
	content: "";
	width: 20px;
	height: 30px;
	background: url("../img/arrow_w.png") no-repeat left top;
	left: 50%;
	bottom: 15px;
	transform: var(--transformX);
}
#content ul li:nth-of-type(2n) p { background-color: rgba(255,99,0,0.75); }
#content ul li p span {
	position: relative;
	display: block;
	margin-top: 15px;
	padding-top: 20px;
	font-size: 0.6em;
}
#content ul li p span::before {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	max-width: 280px;
	height: 6px;
	background-color: var(--co-white);
	top: 0;
	left: 50%;
	transform: var(--transformX);
}

@media (max-width: 960px) {}
@media (max-width: 650px) {
	#content ul li { width: 100%; }
}

@media (max-width: 480px) {
	#content ul li img {
		width: 100%;
		height: 300px;
	}
	#content ul li p { width: 80%; }
}


/*------------info------------------------*/
#news {
	position: relative;
	width: 100%;
	max-width: inherit;
	margin: 100px auto 0;
	background-image: linear-gradient(90deg, #ffffff 30%, #8b7e74 30%);
}
#news section {
	display: flex;
	justify-content: space-between;
	width: 100%;
	max-width: inherit;
	margin: 0 auto;
	gap: 30px;
}
#news h2 {
	width: 20%;
	text-align: right;
	font-size: 1.9em;
	font-weight: bold;
	color: #8b7e74;
}
#news div {
	width: calc(100% - 20% - 30px);
	margin: 0 auto;
	padding: 10px 1em;
	background-color: #8b7e74;
}
#news iframe {
	display: block;
	width: 100%;
	height: 210px;
	border: none;
	background-color: transparent;
}
@media (max-width: 1100px) {
	#news h2 {
		width: 40%;
		padding: 0 0.25em;
		text-align: left;
	}
	#news div { width: calc(100% - 40% - 30px); }
}
@media (max-width: 830px) {
	#news { background: #fff; }
	#news section {
		flex-direction: column;
		gap: 15px;
	}
	#news h2 { width: 100%; }
	#news div {
		width: 100%;
		margin: 0 auto;
		padding: 15px 1em;
	}
}