/* CSS Document */

body{
	background: #fff;
    background-size: contain;
}

.page-link-header {
    padding-top: 120px;
    margin-top: -120px;
}

.sub-main-area{
	max-width: 1300px;
    width: 100%;
    padding: 0 20px;
	margin: 80px auto 0;
	
}


/*subpage fv  */

.menu_p span::after {
    text-shadow: none;
	color: #776f46;
}

.sub_fv{
    width: 100%;
    height: 550px;
    position: relative;
    display: flex;
	background: url(../img/subpage-fv.jpg) no-repeat right bottom;
    background-size: cover;
	justify-content: center;
	align-items: center;
}

.sub_fv_title{
    position: absolute;
    width: 100%;
    max-width: 1300px;
    margin: auto;
    padding: 30px;
}

.sub-en-title{
	font-family: "Playfair Display SC", serif;
	color: #b7a06e;
	font-size: min(6vw,90px);
	letter-spacing: 10px;
	position: relative;
}

.sub-en-title::before{
	position: absolute;
    content: '';
    display: block;
    width: 6vw;
    aspect-ratio: 1 / 1;
    background: url(../img/music-icon-beju.png) center no-repeat;
    background-size: cover;
    left: -2.5vw;
    top: -1.0vw;
}

.sub_fv_title h2 p{
	font-size: 26px;
	font-weight: 500;
	color: #333;
	letter-spacing: 5px;
}


.sub-title {
    margin: auto;
    max-width: 1300px;
    padding: 30px 30px 0;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
}

.sub-title a {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
	font-size: 16px;
}

.sub-title span{
	margin: 0 3px;
}


.sub-title span{
	font-size: 16px;
	font-weight: 500;
}

.sub-title a span{
	border-bottom: 1px dashed #333;
}

/*subpage fv */



.sub-main-area h3{
	font-size:35px;
	letter-spacing: 3px;
	padding-left: 50px;
	position: relative;
}

.sub-main-area h3::before{
	position: absolute;
	display: block;
	content: '';
	background: url("../img/icon-beji.png") center no-repeat;
	background-size:100% 100%;
	width:40px;
	aspect-ratio:4/3;
	left: 0;
	top:50%;
	transform: translateY(-50%);
}

.footer-top-line {
	max-width: 1300px;
	padding:0 20px;
	margin: 0 auto;
}

.footer-top-line span{
	display: block;
	background: #dfdfdf;
	width: 100%;
	height: 1px;
}



.sub-box-text {
    background: #f9f1ee;
    padding: 30px;
	font-family: "Noto Sans JP", sans-serif;
    margin: 10px 0;
	color:#333;
}

.sub-box-text h4{
	font-size: 20px;
	font-weight: 600;
	padding-bottom: 10px;
	display: inline-block;
}


.sub-box-text p{
	font-size: 16px;
	letter-spacing: 1px;
	line-height: 26px;
	padding-bottom: 10px;
	font-weight: 500;
}


.sub-box-text p span{
	font-weight: 600;
	color: #d52423;
}

.sub-box-text h4 span{
	color: #d52423;
}

.sub-box-item{
	padding: 20px 0 0;
	font-family: "Noto Sans JP", sans-serif;
}


.sub-box-item h4{
	font-size: 22px;
	letter-spacing: 2px;
	line-height: 40px;
    background: #4eb746;
	    background: #ef8200;
    color: #fff;
    padding: 0 20px;
}

.sub-box-item h4 span{
	padding-right: 20px;
}

.sub-box-item h5 {
	font-size: 20px;
	font-weight: 600;
	color: #772012;
	padding-left: 20px;
}

.sub-box-item .button2{
	justify-content: flex-start;
	margin: 20px auto;
}



.sub-box-item table{
	max-width: 800px;
	width: 100%;
	border-spacing: 0;
	border: 1px solid #666;
	background: #fff;
}



.sub-box-item table tr:first-child th{
	background: #f1f1f1;
}


.sub-box-item .table-type2 th{
	background: #f1f1f1;
}


.sub-box-item table th,
.sub-box-item table td{
	border: 1px solid #999;
	text-align: center;
	font-size: 18px;
	line-height: 24px;
	padding: 5px;
}


.sub-box-item table img{
	height: 100%;
	aspect-ratio:3/4;
    max-height: 60px;
	width: inherit;
}

.sub-box-item-content{
	padding:20px 0 0;
}

.sub-box-item-content p,
.sub-box-item-content ul{
	font-size: 18px;
	line-height: 30px;
	padding-bottom: 15px;
}

.sub-box-item-content ul li{
	padding-left: 30px;
	position: relative;
	font-size: 18px;
	font-weight: 500;
	line-height: 30px;
}

.sub-box-item-content ul li::before{
	position: absolute;
	display: block;
	content: '';
	background: url("../img/check-icon.png") center no-repeat;
	background-size:100% 100%;
	width:20px;
	aspect-ratio:1/1;
	left: 5px;
	top:50%;
	transform: translateY(-50%);
}

.sub-box-item-content p a{
	color:blue;
	font-weight: 500;
	text-decoration: underline;
}


.sub-box-ps{
	padding-top: 20px;
}

.sub-box-ps p{
	font-size: 18px;
	line-height: 25px;
	letter-spacing: 1px;
	padding-bottom: 5px;
	display: flex;
    align-items: center;
}


@media(max-width: 1300px){
	.sub_fv {
		height: 450px;
	}
	
	
}

@media(max-width: 1200px){

	.sub-box-text p {
		font-size: 16px;
	}
	
	.sub-box-item h4 {
	    font-size: 20px;
	    letter-spacing: 1px;
		line-height: 36px;
	}
	
	.sub-box-item h4 span {
		padding-right: 10px;
	}
	
	.sub-box-item-content {
		padding: 10px 0;
	}
	
	.sub-box-item-content p, .sub-box-item-content ul {
    	font-size: 16px;
		line-height: 26px;
	}
	
	
}

@media(max-width: 1000px){
	
	.sub-main-area {
        padding: 0 10px;
        margin: 50px auto 0;
    }
	
	.sub_fv {
    	height: 350px;
	}

	
	.sub_fv_title {
		padding: 20px;
	}
	
	.sub-main-area h3 {
    	font-size: 30px;
    	letter-spacing: 2px;
	}
	
	.sub-title {
		padding: 20px 10px 0;
	}
	
	
	 .sub-title  .fa-solid, .fas {
        font-weight: 900;
        font-size: 13px;
    }

	.sub-title span {
		letter-spacing: 0;
	}
	
	.sub-box-text {
    	padding: 10px;
	}

	
	.sub-box-item .button2 {
		justify-content: center;
	}
	
	.sub-box-item table {
	 	max-width:100%; 
	}
	
	.sub-box-item table th, .sub-box-item table td {
    	font-size: 15px;
		line-height: 22px;
	}
}



@media(max-width: 800px){
    .main-area h3, .main-area h3 span {
        font-weight: 400;
        font-size: 23px;
        letter-spacing: 1px;
        padding-left: 0;
	}
}


@media(max-width: 650px){
	
	body {
		background: #fff;
	}
	
	.sub_fv {
        height: 200px;
        background-size: contain;
    }
	
	.sub-main-area h3{
		font-size: 24px;
		padding-left: 35px;
	}
	
	.sub-main-area h3::before {
		width: 30px;
	}
	
	.sub-box-text p {
        font-size: 16px;
    }

}






@media(max-width: 450px){
	
	.sub_fv_title h2 p {
		font-size: 20px;
	}
	
	.sub-box-item-content p, .sub-box-item-content ul {
        font-size: 16px;
        line-height: 28px;
		letter-spacing: 0;
    }
	
	.sub-box-item-content ul li::before {
		position: absolute;
		display: block;
		content: '';
		background: url(../img/check-icon.png) center no-repeat;
		background-size: 100% 100%;
		width: 16px;
		aspect-ratio: 1 / 1;
		left: 0px;
	}
	
	.sub-box-item-content ul li {
		padding-left: 25px;
		position: relative;
		font-size: 16px;
		font-weight: 500;
		line-height: 30px;
		letter-spacing: 0;
	}


    .sub-main-area h3::before {
        width: 20px;
	}
	
	.sub-main-area h3 {
		font-size: 21px;
        padding-left: 25px;
        letter-spacing: 1px;
    }

	.sub-box-item {
        padding: 0;
    }
	
	.sub-box-item h4 {
		margin-top: 5px;
        font-size: 18px;
        letter-spacing: 0px;
        line-height: 34px;
		padding: 0 20px 0 10px;
    }
	
	.sub-box-item-img img{
		width: 100%;
	}
	
	.sub-box-item h5 {
		font-size: 18px;
		padding-left: 0;
	}
}