@charset "UTF-8";
/* CSS Document */

#pageWrap {
    padding: 0 0 6%;
    /*font-family: 'YakuHanMP', 'Noto Serif JP', serif;*/
}

#sec01 {
	position: relative;
	container-type: inline-size;
}
#sec01 .txtBox {
	position: absolute;
	width: 100%;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
#sec01 .txtBox h3 {
	font-size: 4cqw;
	letter-spacing: 0.1em;
	color: #fff;
	text-shadow: 0px 2px 6px #000;
}
#sec01 .txtBox p {
	font-size: 1.4cqw;
	padding-top: 1em;
}

#sec02,#sec03 {
	border-top: #fff000 solid 1.3cqw;
}
.secTit {
	padding: 3% 0;
	background-image: url("../images/bg-01.jpg");
	background-repeat: no-repeat;
	background-position: center right;
	background-size: cover;
	position: relative;
}
.secTit::after {
	content: "image";
	position: absolute;
	bottom: 0.3em;
	right: 0.5em;
	font-size: 10px;
	color: #fff;
}
.secTit .h3Box {
	text-align: center;
	container-type: inline-size;
	color: #fff;
}
.secTit .h3Box h3 {
	width: 80%;
	max-width: 400px;
	margin: 0 auto;
	padding-bottom: 15px;
}
.secTit .h3Box h4 {
	font-size: 2cqw;
}
.secTit .h3Box p {
	padding-top: 0.5em;
	font-size: 1.4cqw;
}
.secTit .h3Box p.cap {
	font-size: 70%;
}
	
#sec02 {}
#sec02 .figBox {
	max-width: 1000px;
	padding: 6% 0;
}
#sec02 .figBox .leftBox {
	width: 68%;
}
#sec02 .figBox .rightBox {
	width: 28%;
}
#sec02 .figBox > div {
	position: relative;
}
#sec02 .figBox > div::after {
	content:attr(data-cap);
	position: absolute;
	right: 0;
	bottom: 0;
	font-size: 10px;
}

#sec03 {}
#sec03 .secTit {
	background-image: url("../images/bg-02.jpg");
}
#sec03 .itemBox {
	max-width: 1000px;
	padding: 3% 0 0;
}
#sec03 .itemBox dl {
	display: flex;
	align-items: center;
	background: #FFF000;
background: linear-gradient(60deg, rgba(255, 240, 0, 1) 42%, rgba(0, 105, 52, 1) 42%);
	container-type: inline-size;
}
#sec03 .itemBox dt {
	padding: 0.5em;
	text-align: center;
	width: 18em;
	font-size: 2.4cqw;
}
#sec03 .itemBox dd {
	padding: 0.5em 1em;
	color: #fff;
	font-size: 2cqw;
}
#sec03 .itemBox .flex {
	align-items: center;
	padding: 15px 0 0;
}
#sec03 .itemBox .flex .imgBox {
	width: 55%;
}
#sec03 .itemBox .flex p {
	width: 40%;
	text-align: justify;
	font-size: 1.3cqw;
}
#sec03 .itemBox .flex p .cap {
	font-size: 75%;
}

#sec04 {
	padding-top: 5%;
	margin-bottom: 30px;
}
#sec04 > div {
	max-width: 1000px;
	padding: 3% 5%;
	background-color: #fff;
	box-shadow: 2px 2px 10px rgba(0,0,0,0.8);
	container-type: inline-size;
}
#sec04 h3 {
	font-size: 3.3cqw;
	text-align: center;
	border-bottom: #000 solid 1px;
	padding: 0.3em 0;
	margin-bottom: 0.3em;
}
#sec04 p {
	font-size: 2.3cqw;
	line-height: 2;
}
#sec04 .logo {
	width: 15%;
	margin: 30px auto 0;
}

@media screen and (max-width: 959px){}

@media screen and (max-width: 599px){
	#pageTit h2 {
		line-height: 1.2;
	}
	#sec01 .txtBox {
    position: static;
    width: 100%;
    transform: translateY(0%);
		padding: 30px 0;
	}
	#sec01 .txtBox h3 {
		font-size: 6cqw;
		letter-spacing: 0.1em;
		color: #000;
		text-shadow: 0px 2px 4px rgba(0,0,0,0.2);
	}
	#sec01 .txtBox p {
		font-size: 3.4cqw;
	}
	.secTit {
		padding: 6% 0;
	}
	.secTit .h3Box {
		text-align: center;
		container-type: inline-size;
		color: #fff;
	}
	.secTit .h3Box h3 {
		width: 90%;
	}
	.secTit .h3Box h4 {
		font-size: 4cqw;
	}
	.secTit .h3Box p {
		font-size: 3.4cqw;
	}
	.secTit .h3Box p.cap {
		font-size: 80%;
	}
	#sec02 .figBox .leftBox {
		width: 100%;
	}
	#sec02 .figBox .rightBox {
		width: 60%;
		margin: 20px auto 0;
		padding-bottom: 10px;
	}
	#sec03 .itemBox dl {
		display: block;
		background:none;
	}
	#sec03 .itemBox dt {
		padding: 0.5em;
		text-align: center;
		width: 100%;
		font-size: 4.4cqw;
		background-color: rgba(255, 240, 0, 1);
	}
	#sec03 .itemBox dd {
		font-size: 4cqw;
		background-color: rgba(0, 105, 52, 1);
	}
	#sec03 .itemBox .flex .imgBox {
		width: 100%;
	}
	#sec03 .itemBox .flex p {
		width: 100%;
		font-size: 3.4cqw;
		padding: 1em;
	}
	#sec04 > div {
		padding: 30px;
	}
	#sec04 h3 {
		font-size: 6cqw;
	}
	#sec04 p {
		font-size: 4.4cqw;
		line-height: 2;
	}
	#sec04 .logo {
		width: 30%;
	}
}






