@charset "UTF-8";

body{
	font-family: 'Times New Roman', Times, serif;
	margin: 0px;
	padding: 0px;
	font-size:12px;
	color:#000;
}

a:link {
	color: #FFF;
	text-decoration:none;
}

a:visited {
	color: #FFF;
	text-decoration:none;
}

a:hover {
	text-decoration: none;
	color: #CCC;
}

a:active {
	color: #FFF;
	text-decoration:none;
}

@media screen and (max-width: 768px){
/***********************************/
h1{
	text-align:center;
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0px;
}
header{
	background-image:url(../img/common/header_back.jpg);
	background-position: left top;
	background-size:100% auto;
	background-repeat: repeat-x;
	background-color:#e9e9e9;
	width:100%;
	height:auto;
	overflow:hidden;
	padding:.5% 0;
	margin:0;
}
.header-inner{
	width:100%;
	height:auto;
	overflow:hidden;
	position: relative;
	display: flex;
	justify-content: start;
	box-sizing: border-box;
}
.header-logo{
	width:45%;
	height:auto;
	overflow:hidden;
	text-align:left;
	margin:0;
	padding:.5% 0 1% 1%;
	box-sizing: border-box;
}
.header-logo img{
	width:85%;
	vertical-align: bottom;
}
.header-languages-menu{
	width:38%;
	height:auto;
	overflow:hidden;
	margin:0;
	text-align:right;
	padding:1% 4% 1% 0;
	display: flex;
	justify-content: flex-end;
}
.header-language{
	width:auto;
	margin:0;
	padding:0 2%;
	line-height:1.6em;
}
.header-language a{
	font-size:3vw;
	color:#FFF;
	display: block;
	text-decoration: underline;
}
nav.header_pc_navbox{
	display:none;
}
nav.header_navbox{
	width:10%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding:0;
	position:absolute;
	top:0;
	right:0;
}
.menu-btn {
	position: relative;
	top: -22px;
	right: 20px;
	display: flex;
	height: 80px;
	width: 80px;
	justify-content: center;
	align-items: center;
	z-index: 90;
	border-radius: 5px;
}
.menu-btn:hover {
	cursor: pointer;
}
/* 三本線の実装 */
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
	content: "";
	display: block;
	height: 4px;
	width: 40px;
	border-radius: 3px;
	background-color: #333;
	position: absolute;
}
.menu-btn span:before {
	bottom: 10px;
}
.menu-btn span:after {
	top: 10px;
}
/* チェックボックスを非表示にする */
#menu-btn-check {
	display: none;
}
#menu-btn-check:checked ~ .menu-btn span {
	background-color: rgba(
	255,
	255,
	255,
	0
	); /*メニューオープン時は真ん中の線を透明にする*/
}

/* メニューを開いている時はハンバーガーボタンが×になる */
#menu-btn-check:checked ~ .menu-btn span::before {
	bottom: 0;
	transform: rotate(45deg);
}
#menu-btn-check:checked ~ .menu-btn span::after {
	top: 0;
	transform: rotate(-45deg);
}

#container {
	background-color:#FFF;
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;
}

#contents{
	width:98%;
	height:auto;
	overflow:hidden;
	margin:0 auto;
}
#contents_title{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:10px auto 5px;
	font-family: 'Times New Roman', Times, serif;
	font-size:5.5vw;
	color:#000;
	line-height:1.2em;
	letter-spacing: .1em;
	text-align:center;
}
#contents_title div{
	font-size:2.5vw;
	line-height:1em;
}
#reccontents_title{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:10px auto 5px;
	font-family: 'Times New Roman', Times, serif;
	font-size:5.5vw;
	color:#000;
	line-height:1.2em;
	letter-spacing: .1em;
	text-align:center;
}
#reccontents_title div{
	font-size:2.5vw;
	line-height:1em;
}


footer{
	background-image:url(../img/common/footer_back.jpg);
	background-position:left top;
	background-size:100% auto;
	background-repeat: no-repeat;
	background-color:#e9e9e9;
	font-family: 'Times New Roman', Times, serif;
	width:100%;
	height:auto;
	overflow:hidden;
	text-align:center;
	line-height:2em;
	padding:1% 0;
}
footer .footer-logo{
	width:40%;
	font-size:3.5vw;
	color:#333;
	text-align:center;
	padding:3px 1px;
	margin:5px auto;
}
footer .footer-logo img{
	width:80%;
	vertical-align:bottom;
}
footer .footer-logo div{
	font-size:4.5vw;
	color:#333;
}
footer .footer-tel{
	background:url(../img/common/tel.png) no-repeat;
	background-position:left 3% center;
	background-size: auto 100%;
	width:43%;
	height:50px;
	font-size:5vw;
	color:#333;
	text-align:center;
	padding:0 1px 0 5%;
	line-height:1.8em;
	margin:15px auto;
	position: relative;
}
footer .footer-tel a{
	color:#333;
}
footer .footer-add{
	width:80%;
	font-size:2.5vw;
	color:#333;
	line-height:1.2em;
	text-align:center;
	padding:0;
	margin:2% auto;
}
footer .footer-sns{
	width:30%;
	display: flex;
	justify-content: space-between;
	margin:0 auto;
}
footer .footer-snsicon{
	width:50%;
	padding:1%;
	text-align: center;
	box-sizing: border-box;
}
footer .footer-snsicon img{
	width:80%;
	vertical-align: bottom;
}

footer .footer-navbox ul{
	width:95%;
	height:auto;
	overflow:hidden;
	margin:3% auto;
	padding:0;
	list-style-type: none;
}
footer li.footer-nav{
	display: block;
	width:auto;
	font-size:2.6vw;
	color:#333;
	line-height:1.4em;
	padding:0 1%;
	float:left;
	border-right:1px #666 solid;
}
footer li.footer-nav a{
	color:#333;
}
footer li.footer-nav:last-child{
	border:0;
}

footer h2, footer h2 a:link{
	width:60%;
	font-size:3vw;
	color:#333;
	margin:3% auto 0;
	clear:both;
}
footer p{
	font-size:2.5vw;
    color:#333;
    margin:0 auto;
}

.menu-content {
	width: 80%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 100%;
	z-index: 80;
	background: rgba(137,137,137,0.9);
	transition: all 0.5s;
}
.menu-content ul {
	padding: 100px 10px 0;
}
.menu-content ul li {
	border-bottom: solid 1px #ccc;
	text-align:left;
	list-style: none;
}
.menu-content ul li a {
	display: block;
	width: 100%;
	font-size: 3.5vw;
	box-sizing: border-box;
	color: #FFF;
	text-decoration: none;
	padding: 7% 13% 0 0;
	position: relative;
}
.menu-content ul li a span{
	font-size:2.5vw;
	float:right;
}
#menu-btn-check:checked ~ .menu-content {
	left: 30%;
}

}

@media screen and (min-width: 769px) and (max-width: 1024px){
h1{
	width:100%;
	margin:0;
}
header{
	background-image:url(../img/common/header_back.jpg);
	background-position: left top;
	background-size:100% auto;
	background-repeat: repeat-x;
	background-color:#e9e9e9;
	width:100%;
	height:auto;
	overflow:hidden;
	padding:0;
	margin:0;
}
.header-inner{
	width:100%;
	height:auto;
	overflow:hidden;
	position: relative;
	display: flex;
	justify-content: start;
}
.header-logo{
	width:50%;
	height:auto;
	overflow:hidden;
	text-align:left;
	margin:0;
	padding:.5% 0 0 1%;
	box-sizing: border-box;
}
.header-logo img{
	width:80%;
	vertical-align: bottom;
}
.header-languages-menu{
	width:40%;
	height:auto;
	overflow:hidden;
	margin:0;
	text-align:right;
	padding:2% 1% 2% 0;
	display: flex;
	justify-content: flex-end;
}
.header-language{
	width:auto;
	margin:0;
	padding:0 2%;
	line-height:2em;
}
.header-language a{
	font-size:2.2vw;
	color:#FFF;
	display: block;
	text-decoration: underline;
}
nav.header_navbox{
	width:10%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding:0;
	position:absolute;
	top:0;
	right:0;
}
.menu-btn {
	position: relative;
	top: 0;
	right: 10px;
	display: flex;
	height: 80px;
	width: 80px;
	justify-content: center;
	align-items: center;
	z-index: 90;
	border-radius: 5px;
}
.menu-btn:hover {
	cursor: pointer;
}
/* 三本線の実装 */
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
	content: "";
	display: block;
	height: 4px;
	width: 50px;
	border-radius: 3px;
	background-color: #333;
	position: absolute;
}
.menu-btn span:before {
	bottom: 15px;
}
.menu-btn span:after {
	top: 15px;
}
/* チェックボックスを非表示にする */
#menu-btn-check {
	display: none;
}
#menu-btn-check:checked ~ .menu-btn span {
	background-color: rgba(
	255,
	255,
	255,
	0
	); /*メニューオープン時は真ん中の線を透明にする*/
}

/* メニューを開いている時はハンバーガーボタンが×になる */
#menu-btn-check:checked ~ .menu-btn span::before {
	bottom: 0;
	transform: rotate(45deg);
}
#menu-btn-check:checked ~ .menu-btn span::after {
	top: 0;
	transform: rotate(-45deg);
}
nav.header_pc_navbox{
	display:none;
}

#container {
	background-color:#FFF;
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;
}

#contents{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding-top:1%;
}

#contents_title{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:10px auto 5px;
	font-family: 'Times New Roman', Times, serif;
	font-size:4vw;
	color:#000;
	line-height:1.2em;
	text-align:center;
}
#contents_title div{
	font-size:2vw;
	line-height: 1em;
}
#reccontents_title{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:10px auto 5px;
	font-family: 'Times New Roman', Times, serif;
	font-size:4vw;
	color:#000;
	line-height:1.2em;
	letter-spacing: .1em;
	text-align:center;
}
#reccontents_title div{
	font-size:2vw;
	line-height:1em;
}

footer{
	background-image:url(../img/common/footer_back.jpg);
	background-position:left top;
	background-size:100% auto;
	background-repeat: no-repeat;
	background-color:#e9e9e9;
	font-family: 'Times New Roman', Times, serif;
	width:100%;
	height:auto;
	overflow:hidden;
	text-align:center;
	padding:1% 0;
}
footer .footer-logo{
	width:40%;
	font-size:2vw;
	color:#333;
	text-align:center;
	padding:3px 1px;
	margin:5px auto;
}
footer .footer-logo img{
	width:80%;
	vertical-align:bottom;
}
footer .footer-logo div{
	font-size:3.5vw;
	color:#333;
}
footer .footer-tel{
	background:url(../img/common/tel.png) no-repeat;
	background-position:left 2% center;
	background-size: auto 100%;
	width:30%;
	height:50px;
	font-size:4vw;
	color:#333;
	text-align:center;
	padding:0 1px 0 3%;
	line-height:1.6em;
	margin:15px auto;
	position: relative;
}
footer .footer-tel a{
	color:#333;
	display: block;
}
footer .footer-add{
	width:70%;
	font-size:2vw;
	color:#333;
	text-align:center;
	padding:0 1px;
	margin:5px auto;
}
footer .footer-sns{
	width:20%;
	display: flex;
	justify-content: space-between;
	margin:0 auto;
}
footer .footer-snsicon{
	width:50%;
	padding:1%;
	text-align: center;
}
footer .footer-snsicon img{
	width:70%;
	vertical-align: bottom;
}

footer .footer-navbox ul{
	width:100%;
	margin:2% auto;
	padding:0;
	display: flex;
	justify-content: center;
}
footer li.footer-nav{
	display: block;
	width:auto;
	font-size:1.4vw;
	color:#333;
	padding:0 1%;
	border-right:1px #999 solid;
	list-style-type:none;
}
footer li.footer-nav a{
	color:#333;
}
footer li.footer-nav:last-child{
	border:0;
}
footer h2{
	margin:0 auto;
	font-size:1.8vw;
	color:#333;
}
footer h2 a:link{
	color:#333;
}
footer p{
	font-size: 1.5vw;
    color:#333;
    margin:0 auto;
	text-align:center;
}

.menu-content {
	width: 80%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 100%;
	z-index: 80;
	background: rgba(137,137,137,0.9);
	transition: all 0.5s;
}
.menu-content ul {
	padding: 100px 10px 0;
}
.menu-content ul li {
	border-bottom: solid 1px #ccc;
	text-align:left;
	list-style: none;
}
.menu-content ul li a {
	display: block;
	width: 100%;
	font-size: 2.5vw;
	box-sizing: border-box;
	color: #FFF;
	text-decoration: none;
	padding: 7% 13% 0 0;
	position: relative;
}
.menu-content ul li a span{
	font-size:2vw;
	float:right;
}
#menu-btn-check:checked ~ .menu-content {
	left: 30%;
}

}

@media screen and (min-width: 1025px) {
h1{
	width:100%;
	margin:0;
}

header{
	background-image:url(../img/common/header_back.jpg);
	background-position: left top;
	background-size:100% auto;
	background-repeat: repeat-x;
	background-color:#e9e9e9;
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;
}
.header-inner{
	width:98%;
	height:auto;
	overflow:hidden;
	margin:0 auto;
	display: flex;
	justify-content: flex-start;
}
.header-logo{
	width:15%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding:1% 0;
	box-sizing: border-box;
}
.header-logo a img{
	width:100%;
	vertical-align:bottom;
}
.header-languages-menu, nav.header_navbox{
	display:none;
}
nav.header_pc_navbox{
	width:95%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding:0;
	position:relative;
}
nav.header_pc_navbox ul{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding:1% 0;
	position:relative;
	display: flex;
	justify-content:flex-start;
}

li.header_menubtn{
	position:relative;
	width:auto;
	max-width: 13%;
	min-width: 5%;
	height:auto;
	overflow:hidden;
	font-size:1.1vw;
	color:#333;
	text-align:center;
	padding:3px 10px;
	box-sizing: border-box;
	border-right:1px #b3b3b3 solid;
}
li.header_menubtn a:link{
	display: block;
	color:#333;
}
li.header_menubtn a:visited{
	display: block;
	color:#333;
}
li.header_menubtn a:hover{
	display: block;
	color:#999;
}
li.header_menubtn div, li.header_menubtn a div{
	font-size:.8vw;
}

#container {
	background-color:#FFF;
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0 auto;
}
#contents{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;
	padding-top:1%;
}
#contents_title{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:10px auto 5px;
	font-family: 'Times New Roman', Times, serif;
	font-size:4vw;
	color:#000;
	line-height:1.2em;
	letter-spacing: .1em;
	text-align:center;
}
#contents_title div{
	font-size:2vw;
	line-height:1em;
}
#reccontents_title{
	width:100%;
	height:auto;
	overflow:hidden;
	margin:10px auto 5px;
	font-family: 'Times New Roman', Times, serif;
	font-size:4vw;
	color:#000;
	line-height:1.2em;
	letter-spacing: .1em;
	text-align:center;
}
#reccontents_title div{
	font-size:2vw;
	line-height:1em;
}

footer{
	background-image:url(../img/common/footer_back.jpg);
	background-position:left top;
	background-size:100% auto;
	background-repeat: no-repeat;
	background-color:#e9e9e9;
	font-family: 'Times New Roman', Times, serif;
	width:100%;
	height:auto;
	overflow:hidden;
	text-align:center;
	padding:1% 0;
}
footer .footer-logo{
	width:30%;
	font-size:2vw;
	color:#333;
	text-align:center;
	padding:3px 1px;
	margin:5px auto;
}
footer .footer-logo img{
	width:80%;
	vertical-align:bottom;
}
footer .footer-logo div{
	font-size:3vw;
	color:#FFF;
}
footer .footer-tel{
	background:url(../img/common/tel.png) no-repeat;
	background-position:left 3% center;
	background-size: auto 100%;
	width:400px;
	height:80px;
	font-size:3.5vw;
	color:#333;
	text-align:center;
	padding:0 1px 0 3%;
	line-height:1.8em;
	margin:15px auto;
	position: relative;
}
footer .footer-tel a:link{
	color:#333;
	display: block;
}
footer .footer-tel a:hover{
	color:#999;
	display: block;
}
footer .footer-add{
	width:50%;
	font-size:1.2vw;
	color:#333;
	text-align:center;
	padding:0 1px;
	margin:5px auto;
}
footer .footer-sns{
	width:15%;
	display: flex;
	justify-content: space-between;
	margin:0 auto;
}
footer .footer-snsicon{
	width:50%;
	padding:1%;
	text-align:center;
}
footer .footer-snsicon a:hover{
	opacity: 0.8;
}
footer .footer-snsicon img{
	width:70%;
	vertical-align: bottom;
}

footer .footer-navbox ul{
	width:100%;
	margin:15px auto;
	padding:0;
	display: flex;
	justify-content: center;
}
footer li.footer-nav{
	display:block;
	width:auto;
	text-align:center;
	font-size:1.3vw;
	color:#333;
	padding:3px 10px;
	border-right:1px #CCC solid;
	list-style-type:none;
}
footer li.footer-nav a:link{
	color:#333;
}
footer li.footer-nav a:visited{
	color:#333;
}
footer li.footer-nav a:hover{
	color:#999;
}
footer li.footer-nav:last-child{
	border:0;
}
footer h2{
	margin:0 auto;
	font-size:1.2vw;
	color:#333;
}
footer h2 a:link{
	margin:0 auto;
	font-size:1.2vw;
	color:#333;
}
footer h2 a:hover{
	margin:0 auto;
	font-size:1.2vw;
	color:#999;
}
footer p{
	font-size: 1.2vw;
    color:#333;
    margin:0 auto;
	text-align:center;
}

}
