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

/* == header == */
header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 60px;
	z-index: 10000;
	letter-spacing: 0.1em;transition: 400ms 0s ease;
    background-color: #000;
}
header.bg_fix{background-color: rgb(0 0 0);}

#header_logo {
    display: block;
    position: absolute;
	top: 10px;
    left: 15px;
    height: 40px;
    margin: 0;
    z-index: 500;
}
#header_logo img {
    display: block;
    height: 100%;
}
#header_nav {
float: right;
font-size: 0;
}
#header_nav a {
    text-decoration: none;
}
.header_nav_wrap {
    display: inline-block;
}
.header_nav_wrap a:after{
/*content: "";*/
position: absolute;
right: 0px;
top: 0px;
bottom: 0px;
width: 1px;
height: 1.4em;
margin: auto;
background-color: #FFFFFF;
}
.header_nav_wrap a:after:hover {
opacity: 1!important;
}
li.header_nav_wrap:last-child a:after{
display: none;
}
.header_nav_wrap-hasChild .header_nav_children {
    display: block;
    position: absolute;
    top: 60px;
    left: 100%;
    background: rgba(0,0,0,0.5);
    font-size: 1rem;
    width: 100%;
    opacity: 0;
    transition: opacity 300ms 0s ease, left 300ms 0s ease;
}
.header_nav_children-main,
.header_nav_children-sup {
    text-align: center;
}
.header_nav_children-sup {
    border-top: 1px solid rgba(124,124,124,0.7);
}
.header_nav_l1,
#header_nav a#facebook {
    display: inline-block;
    padding: 0 1em;
    font-size: 0.9rem;
    line-height: 60px;
    position: relative;
    color: #fff;
}
.header_nav_l1:before {
 /*   content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 2px;
    background: #ffffff;
    bottom: 18px;
    left: 0;
    right: 0;
    margin: auto;
    transition: width 300ms 0s ease;
*/
}
.header_nav_l1:hover:before {
    width: 80%;
}
.header_nav_wrap-hasChild-on .header_nav_children {
    left: 0;
    opacity: 1;
}
#header_nav a#facebook {
    display: inline-block;
    width: auto;
    height: 1.3em;
    position: relative;
    bottom: -0.3em;
}
#header_nav a#facebook img {
    display: block;
    width: 1.3em;
}
.header_nav_l2 {
    display: inline-block;
    padding: 0.8em 1.2em 1em 1.2em;
    margin: 0.5em;
    line-height: 1.2;
    font-size: 90%;
    position: relative;
    transition: background 300ms 0s ease;
}
.header_nav_l2:before {
    /*content: "";*/
    display: block;
    background: transparent;
    position: absolute;
    border-top: 1px solid #999999;
    border-left: 1px solid #999999;
    width: 5px;
    height: 5px;
    top: 0;
    left: 0;
    transition: width 300ms 0s ease, height 300ms 0s ease;
}
.header_nav_l2:after {
    /*content: "";*/
    display: block;
    background: transparent;
    position: absolute;
    border-bottom: 1px solid #999999;
    border-right: 1px solid #999999;
    width: 5px;
    height: 5px;
    bottom: 0;
    right: 0;
    transition: width 300ms 0s ease, height 300ms 0s ease;
}
.header_nav_l2:hover {  }
.header_nav_l2:hover:before, .header_nav_l2:hover:after { width: 100%; height: 100%; }


/**footer**/
footer{
	background-color: #000000;
	padding: 40px 0px 20px 0px!important;
	color: #FFFFFF;
}
footer .footer-inner{
margin-left: auto;
margin-right: auto;
text-align: center;
}
footer .footer-inner .footer_logo{
width: 170px;
margin-left: auto;
margin-right: auto;
}
footer .footer-inner .footer_logo img{
width: 100%;
height: auto;
}
footer .footer-inner .foot_smap{
text-align: center;
padding-top: 36px;
margin-left: auto;
margin-right: auto;
gap:2em;
display: flex; justify-content: center;
}
footer .footer-inner .foot_smap+.foot_smap{padding-top: 0;}
footer .footer-inner .foot_smap li{
margin-bottom: 10px; font-size: 0.8em;
}

footer .footer-inner .foot_smap li a{

	padding-top: 0.1em;
	padding-bottom: 0.1em;
	display: block;
	color: #FFFFFF;
} 
footer .footer-inner .foot_smap li a img{
width: 2em;
height: auto;
}
footer .footer-inner .foot_shop{font-size: 0.8em; padding: 1em 0  2em 0;}
footer .footer-inner .foot_shop li{display: flex; padding-bottom: 0.5em;}
footer .footer-inner .foot_shop li .foot_name{width: 6em; text-align: left; border-right: 1px solid #fff; }
footer .footer-inner .foot_shop li .foot_add{padding-left: 1.5em;}
footer .footer-inner .foot_shop li .foot_add a.togmap{ background-color: #393939; display: inline-block; padding: 0.2em 0.5em 0.2em 1em; color: #FFFFFF; letter-spacing: 0.5em;	font-size: 0.7em; margin-left: 1em;}

footer .footer-inner .company_name{text-align: center; display: block; border-top: 1px solid #565656; font-size: 0.8rem; margin-top: 2em; padding-top: 2em;}
footer .footer-inner .foot_office{
	/*border-top: 1px solid #565656;*/
    margin-top: 2em;
	/* [disabled]margin-bottom: 20px; */
}
footer .footer-inner .foot_office li{
display: inline-block;
font-size: 0.8rem;
text-align: left;
}
footer .footer-inner .foot_office li a.togmap{
	background-color: #393939;
	display: inline-block;
	padding: 0.2em 1em;
	color: #FFFFFF;
	letter-spacing: 0.2em;
	font-size: 0.75rem;
	margin-left: 1em;
}
footer .footer-inner .foot_office li strong{
	display: block;
	text-align: center;
	font-weight: normal;
}
footer .footer-inner a.foot_mail{
	font-size: 0.9rem;
	margin-bottom:2em;
	display: inline-block;
}
footer .footer-inner a.foot_mail img{
	margin-right: 1em;
}

footer .footer-inner .foot_copy{
	font-size: 0.75em;
	color: #848484;
}

@media screen and (max-width: 767px) {
    header{background-color: #000!important;}
    #header_btn_sp {
        display: block;
        width: 60px;
        height: 60px;
        position: absolute;
        top: 0;
        right: 0;
        z-index: 1000;
    }
    #header_btn_sp span {
        pointer-events: none;
        display: block;
        width: 24px;
        height: 2px;
        background: #fff;
        position: absolute;
        top: 0;
        bottom: 0;
        right: 18px;
        margin: auto;
        transition: transform 300ms 0s ease, width 300ms 0s ease, top 300ms 0s ease, bottom 300ms 0s ease, right 300ms 0s ease;
    }
    #header_btn_sp span:first-child { top: 16px; }
    #header_btn_sp span:last-child { bottom: 16px; }
    .header_nav-on #header_btn_sp span {
        right: 12px;
        width: 18px;
    }
    .header_nav-on #header_btn_sp span:first-child {
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        width: 12px;
        top: 7px;
        right: 9px;
    }
    .header_nav-on #header_btn_sp span:last-child {
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        width: 12px;
        bottom: 7px;
        right: 9px;
    }
    #header_logo {
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
    }
    #header_logo img {
	width: 40vw;
	position: absolute;
	height: auto;
	top: 0;
	bottom: 0;
	left: 10px;
	right: auto;
	margin: auto;
    }
    #header_nav {
        width: 300px;
        height: 100vh;
        position: absolute;;
        float: none;
        top: 60px;
        right: -100vw;
        background: rgb(51 51 51);
        overflow: scroll;
        transition: right 300ms 0s ease;
    }
    .header_nav-on #header_nav {
        right: 0;
    }
    #header_nav ul {
        display: block;
        width: 300px;
        position: absolute;
        top: 0px;
        right: 0;
        padding: 15px 15px 30px 15px;
    }
    .header_nav_wrap-hasChild .header_nav_children {
        background: transparent;
        position: static;
        padding-left: 1em;
        top: auto;
        left: auto;
        text-align: left;
        opacity: 1;
        max-height: 0;
        overflow: hidden;
        transition: max-height 500ms 0s ease;
    }
    .header_nav_wrap-hasChild-on .header_nav_children {
        display: block;
        max-height: 100vh;
    }
	li.header_nav_wrap:last-child a:after{
	display: inline-block;
		}
    #header_nav ul li { display: block;}
	
    #header_nav ul li a.header_nav_l1 { line-height: 40px; width: 100%; }
    
	.header_nav_l1:before {
    /*  bottom: 8px;
        right: auto;
        left: 1em;
	*/
    }
    .header_nav_l1:hover:before { width: calc( 100% - 2em ); }
    
    .header_nav_l2{padding: 0; }
    .header_nav_l2:before{content: "ー"; position: static; border-style: none; display: inline-block; width: auto; height: auto;}
    .header_nav_children-main { padding-top: 0; }
    .header_nav_children-main,
    .header_nav_children-sup { text-align: left; }

    /**footer**/
    footer{
    }
    footer .footer-inner{
    }
    footer .footer-inner .footer_logo{
    width: 45%;
    }
    footer .footer-inner .footer_logo img{
    width: 100%;
    height: auto;
    }
    footer .footer-inner .foot_smap{ flex-wrap: wrap; gap: 0 1.3em; }
    footer .footer-inner .foot_smap li{
    width: auto;
    }
    footer .footer-inner .foot_smap li:nth-child(2n){border-right-style: none;}
    footer .footer-inner .foot_smap li:nth-child(4),
    footer .footer-inner .foot_smap li:last-child{
    }
    footer .footer-inner .foot_smap li a{
    } 
    footer .footer-inner .foot_smap li a img{
    }
    footer .footer-inner .foot_office{
    margin-top: 0;
    padding: 30px;
    }
    footer .footer-inner .foot_office li{
	max-width: initial;
	width: 100%;
	padding-left: 0px;
	padding-right: 0px;
    }
    footer .footer-inner .foot_office li:first-child{
    margin-bottom: 30px;
    }
    footer .footer-inner .foot_shop{}
    footer .footer-inner .foot_shop li{flex-direction: column; padding-bottom: 1.5em;}
    footer .footer-inner .foot_shop li .foot_name:before{content: ""; display: inline-block; width:1em; height:1px; background-color: #fff; vertical-align: middle; margin-right: 0.5em;}
    footer .footer-inner .foot_shop li .foot_name{width: auto; border-right-style: none;}
    footer .footer-inner .foot_shop li .foot_add{padding-left: 0; text-align: left;}
    footer .footer-inner .foot_shop li .foot_add a.togmap{ }
}