@charset "utf-8";

div#hbg{
	display: none;
}

html {
	font-weight: 400;
	height: 100%;
	text-align: justify;
	font-family: "Reddit Sans", "Noto Sans JP", serif;
	font-style: normal;
	overflow-x: hidden;
}

h1,h2,h3,h4, h5,menu{
	font-feature-settings: "palt";
	margin: 0;
}
ul{
	list-style: none;
	padding: 0;
	margin: 0;
}
*{
	position: relative;
}
body {
	background-color: #dfe2e5;
	background-image: url(../img/bg.png);
	padding:0;
	margin:0;
	overflow-x: hidden;
}
p{
	margin: 1em 0 2em;
}

div.small_logo{
	display: none;
}
div.small_logo>span{
	display: none;
}

header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	box-sizing: border-box;
	height: 80px;
	padding: 0 2em;
	background-color: #fff;
	background-repeat: repeat;
	background-size: 600px;
	overflow:hidden;
	z-index: 100;
}
header>div{
	height: 100%;
	box-sizing: border-box;
	display:flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
}

header>div>div.mark{
	height: 50px;
	width: 50px;
	background-image: url(../img/mark.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}
header>div>*#logo>a{
	display: block;
	width: 180px;
	height: 80px;
	/* background-color: #fff; */
	background-image: url(../img/logo_b.svg);
	background-size: 80%;
	background-position: center center;
	background-repeat: no-repeat;
	/* filter: drop-shadow(0 0 0.2rem #00000099); */
	transition: all .2s;
}
header>div>h1#logo>a{
	opacity: 0;
	/* opacity: 1; */
}
header>div>h1#logo.is_visible>a{
	opacity: 1;
}
header>div>*#logo>a>span{
	display: none;
}

header>div>menu{
	flex-grow: 1;
	display:flex;
	align-items: center;
	justify-content: flex-end;
	flex-flow: row nowrap;
	gap: 20px;
}
header>div>menu>a{
	/* background-color: #fd0; */
	color: #000;
	text-decoration: none;
	font-size: .92em;
	font-weight: 500;
	display: block;
	line-height: 100%;
	transition: all .23s ease;
}

header>div>menu>a:hover{
	font-weight: 500;
	opacity: .5;
}
header>div>menu>div.header_contact{
	font-family: 'Reddit Sans';
	/* background-color: #fd0; */
	font-size: 1.65em;
	font-weight: 700;
	line-height: 100%;
	padding: 5px 20px;
	border-radius: 24px;

}





div#mv{
	margin-top: 80px;
	width: 100%;
	position: relative;
	padding-top: 100px;
	background-color: #555555;
	z-index: -1;
	padding-top: 10vh;
	background-image:url(../img/mvbg.jpg);
	background-size: cover;
	background-position: center;
	background-color: #222;
	background-attachment: fixed;
}

div#mv>div.border{
	position: absolute;
	height: 100%;
	box-sizing: border-box;
	top: 0;
	left: calc((100% - 960px) / 2 );
	width: 100%;
	max-width: 960px;
	border-left: solid 1px #ffffff44;
}

div#mv>div.mvl{
	top: 0;
	left: 0;
	width: 100%;
	max-width: 960px;
	margin: auto;
	height: 50vh;
	box-sizing: border-box;
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
}
div#mv>div.mvl>div{
	font-size: 1.25em;
	display: flex;
	flex-flow: column nowrap;
	align-items: flex-start;
	color: #fff;
	text-shadow: 0 0 3px #000000;
}

div#mv>div.mvl>div>div.big_logo{
	height: 140px;
	width: 100%;
	background-image: url(../img/logo.svg);
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
	position: absolute;
	top: -160px;
	filter: drop-shadow(0 0 0.2rem #00000099);
}
div#mv>div.mvl>div>div.sub1{
	font-size: 1.4em;
	font-weight: 500;
}
div#mv>div.mvl>div>div.sub2{
	font-family: serif;
	font-size: 2.2em;
	font-weight: 900;
}
div#mv>div.mvl>div>div.sub3{
	font-size: 1.12em;
	font-weight: 400;
}

div#mv>div.mvb{
	box-shadow: inset 0 1px 0 #ffffff44;
	color: #000;
	padding-bottom: 30px;
}
div#mv>div.mvb:nth-last-child(3){
	background: linear-gradient(to bottom, #dfe2e500, #dfe2e555);
}
div#mv>div.mvb:nth-last-child(2){
	background: linear-gradient(to bottom, #dfe2e555, #dfe2e5aa);
}
div#mv>div.mvb:last-child{
	background: linear-gradient(to bottom, #dfe2e500, #dfe2e5ff);
}


div#mv>div.mvb div.mvb_bg{
	position: absolute;
	display: block;
	width: 200%;
	height: 150%;
	background-color: #fd0;
	font-size: 5em;
	top: -45%;
	left: -142%;
	border-radius: 2px;
}

div#mv>div.mvb>div.norm{
	max-width: 960px;
	margin: auto;
	font-size: 1.12em;
}
div#mv>div.mvb>div>h3{
	position: relative;
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	top: -2em;
	font-size: 1.4em;
	opacity: .8;
}
div#mv>div.mvb>div>h3>span.sub{
	font-weight: 300;
	margin-right: 10px;
}

div#mv>div.mvb>div>p{
	position: relative;
	top: -2em;
	max-width: 50%;
	font-weight: 500;
}

main{
	padding: 100px 0 0;
}

main>div.border{
	position: absolute;
	height: 100%;
	box-sizing: border-box;
	top: 0;
	left: calc( (100% - 960px) / 2 );
	width: 100%;
	max-width: 960px;
	border-left: solid 1px #ffffff99;
}

main>section{
	box-shadow: inset 0 1px 0 #ffffff99;
}

main>section>div{
	max-width: 960px;
	margin: auto;
	display: flex;
	flex-flow: row nowrap;
	gap: 5%;
	padding: 0 0 160px 0;
}
main>section>div>div.left{
	width: 53%;
}
main>section>div>div.left>div.image{
	display: flex;
	aspect-ratio: 4/3;
	width: 100%;
}

main>section>div>div>div.image>div{
	display: block;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
main>section>div>div>div.image>div.cut2{
	background-image: url(../img/cut1.png?2);
}

main>section>div>div>div.image>div.cut1{
	background-image: url(../img/cut2.png?2);
}


main>section>div>div.left>h3{
	margin-bottom: 60px;
}
main>section>div>div.left>h3>span{
	display: block;
	font-size:1.3em;

}
main>section>div>div.left>h3>span:first-child{
	font-size: 1.6em;
	/* color: #00000099; */
}


main>section>div>div.right{
	width: 37%;
}

main>section>div>div.right>div.image{
	display: flex;
	aspect-ratio: 3/4;
	width: 100%;
}

main>section>div>div>div.image{
	display: block;
	width: 100%;
	background-color: #fd0;
	overflow: hidden;
}
main>section>div>div>p{
	font-size: .92em;
	line-height: 180%;
}
main>section>div>div.right>p:first-child{
	margin-top: 160px;
}

section.contact{
	background-color: #222;
	color: #fff;
	box-shadow: none;
}
section.contact>div{
	padding: 20px 0;
	display: block;
}

section.contact>div.border{
	position: absolute;
	height: 100%;
	box-sizing: border-box;
	top: 0;
	left: calc((100% - 960px) / 2 );
	width: 100%;
	max-width: 960px;
	border-left: solid 1px #fd0;
}
section.contact>div>h3{
	font-family: serif;
	font-style: italic;
	font-weight: 200;
	color: #fd0;
	font-size: 1.6em;
}
section.contact>div>div.tel{
	text-align: center;
	padding-bottom: 30px;
}

section.contact>div>div.tel>p{
	font-size: 4em;
	margin: 0;
	line-height: 1em;
	font-family: serif;
	font-weight: 600;
	font-family: 'Reddit Sans';
	text-shadow: 0 0 10px #000000cc;
}

section.contact>div>div.tel>p>small{
	font-size: .86em;
	margin-right: 20px;
}
section.contact>div>div.tel>div{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1em;
	line-height: 100%;
	margin-top: 10px;
}
section.contact>div>div.tel>div span{
	border-radius: 4px;
	background-color: #fd0;
	color: #000;
	font-weight: 600;
	font-size: .8em;
	padding: 1px 4px 2px 4px;
	top: 1px;
}

footer{
	background-color: #fd0;
	background-image: url(../img/fbg.png);
	background-position: center center;
	background-size: cover;
	font-size: .92em;
	font-weight: 300;
	line-height: 180%;
}
footer>div.border{
	position: absolute;
	height: 100%;
	box-sizing: border-box;
	top: 0;
	left: calc((100% - 960px) / 2 );
	width: 100%;
	max-width: 960px;
	border-left: solid 1px #222;
}
footer>menu{
	display: flex;
	flex-flow: row;
	justify-content: space-between;
	align-items: center;
	max-width: 960px;
	margin: auto;
	padding: 100px 0;
	box-sizing: border-box;
}
footer>menu>ul>li>a{
	font-weight: 400;
	text-decoration: none;
	color: #fff;
	display: block;
	border-left: solid 0px#fd0;	
	transition: border .3s ease;
	padding-left: 8px;
}

footer>menu>ul>li>a:hover{
	border-left: solid 8px #fd0;	
}
footer>menu>div{

	filter: drop-shadow(0 0 0.2rem #00000099);
}
footer>menu>div>a{
	display: block;
	height: 80px;
	/* background-color: #fd0; */
	background-image: url(../img/logo.svg);
	background-position: right center;
	background-repeat: no-repeat;
	background-size: contain;
}
footer>menu>div>p{
	text-align: right;
	font-weight: 400;
	color:#fff;
}
footer>menu>div>a>span{
	display: none;
}






address{
	background-color: #fd0;
	color: #000;
	padding: 20px 0;
	font-style: normal;
	font-size: .86em;
	text-align: center;
}

br.sp{
	display: none;
}







/* 第2階層 */

#second>h1{
	height: 200px;
	background-color: #555;
	padding-top: 80px;
	background-image: url(../img/mvbg.jpg);
	background-position: left bottom;
	background-size: 200%;
}
#second>h1>div{
	margin-top: 80px;
	display: flex;
	flex-flow: row;
	align-items: center;
	justify-content: center;
	font-size: 1.14em;
	font-weight: 400;
	color: #fd0;
}





#second main>section.single>div{
	max-width: 600px;
}
#second main>section.single>div>div>p{
	line-height: 180%;
}
#second main>section.single>div>div>p:first-child{
	margin-top: 160px;
}

#second main>section.single>div>div>h3 {
	font-size: 1.6em;
	color: #00000099;
	padding-bottom: .5em;
}

#second main>section.single>div>div>h4 {
	display: block;
	font-size: 1.2em;
}

#second main>section.single>div>div>h4 {
	display: block;
	font-size: 1.2em;
}
#second main>section.single>div>div>h5 {
	display: block;
	font-size: 1.2em;
	font-weight: 300;
}
#second main>section.single>div>div>ul{
	font-size: .86em;
	margin: 1em 0;
}
#second main>section.single>div>div>ul.number>li{
	text-indent: -3em;
	padding-left: 3em;
}


















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

	header{
		font-size: .86em;
	}
	header>div>menu{
		gap: 12px;
	}
	
}




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

	header div.header_contact{
		display: none;
	}
	
}





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


	div#mv>div.mvb div.mvb_bg{
		width: 120%;
		left: -10%;
		background-color: #ffdd0000;
	}

	div#mv>div.mvl>div>div.big_logo{
		display: none;
	}
	header>div>*#logo>a{
		opacity: 1;
	}
	div.small_logo{
		display: block;
		position: absolute;
		top: 12px;
		left: 12px;
		width: 120px;
		height: 45px;
		/* background-color: #ffffff99; */
		background-image: url(../img/logo.svg);
		background-size: contain;
		background-repeat: no-repeat;
		background-position: center center;
		filter: drop-shadow(0 0 0.2rem #00000099);
	}

	div#hbg{
		z-index: 99999;
		position: fixed;
		display: flex;
		justify-content: center;
		align-items: center;
		top: 12px;
		right: 12px;
		background-color: #ffffff99;
		width: 50px;
		height: 30px;
		box-shadow: 0 0 10px -5px #00000099;
	}
	div#hbg>div{
		display: flex;
		height: fit-content;
		justify-content: center;
		align-items: center;
		flex-flow: column nowrap;
		gap: 5px;
	}
	div#hbg>div>span{
		background-color: #000;
		width: 40px;
		height: 1px;
		display: block;
		transition: all .4s ease;
		bottom: 0;
		transition: all .4s ease;
	}
	div#hbg.open>div>span:first-child{
		position: relative;
		bottom: -6px;
		transition: all .4s ease;
	}
	div#hbg.open>div>span:last-child{
		position: relative;
		bottom: 6px;
		transition: all .4s ease;
	}


	br.sp{
		display: block;
	}


	
	div#mv{
		background-position: 65% center;
	}

	div#mv>div.mvl{
		width: 100%;
		box-sizing: border-box;
		padding: 1em;
	}
	div#mv>div.mvl>div{
		font-size: .8em;
	}
	div#mv>div.mvb{
		padding-right: 1em;
		padding-left: 1em;
		padding-bottom: 40px;
		position: relative;
	}
	div#mv>div.mvb>div>p{
		max-width: 100%;
	}

	section.contact>div>div.tel>p{
		font-size: 2em;
		margin-top: 1em;
	}
	
	main>section{
		padding-left: 1em;
		padding-right: 1em;
	}
	main>section>div{
		flex-flow: column nowrap;
		padding-bottom: 80px;
	}
	main>section>div>div.left,
	main>section>div>div.right{
		width: 100%;
	}
	main>section>div>div.left>h3>span:first-child{
		font-size: 1.3em;
	}
	main>section>div>div.left>h3>span{
		font-size: 1em;
	}
	main>section>div>div.right>p:first-child{
		margin-top: 2em;
	}

	footer>menu{
		flex-flow: column-reverse nowrap;
		gap: 2em;
		padding: 30px 0 0 0;
	}

	footer>menu>ul{
		margin-bottom: 30px;
	}

	footer>menu>ul>li>a{
		padding: 1em 0 ;
		text-align: center;
		font-weight: 500;
	}


	header{
		opacity: 0;
		z-index: -9999;
		background-color: #fd0;
		width: 100%;
		height: 100vh;
	}
	header>div{
		flex-flow: column nowrap;
		justify-content: center;
		gap: 20px;
	}
	header>div>menu{
		flex-flow: column nowrap;
		align-items: center;
		padding: 0;
	}
	header>div>menu>a{
		font-size: 1.4em;
		margin: 0;
		padding: 1em 0;
	}
	header.open{
		z-index: 9999;
		opacity: 1;
	}

	main{
		padding-top:40px;
	}

}








@media print{

	header{
		background-color: #ffffff44;
		opacity: .6;
	}
	div#mv{
		background-size: cover;
		background-position: center;
		background-color: #222;
		background-attachment:inherit;
	}

}