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

/*			location
==============================*/
.contents_Wrap {
	background: transparent;
	color: #3e4e57;
}
.contents_Wrap section {
	overflow: hidden;
}
.contents_Wrap figure {
	position: relative;
	height: fit-content;
}

.page_mv {
	position: relative;
	background: url(../img/main.jpg) no-repeat center center;
	background-size: cover;
	aspect-ratio: 14 / 5.3;
}
.page_mv h2 {
	padding: 5% 0;
	font-family: "EB Garamond", serif;
	color: #fff;
	font-size: 4vw;
	letter-spacing: 0.2em;
	text-align: center;
	filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.8)) drop-shadow(0 0 7px rgba(0, 0, 0, 0.8));
}

.head_box {
	text-align: center;
	line-height: 1.8;
	letter-spacing: 0.08em;
}
.head_box span {
	font-size: 24px;
	display: inline-block;
}
.head_box p {
	font-size: 16px;
}
.text {

letter-spacing: 0.08em;
}
.text h3 {
font-family: "EB Garamond", serif;
font-size: 32px;
letter-spacing: 0.08em;
margin-bottom: 30px;
}
.text h4 {
font-size: 20px;
line-height: 2.0;
}
.text p {
font-size: 14px;
line-height: 2.0;
}

/*----- 個別 -----*/
.page_head {
	margin: 80px auto;
}
.page_head span {
	color: #273c7d;
}


.sec01 {
display: flex;
justify-content: space-between;
align-items: center;
margin: 0 auto 120px;
}
.sec01 figure {
width: 52.142857142857143%;
}
.sec01 img {
}
.sec01 .text {
width: 36.428571428571429%;
margin: 0 7.142857142857143% 0 auto;
}
.sec01 .text h3{
display: block;
width: 100%;
line-height: 0.65;
margin-left: 40px;
}
.sec01 .text p{
margin-left: 40px;
}
.sec01 .text figure{
width: 100%;
max-width: 510px;
margin: 60px auto 0 0;
}
.sec02 {
margin: 0 auto 120px;
}
.sec02 .flex{
width: 100%;
justify-content: space-between;
align-items: center;
}
.sec02 figure{
width: 85.714285714285714%;
}
.sec02 .cat_ttl{
width: calc(6.5% * 0.7);
}
.sec02 .text{
text-align: center;
width: 94%;
max-width: 1200px;
margin: 60px auto 0;
}
.sec03 {
margin: 0 auto 150px;
}
.sec03 .flex{
width: 100%;
justify-content: space-between;
align-items: center;
}
.sec03 figure{
width: 85.714285714285714%;
}
.sec03 .cat_ttl{
width: calc(6.5% * 0.7);
}
.sec03 .text{
text-align: center;
width: 94%;
max-width: 1200px;
margin: 60px auto 0;
}

.sec04 {
margin: 0 auto 100px;
}
.sec04 figure{
}

.sec04 .text{
text-align: center;
margin: 0 auto 60px;
}
.sec04 .text h3{
display: block;
width: 100%;
line-height: 0.65;
}
.sec04 .text h4{
margin: 0 auto 20px;
}



/*-----------------------------
tab
-----------------------------*/
@media only screen and (max-width: 1024px) {

}


/*-----------------------------
tab・sp
-----------------------------*/
@media only screen and (max-width: 769px) {

	.page_mv {
		background: url(../img/main_sp.jpg) no-repeat center center;
		background-size: cover;
		aspect-ratio: 18 / 13.6;
	}
	.page_mv h2 {
		padding: 8% 0;
		font-size: 7vw;
	}

	.head_box span {
		font-size: 19.2px;
	}
	.head_box p {
		font-size: 14px;
		text-align: left;
	}
    .text h3 {
    text-align: left;
    font-size: 27px;
    margin-bottom: 20px;
}
    .text h4 {
    font-size: 18px;
    line-height: 1.8;
}
    .text p {
    font-size: 13px;
    text-align: left;
}


	/*----- 個別 -----*/
	.page_head {
		margin: 40px auto;
	}
    .sec01,
    .sec04{
    margin: 0 auto 60px;
}
    .sec02,
    .sec03{
    margin: 0 auto 80px;
}
    .sec01{
    flex-wrap: wrap;
}
    .sec01 figure {
width: 100%;
}

.sec01 .text {
width: 94%;
margin: 30px auto 0;
}
.sec01 .text h3{
margin-left: 0;
}
.sec01 .text p{
margin-left: 0;
}
.sec01 .text figure{
margin: 30px auto 0;
}
.sec02 .flex {
flex-wrap: wrap;
}
.sec02 .cat_ttl{
width: calc(6.5% * 1);
}
.sec02 .text {
    margin: 30px auto 0;
}
.sec02 figure {
    width: 100%;
    order: 2;
}
.sec02 .cat_ttl{
width: 62.111111111111111%;
margin: 0 auto 0 0;
order: 1;
}
.sec03 .flex {
flex-wrap: wrap;
}
.sec03 .cat_ttl{
width: 100%;
order: 1;
}
.sec03 .text {
    margin: 30px auto 0;
}
.sec03 figure {
    width: 100%;
    order: 2;
}
.sec04 .inner_1000{

}
.sec04 .text{
margin: 0 auto 30px;
}
.sec04 .text h4{
text-align: left;
}
.sec04 figure{

}

}
