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

#pageWrap {
    padding: 0;
}
#sec01 {
	position: relative;
}
#sec01 h3 {
	position: absolute;
	left: 50%;
	top:50%;
	width: 70%;
	transform: translate(-50%,-50%);
}
#bgWrap {
	background-image: url("../images/bg-paper.jpg");
	background-position: left top;
	background-size: 50%;
	padding-bottom: 5%;
}
.boxWidth {
	container-type: inline-size;
}
#sec02 {}
#sec02 .h3Box {
	padding: 3% 0;
}
#sec02 .h3Box h3 {
	font-size: clamp(13px, 2.5cqw, 30px);
}
#sec02 .h3Box h3 span {
	color: #c6000b;
	font-size: 220%;
}
#sec02 h4 {
	
	font-size: clamp(13px, 2.2cqw, 30px);
	line-height: 1.3;
	padding: 0.5em 0;
	position: relative;
	margin-bottom: 30px;
}
#sec02 h4::before,#sec02 h4::after {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 6px;
	border-top: #000 solid 1px;
	border-bottom: #000 solid 1px;
}
#sec02 h4::after {
	top: auto;
	bottom: 0;
}
#sec02 #figBox {
	max-width: 1000px;
	margin: 0 auto;
}
#sec02 #figBox dt {
	width: 21%;
}
#sec02 #figBox dd {
	width: 78%;
}

.whBase {
	background-color: #fff;
	padding: 3% 5%;
	margin-top: 5%;
}
.whBase .pointBox {
	background-color: #fffded;
	border: #e50012 solid 1px;
	border-radius: 10px;
	position: relative;
	box-shadow: 5px 5px 0px #e50012;
	width: 93%;
	margin-left: 7%;
	
}
.whBase .pointBox .point {
	position: absolute;
	width: 12%;
	left: 0;
	top: -1px;
	transform: translateX(-50%);
}
.whBase .pointBox h3 {
	color: #e50012;
	padding: 1em 0;
	font-size: clamp(13px, 2.2cqw, 30px);
	min-height: 4.5em;
	display: flex;
justify-content: center;
align-items: center;
	
}

#sec03 {}
#sec03 .flex01 {
	margin-top: 50px;
}
#sec03 .flex01 .itemBox {
	width: 48%;
	border: #c8bb9b solid 1px;

}
#sec03 .flex01 .itemBox h4 {
	font-size: 19px;
	background-color: #c8bb9b;
	color: #fff;
	padding: 0.5em;
}
#sec03 .flex01 .itemBox .flex02 {
	padding: 30px 20px 10px;
}
#sec03 .flex01 .itemBox .flex02 .figBox {
	width: 35%;
}
#sec03 .flex01 .item02 .flex02 .figBox {
	width: 15%;
}
#sec03 .flex01 .itemBox p {
	font-size: 15px;
	text-align: justify;
	flex: 1;
	padding-left: 1em;
}
#sec03 .flex01 .itemBox p span {
	color: #e50012;
}
#sec03 .flex01 .itemBox .flex02 {}

#sec04 {}
#sec04 h4 {
	background-color: #c6000b;
	color: #fff;
	font-size: clamp(13px, 2.8cqw, 35px);
	line-height: 1.3;
	padding: 1em;
}

#sec05 {}
#sec05 .flex {
	margin-top: 4%;
}
#sec05 .flex .itemBox {
	width: calc(100% / 3);
	position: relative;
	transition: 0.5s ease-out;
	transition-delay: calc(0.5s * var(--char-index));
	transform: translateY(0);
}
#sec05 .flex .itemBox .txtBox {
	position: absolute;
	width: 100%;
	top: 50%;
	transform: translateY(-50%);
	container-type: inline-size;
}
#sec05 .flex .itemBox .txtBox p {
	text-align: center;
	color: #fff;
	font-size: 6.4cqw;
	line-height: 1.3;
}

#txtLast {
	padding-top: 4%;
}
#txtLast h3 {
	color: #e50012;
	font-size: clamp(13px, 2.4cqw, 35px);
}
.info-area {
	background: none;
	padding: 3% 0 0;
}



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

@media screen and (max-width: 599px){
	#sec01 h3 {
		width: 85%;
	}
	#sec02 .h3Box {
    padding: 5% 0;
}
	#sec02 .h3Box h3  {
    font-size: clamp(13px, 4.8cqw, 30px);
	}
	#sec02 h4 {
	
	font-size: clamp(13px, 4.6cqw, 30px);
		padding: 1em 0;
		margin: 10px 0 30px 0;
	}
/*	#sec02 #figBox {
		width: 90%;
	}
	#sec02 #figBox dt {
		width: 43%;
	}
	#sec02 #figBox dd {
		width: 53%;
		overflow-x:scroll;
	}
	#sec02 #figBox dd img {
		width:  300%;
	}*/
	.whBase .pointBox {
		position: relative;
		box-shadow: 5px 5px 0px #e50012;
		width: 97%;
		margin-left: 3%;
		margin-top: 7%;

	}
	.whBase .pointBox .point {
		position: absolute;
		width: 24%;
		left: 3%;
		top: -1px;
		transform: translate(-50%,-50%);
	}
	.whBase .pointBox h3 {
		color: #e50012;
		padding: 1em 0;
		font-size: clamp(13px, 5.2cqw, 30px);
		min-height: 4.5em;
		display: flex;
	justify-content: center;
	align-items: center;

	}
	#sec03 .flex01 .itemBox {
    width: 100%;
	}
	#sec03 .flex01 .itemBox .flex02 {
		padding: 10px 20px 30px;
	}
	#sec03 .flex01 .itemBox .flex02 .figBox {
		width: 35%;
		margin: 0 auto;
	}
	#sec03 .flex01 .item02 .flex02 .figBox {
		width: 15%;
		margin: 0 auto;
	}
	#sec03 .flex01 .itemBox p {
		font-size: clamp(13px, 3.4cqw, 16px);
		text-align: justify;
		flex: none;
		padding-left: 0em;
		width: 100%;
	}
	#sec04 h4 {
   font-size: clamp(13px, 5.2cqw, 30px);
		line-height: 1.6;
		margin: 30px 0;
	}
	.whBase .pointBox h3 {
		 min-height: 5.5em;
  }
	#sec05 .flex .itemBox {
    width: 90%;
		padding-bottom: 10px;
		margin: 0 auto;
}
/*	#sec05 .flex .itemBox:nth-child(2n) {
		margin-left: 10%;
	}*/
	#txtLast h3 {
		font-size: clamp(13px, 5.2cqw, 30px);
		padding: 2em 0;
	}
	#sec05 .flex .itemBox {
		transition-delay: calc(0s * var(--char-index));
	}
	

}