@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');


html,body{
	margin: 0;
	padding: 0;
	font-family: "Noto Sans JP", sans-serif;
}
a{
	transition: 0.4s;
	text-decoration: none;
	color: unset;
}
a:hover{
	opacity: 0.7;
}
p{
	margin: 0;
}
.sp{
	display: none;
}
.text-center{
	text-align: center;
}
.text-right{
	text-align: right;
}
img{
	max-width: 100%;
	vertical-align:top;
}

/* header */
#header{
	position: fixed;
	width: 100%;
	text-align: right;
	box-sizing: border-box;
	z-index: 10;
	background-color: #fff;
}
#header #logo_area{
	width: 300px;
	position: absolute;
	left: 20px;
	top: 20px;
}
#header .head_box{
	padding: 10px 20px;
	height: 100px;
	box-sizing: border-box;
	display: inline-block;
	vertical-align: top;
	align-content: center;
}
#header #head_tel{
	color: #F05A24;
	font-weight: bold;
	text-align: left;
}
#header #head_tel img{
	width: 30px;
	vertical-align: middle;
	margin-right: 5px;
	margin-top: -5px;
}
#header #head_tel p#telno{
	font-size: 2.5em;
	line-height: 1em;
	margin-bottom: 3px;
}
#header #head_tel p.hours{
	color: #000;
	font-size: 0.8em;
}
#header #head_mail{
	background-color: #F05A24;
	color: #fff;
	font-weight: bold;
}
#header #head_mail img{
	display: block;
	margin: 0 auto 5px;
	width: 35px;
}
#pc_menu{
	background-color: #0092D5;	
	text-align: center;
	width: 100%;
	padding: 5px 0;
	box-shadow: 0px 5px 5px 0px rgba(0,0,0,0.3);
}
#pc_menu .menu_box{
	color: #fff;
	display: inline-block;
	vertical-align: middle;
	padding: 0 15px;
}

/* spmenu */
#g-nav{
	position:fixed;
	z-index: -1;
	opacity: 0;
	top: 0;
	width: 100%;
	height: 100vh;
	background: rgba(0, 146, 213,0.95);
	transition: all 0.3s;
}
#g-nav.panelactive{
	opacity: 1;
	z-index: 999;
}
#g-nav.panelactive #g-nav-list{
	position: fixed;
	z-index: 999; 
	width: 100%;
	height: 100vh;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
#g-nav ul {
	display: none;
	position: absolute;
	z-index: 999;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
#g-nav.panelactive ul {
	display: block;
	padding: 0;
}
#g-nav li{
	list-style: none;
	text-align: center; 
}
#g-nav li a{
	color: #fff;
	text-decoration: none;
	padding: 10px;
	display: block;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: bold;
}

/* button */
.openbtn1{
	position: fixed;
	z-index: 9999;
	top: 0px;
	right: 0px;
	cursor: pointer;
	width: 65px;
	height: 65px;
	background: #F05A24;
}
.openbtn1 span{
	display: inline-block;
	transition: all .4s;
	position: absolute;
	left: 17px;
	height: 2px;
	border-radius: 2px;
	background-color: #fff;
	width: 50%;
}
.openbtn1 span:nth-of-type(1) {
	top: 22px; 
}
.openbtn1 span:nth-of-type(2) {
	top: 32px;
}
.openbtn1 span:nth-of-type(3) {
	top: 42px;
}
.openbtn1 p{
	position: fixed;
	color: #fff;
	margin: 0;
	padding: 0;
	top: 43px;
	right: 23.5px;
	font-size: 10px;
}
.openbtn1.active span{
	height: 2px;
}
.openbtn1.active span:nth-of-type(1) {
	top: 25px;
	left: 17px;
	transform: translateY(6px) rotate(-45deg);
	width: 50%;
}
.openbtn1.active span:nth-of-type(2) {
	opacity: 0;
}
.openbtn1.active span:nth-of-type(3){
	top: 37px;
	left: 17px;
	transform: translateY(-6px) rotate(45deg);
	width: 50%;
}
#spmenu{
	display: none;
}

#head_contents{
	margin: auto;
	padding-top: 135px;
}
.contents{
	width: 1100px;
	max-width: 100%;
	padding: 5px;
	box-sizing: border-box;
	margin: auto;
}
ul.breadcrumbs {
    font-size: 0.9em;
    list-style: none;
    padding: 0;
}
ul.breadcrumbs li {
    display: inline-block;
}
ul.breadcrumbs li a{
	color: #0092D5;
}
ul.breadcrumbs li:after {
    content: " ＞ ";
    font-size: 0.85em;
}
ul.breadcrumbs li:last-child::after {
    content: "";
}

/* footer */
#footer_menu{
	background-color: #ddd;
	text-align: center;
	padding: 30px 10px;
	font-size: 0.9em;
	box-sizing: border-box;
}
#copyright{
	padding: 20px 10px;
	font-size: 0.9em;
	box-sizing: border-box;
	position: relative;
	background-color: #fff;
}
#copyright p{
	text-align: right;
}
#footer_logo {
    width: 250px;
    position: absolute;
    left: 10px;
    top: 10px;
}
#foot_tel{
	display: none;
}

@media (max-width: 867px) {
	#header #head_tel p#telno{
		font-size: 2em;
	}
	#header .head_box{
		padding: 10px;
	}
}

@media (max-width: 767px) {
	.pc{
		display: none;
	}
	.sp{
		display: block;
	}
	#spmenu{
		display: unset;
	}
	#header{
		height: 65px;
	}
	#header #logo_area{
		top: 10px;
		left: 10px;
		width: 200px;
	}
	#head_contents{
		margin: auto;
		padding-top: 65px;
	}
	.contents{
		padding: 10px;
	}
	#copyright{
		margin: auto;
		text-align: center;
        padding-bottom: 100px;
	}
	#footer_logo {
	    width: 250px;
	    position: static;
	    margin: 0 auto 10px;
	}
	#copyright p{
		text-align: center;
	}
    #foot_tel{
        display: block;
        width: 84%;
        color: #ffffff;
        background: rgba(241,90,36,0.9);
        font-weight: bold;
        text-align: center;
        position: fixed;
        bottom: 0;
        left: 8%;
        z-index: 10;
        font-size: 0.8em;
        padding: 10px 0 10px 0;
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
    }
    #foot_tel a {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        text-indent:-999px;
    }

    #foot_tel img{
        width: 25px;
        vertical-align: middle;
        margin-right: 5px;
        margin-top: -5px;
    }
    #foot_tel p#telno{
        font-size: 2.2em;
        line-height: 1em;
        margin-bottom: 3px;
    }
    #foot_tel p.hours{
        font-size: 0.8em;
        line-height: 0.8em;
    }
}