@charset "UTF-8";

/*@import "reset.css";*/
@import "util.css";
@import url('https://fonts.googleapis.com/earlyaccess/sawarabimincho.css');

/* 1 ---------------------------------------*/ 
html {
  font-size: 62.5%;
}


body {
	/*background: url(../img/common/back.jpg) top center fixed;
	background-size:cover;*/
	text-align:center;
	margin:0 auto;
	font-size: 13px;
	font-size: 1.3rem;
	line-height:1.6;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	min-width:1100px;
	height: 100%;
	background-color:#000;
	color:#fff;
	
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
	border:none;
}


.clear{
clear:both;
}

a{
outline:0;
}

.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
	font-size: 0;
	line-height: 0;
}

.sp{
	display:none;
}

span{
	display:none;
}

p{
font-size: 14px;
font-size: 1.4rem;
margin:0 0 20px 0;
color: #fff;
text-align: justify;
text-justify: inter-ideograph;
}

p.read{
font-size:16px;
font-size:1.6rem;
margin:0 0 80px 0;
text-align: center;
font-weight:normal;
}

.p_cap{
font-size: 10px;
font-size: 1.0rem;
padding:0;
margin:0 0 20px 0;
text-align:left;
}


.p_cap_r{
font-size: 10px;
font-size: 1.0rem;
padding:0;
margin:0 0 20px 0;
text-align: right;
}

a:link {
color: #bc0d38;
text-decoration: underline;
}

a:visited {
color: #bc0d38;
text-decoration: underline;
}

a:hover {
color: #bc0d38;
text-decoration: none;
}

a:active {
color: #bc0d38;
text-decoration: none;
}

/* header---------------------------------------*/

header{
	position:relative;
	width:100%;
	height:auto;
	margin:0 auto;
	text-align:center;
	overflow:hidden;
	z-index:100;
	position: fixed;
	background-color:rgba(0,0,0,0.8);
	/*background-color:#000;*/
    border-bottom:1px solid rgba(112,112,112,0.6);
}


header #header_l{
	float:left;
	width:240px;
	height:auto;
	margin:0 0 0 20px;
}

#header_l ul{
	float:left;
	padding:0;
	margin:0 0 0 0;
	overflow:hidden;
}

#header_l ul li a{
outline:0;
}


#header_l ul li{
	float:left;
	margin:0 0 0 0;
}

#header_l ul li.li01{width:240px; height:32px; margin:10px 0 0 0;}
#header_l ul li.li02{width:240px; height:40px; margin:16px 0 10px 0;}


#header_l h1{
	margin:0;
	padding:0;
}

#header_r{
	float:right;
	width:470px;
	height:auto;
	text-align: right;
	margin:0;
	overflow:hidden;
	display: flex;
	justify-content: flex-end;
}
#header_r .header_r_phone{
	width: 210px;
	margin-right: 30px;
}
#header_r .header_r_logo{
	width: 68px;
	margin: 10px 20px 0 0;
}

/* nav---------------------------------------*/


.nav02 {
    display:none;
}

header nav,
.nav02{
	clear:both;
	width:100%;
	min-width:1200px;
	height:50px;
	margin:0 auto;
	padding:0;
	text-align:center;
	font-size:12px;
	font-size:1.2rem;
	line-height:50px;
	font-weight:normal;
	background-color:rgba(63,63,63,0.7);
	border-top:1px solid rgba(112,112,112,0.6);
}

/*header nav{
 box-shadow: 0px 4px 2px -2px rgba(0,0,0,1);
  -webkit-box-shadow: 0px 4px 2px -2px rgba(0,0,0,1);
  -moz-box-shadow: 0px 4px 2px -2px rgba(0,0,0,1);
}*/

header nav ul,
.nav02 ul{
	overflow:hidden;
	padding:0;
	margin:0 auto;
	text-align:center;
}


header nav ul li,
.nav02 ul li {
	display:inline;
	position: relative;
}


header nav ul li .li_new,
.nav02 ul li .li_new {
	position:absolute;
	width:30px;
	height:12px;
	background-color:#e6b422;
	top:-15px;
	left:1px;
	text-align:center;
	font-size:8px;
	font-size:0.8rem;
	line-height:12px;
	color:rgba(40,26,20,1);
	z-index:999;
}


header nav ul li a,
.nav02 ul li a{
	display: inline-block;
	outline:0;
	width: 110px;
	margin:0;
	text-decoration: none;
	-webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    transition: all  0.8s ease;
}

header nav ul li a:hover,
.nav02 ul li a:hover{
	background-color:#aa130e;
}



header nav ul li a:link,
.nav02 ul li a:link{
	text-decoration:none;
}

header nav ul li a span.nav_en,
.nav02 ul li a span.nav_en{
	color:#f8f4e6;
    display: inline;
}
header nav ul li a:hover span.nav_en,
.nav02 ul li a:hover span.nav_en{
    display: none;
}
header nav ul li a span.nav_jp,
.nav02 ul li a span.nav_jp{
	display: none;
}
header nav ul li a:hover span.nav_jp,
.nav02 ul li a:hover span.nav_jp{
	color:#fff;
    display: inline;
}


header nav ul li.current a span.nav_en,
.nav02 ul li.current a span.nav_en{
	display: none;
}
header nav ul li.current a:hover span.nav_en,
.nav02 ul li.current a:hover span.nav_en{
    display: none;
}
header nav ul li.current a span.nav_jp,
.nav02 ul li.current a span.nav_jp{
	width: 110px;
    color:#fff;
    display: inline-block;
	background-color:#aa130e;
}
header nav ul li.current a:hover span.nav_jp,
.nav02 ul li.current a:hover span.nav_jp{
	width: 110px;
	color:#fff;
    display: inline-block;
	background-color:#aa130e;
}

header nav ul li.soon a span.nav_en,
.nav02 ul li.soon a span.nav_en{
	cursor:default;
	color:rgba(92,92,92,0.6);
    display: inline;
}
header nav ul li.soon a:hover span.nav_en,
.nav02 ul li.soon a:hover span.nav_en{
    display: none;
}
header nav ul li.soon a span.nav_jp,
.nav02 ul li.soon a span.nav_jp{
	display: none;
}
header nav ul li.soon a:hover span.nav_jp,
.nav02 ul li.soon a:hover span.nav_jp{
	cursor:default;
	width: 110px;
	color:rgba(255,255,255,0.6);
    display: inline-block;
}

.button-toggle {
    display:none;
}

.button-phone{
    display:none;
}


/* contents -------------------------------------*/

#contents{
	width:1000px;
	margin:0 auto 20px auto;
	padding:200px 0 0 0;
	text-align:center;
	overflow:hidden;
}

#contents h2{
	width:100%;
	height: auto;
	margin:10px 0 15px 0;
	text-align:left;
	padding:0 0 0 0;
	font-size: 18px;
	font-size: 1.8rem;
	font-weight:normal;
	font-style:normal;
	border-bottom:1px solid #808080;
}

#contents h2 em{
	font-size: 30px;
	font-size: 3.0rem;
	margin:0 20px 0 0;
	letter-spacing:2px;
}

h4{
	width:100%;
	height: auto;
	margin:0 auto;
	text-align:center;
	padding:20px 0 40px 0;
	font-size: 30px;
	font-size: 3.0rem;
	font-weight:normal;
	font-style:normal;
	letter-spacing:2px;
}

h4 em{
	font-size: 38px;
	font-size: 3.8rem;
}

h5{
	width:100%;
	height: auto;
	margin:0 auto;
	text-align:left;
	padding:0 0 20px 0;
	font-size: 22px;
	font-size: 2.2rem;
	font-weight:normal;
	font-style:normal;
	letter-spacing:2px;
}

.con_navi{
	width:100%;
	margin:40px auto;
	text-align:center;
}

.con_navi ul {
	padding: 0;
	margin: 0;
	list-style: none;
}

.con_navi li {
	display: inline-block;
  /display: inline;
  /zoom: 1;
	width:200px;
	height:auto;
	background: #5b5b5b;
	margin:0 5px 0 0 !important;
}

.con_navi .li_cr {
	background-color:#aa130e;
}

.con_navi a {
	display: block;
	color: #fff;
	text-decoration: none;
	padding:4px 0;
	height: auto;
	font-size:14px;
	font-size:1.4rem;
	letter-spacing:1px;
}

.con_navi a:hover {
	background: #aa130e;
}

.con_box_01l{
	float:left;
	width:480px;
	margin:0 0 40px 0;
	overflow:hidden;
}


.con_box_01r{
	float: right;
	width:480px;
	margin:0 0 40px 0;
	overflow:hidden;
}
.snsLogos{
	display: flex;
	justify-content: center;
	margin: 6% auto 2%;
	/*padding: 10px 0 16px 0;*/
	/*background-color: #747474;*/
}
.snsLogos li{
	width: 6%;
	max-width: 40px;
	margin: 0 16px;
}
/* foot ---------------------------------------*/


footer{
	clear:both;
	width:100%;
	height:100px;
	margin:0 auto;
	padding:0 0 20px 0;
	text-align:center;
	overflow:hidden;
	background-color:#000;
	border-top:1px solid rgba(112,112,112,0.6);
}

#foot{
	width:100%;
	margin:0 auto;
	text-align:center;
}
	
#foot_l{
	float:left;
	width:300px;
	padding:20px 0 0 20px;
	text-align:left;
}

#foot_r{
	float:right;
	width:213px;
	height:70px;
	padding:20px 20px 0 0;
	text-align:right;
}


address{
	margin:10px 0;
	font-size:10px;
	color:#fff;
	text-align:left;
	font-style:normal;
	font-weight:normal;
}





@media only screen and (max-width: 767px) {
body{
	min-width:100%;
}

.pc{
	display:none;
}

.sp{
	display:inherit;
}

span{
	display:block;
}

p.read{
	text-align: justify;
text-justify: inter-ideograph;
}

.p_cap{
text-align: justify;
text-justify: inter-ideograph;
}

.p_cap_r{
text-align: justify;
text-justify: inter-ideograph;
}

header{
	width:100%;
	min-width:100%;
	height:auto;
	margin:0 auto;
	padding:0 0 0 0;
	box-shadow: 0px 0 0 0 rgba(0,0,0,0.0);
}


header #header_l{
	width:50%;
	height:auto;
    margin: 14px auto 0 auto;
    text-align: center;
	float:none;
}

#header_l ul{
	float:none;
	display: flex;
	justify-content: center;
    padding: 0;
    margin: 0;
}


#header_l ul li{
	float:none;
}

#header_l ul li.li01{display: none;}
#header_l ul li.li02{
	width:180px; 
	height:auto; 
	text-align: center;
	margin:0 auto;
	padding: 6px 0 0 0;
	}
#header_l ul li.li03{ display: none;}

	
header #header_r{
	display:none;
}
.button-logo{
	float: left;
	margin:10px 10px 10px 6px;
}


.button-toggle {
	float: right;
	margin:6px;
	cursor:pointer;
}


header nav,
.nav02{
	width:100%;
	min-width:100%;
	height:auto;
	font-size:10px;
	font-size:1.0rem;
	margin:5px 0 0 0;
	box-shadow: none;
  -webkit-box-shadow:none;
  -moz-box-shadow: none;
}

.nav02{
	border-bottom:none;
}

header nav{
	display:none;
}

.nav02{
	display: inherit;
}


header nav ul li,
.nav02 ul li {
	display: inherit;
	position: relative;
	float:left;
	width:50%;
	/*width: 110px;*/
}

header nav ul li a span.nav_en,
.nav02 ul li a span.nav_en{
	color:#fff;
    display: inline;
}

header nav ul li a,
.nav02 ul li a{
	float:left;
	width:100%;
}

header nav ul li.current a span.nav_jp,
.nav02 ul li.current a span.nav_jp{
	width:100%;
}
header nav ul li.current a:hover span.nav_jp,
.nav02 ul li.current a:hover span.nav_jp{
	width:100%;
}


header nav ul li.soon a span.nav_jp,
.nav02 ul li.soon a span.nav_jp{
	width:100%;
}
header nav ul li.soon a:hover span.nav_jp,
.nav02 ul li.soon a:hover span.nav_jp{
	width:100%;
}





header nav ul li .li_new,
.nav02 ul li .li_new {
	top:0;
	left:0;
}




/* contents -------------------------------------*/

#contents{
	width:94%;
	padding:80px 0 0 0;
}

#contents h2{
	text-align:center;
	border-bottom:1px solid rgba(112,112,112,0.6);
	padding:0 0 20px 0;
}

#contents h2 em{
	margin:0 0 0 0;
}


h4{
	text-align:left;
	font-size: 26px;
	font-size: 2.6rem;
}

	.con_navi{
	width:94%;
	margin:20px auto;
	text-align:center;
}


.con_navi li {
	width:100%;
	margin:0 0 5px 0 !important;
}


.con_box_01l,
.con_box_01r{
	float:none;
	width:100%;
}
.snsLogos{
	display: flex;
	justify-content: center;
	margin: 6% auto;
	/*padding: 8px 0 14px 0;*/
}
.snsLogos li{
	width: 8%;
	max-width: 50px;
	

/* foot ---------------------------------------*/

footer{
	height:auto;
}
#foot{
	width:100%;
}
	
#foot_l{
	float:none;
	width:80%;
	margin:0 auto;
	text-align:center;
}

#foot_l img{
	width:100%;
	margin:0 auto;
	text-align:center;
}

#foot_r{
	float:none;
	width:60%;
	height:auto;
	margin:0 auto;
	text-align:center;
}


address{
	text-align:center;
}



}


@media print{
	header #header_r{
	display:none;
}


#gnavi_back{
	display:none;
}

nav{
	display:none;
}

#contents{
	padding:0 0 0 0;
}

#contents h2{
	display:none;
}
footer{
	display:none;
}
	
}


