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

#pageTit {
	background-image: url("../img/bg-tit.jpg");

}

#sec01{}
#sec01 .flex01{
	border-bottom: #eee solid 2px;
}
#sec01 .flex01 .leftBox{
	width: 35%;
	display: flex;
justify-content: center;
align-items: center;
	flex-wrap: wrap;
}
#sec01 .flex01 .leftBox .box01 {
}
#sec01 .flex01 .leftBox .box01 .icon {
	width: 25%;
	margin: 0 auto;
}
#sec01 .flex01 .leftBox .box01 h3 {
	
	text-align: center;
	font-size: 18px;
	padding-top: 2em;
	line-height: 2;
	letter-spacing: 0.2em;
	padding-left: 0.2em;
}

#sec01 .flex01 .rightBox{
	border-left: #eee solid 2px;
	padding: 7vw 0 7vw 5vw;
	width: 65%;
}

#sec01 .flex01 .rightBox .lead {
	line-height: 4;
/*	transition-delay: 1s;*/
}
#sec01 .flex01 .rightBox p span {
	display: inline-block;
	transition-delay: calc(0.3s * var(--char-index));
	transition-duration: 1s;
	opacity: 0;
	transform: translateY(50px);
}
#sec01 .flex01 .rightBox .lead.active span {
	opacity: 1;
	transform: translateY(0px);
}

#sec01 .flex02 .rightBox{
	width: 35%;
}
#sec01 .flex02 .rightBox{
	border-left: #eee solid 2px;
	padding: 7vw 0 7vw 5vw;
	width: 65%;
}
#sec01 .flex02 .rightBox table{
}
#sec01 .flex02 .rightBox th,#sec01 .flex02 .rightBox td{
	padding: 1em;
	font-weight: 300;
	letter-spacing: 0.1em;
	line-height: 2;
}
#sec01 .flex02 .rightBox th{
}
#sec01 .flex02 .rightBox td{
}

#sec02 {}
#sec02 .mapWrap {
	width: 100%;
	height: 30vw;
	position: relative;
}
#sec02 .mapWrap iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 959px) {
	#sec01 .flex01 .leftBox {
		container-type: inline-size;
	}
	#sec01 .flex01 .leftBox .box01 h3 {
		font-size: 6cqw;
	}
	#sec01 .flex02 .rightBox {
    padding: 7vw 0 7vw 1vw;
}
	#sec01 .flex02 .rightBox th, #sec01 .flex02 .rightBox td {
		font-size: clamp(13px, 1.7vw, 14px);
	}
	#sec02 .mapWrap {
    height: 50vh;
	}
}

@media screen and (max-width: 599px) {
	#sec01 .flex01 .leftBox {
		width: 100%;
	}
	#sec01 .flex01 .leftBox .box01 .icon {
    width: 25%;
		max-width: 60px;
		margin-top: 30px;
}
	#sec01 .flex01 .leftBox .box01 h3 {
		font-size: 4.7cqw;
	}
	#sec01 .flex01 .rightBox,
	#sec01 .flex02 .rightBox {
    border-left: #eee solid 0px;
    padding: 7vw 0;
    width: 90%;
		margin: 0 auto;
	}
	#sec01 .flex01 .rightBox .lead {
		line-height: 2.4;
	}
	#sec01 .flex01 .rightBox p span {
		display: inline;
	}
	#sec01 .flex02 .rightBox table {
		width: 100%;
	}
	#sec01 .flex02 .rightBox th, #sec01 .flex02 .rightBox td {
    padding: 0;
    letter-spacing: 0em;
    line-height: 1.8;
		text-align: left;
		font-size: clamp(12px, 3.5vw, 14px);
		display: block;
		width: 100%;
}
	#sec01 .flex02 .rightBox table {
		
	}
	#sec01 .flex02 .rightBox th{
		border-bottom: #ccc solid 1px;
		padding-top: 1em;
		font-weight: 400;
	}


}



