@charset "utf-8";
/* CSS Document */
*{
	margin: 0;
	padding: 0;
} 
body {
	font-size: 14px;
	letter-spacing: 1px;
/*	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;*/
	/*font-family: "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";*/
	/*font-family: 'Kosugi Maru', sans-serif;*/
	font-family: "Times New Roman", 游明朝, "Yu Mincho", 游明朝体, YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", HiraMinProN-W3, HGS明朝E, serif;
	font-weight: normal;
}
img{
	vertical-align:bottom;
	width: 100%;
	height: auto;
}
h1,h2,h3,h4,h5{
	font-size:100%;
	font-weight: normal; 
}
ul,li{
	list-style-type: none;
}
a{
	text-decoration: none;
}
address{
	font-style: normal;
}
#wrap{
	background-image: url("../img/back.jpg");
}
.linkStyle{
	color:#dedede;
}
.linkStyle:hover{
	color:#dedede;
	opacity: 0.7;
	transition: all 0.5s;
}

/*カーソル*/
#wrap{cursor: none}
.cursor,.follower{
	/*border-radius: 50%;*/
	position: fixed;
	top: 0;
	left: 0;
	pointer-events: none;
}
.cursor{
	width: 40px;
	height: 30px;
	/*background-color: #dedede;*/
	
	z-index: 1001;
	/*transition: 0.3s;*/
background-size: contain;
	background-image: url(../img/arrow.png);
}
/*.follower{
   width: 30px;
   height: 30px;
   background-color: #1c1c1c;
   -webkit-border-radius: 50%;
   border-radius:         50% ;
	z-index: 1000;
	transition: 0.3s;
	opacity: 0.75;
	transition-property: transform,background
}
.follower.is-active{
	background-color: transparent;
	border: solid 1px #dedede;
	transform: scale(1.2);
}*/


.cursor.is-active{
		/*background-color: #1c1c1c;*/
	transform: scale(1.4);
}
/*.cursor.is-active.more_move,.cursor.is-active.more_info{
	background-color: transparent;
}
.follower.is-active.more_move,.follower.is-active.more_info{
	background-color: transparent;
	border-radius: 0;
	border: none;
	transform: scale(1);
	transition-property: none;
	animation: rumble 0.2s linear infinite;
}*/
/*.cursor.is-active.more_move,.cursor.is-active.more_info{
	background-color: transparent;
}
.follower.is-active.more_move,.follower.is-active.more_info{
	background-color: transparent;
	border-radius: 0;
	border: none;
	transform: scale(1);
	transition-property: none;
	animation: rumble 0.2s linear infinite;
}*/
.cursor.is-active.more_move{
	opacity: 0.9;
	background-image: none;
}
.cursor.is-active.more_move::before{
  content: '';
  display: inline-block;
	width: 40px;
	height: 30px;

	background-image: url(../img/arrow2.png);
	background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
a{cursor: none}


/*-------------------------------------------------------
					ヘッダー
-------------------------------------------------------*/
header #header{
	background-color: rgba(255,255,255,0.64);
	padding: 15px 30px;
	border-radius:5px;
	top: 20px;
	margin: auto;
	width: 80%;
	left: 50%;
	transform: translateX(-50%);
    -webkit- transform: translateX(0%);
	z-index: 9;
	max-width: 600px;
}
header{
    transition: .5s;
    top: 0;
}

header.transform{
top: -30px!important;
}
header #header h1{
	width: 30%;
    max-width: 250px;	
}
header #header li{
	line-height: 1;
}

header #header li a:hover {
    color: #5a9d9b;
    transition: 0.3s;
}
header #header li a{
	display: inline-block;
	letter-spacing: 3px;
	position: relative;
	    font-family: 'Fredericka the Great', cursive;
    font-weight: normal;

}
header #header li a span{
	letter-spacing: 0px!important;
	    font-family: "Times New Roman", 游明朝, "Yu Mincho", 游明朝体, YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", HiraMinProN-W3, HGS明朝E, serif;
	font-weight: 400;
	font-weight: bold;
}


header #header {
padding: 7px 7px;
    background-image: url(../img/h_dec.png),url(../img/h_dec.png),url(../img/h_dec.png),url(../img/h_dec.png);
    background-repeat: no-repeat;
    background-position: top 7px left 7px,top 7px right 7px,bottom 7px left 7px,bottom 7px right 7px;
    background-size: 9px;
}
#header:before{
    content: '';
    display: inline-block;
    width: 92%;
    height: 5px;
    border: 1px solid #1c1c1c;
    margin: auto;
    left: 0;
    right: 0;
    position: absolute;
}
#header:after{
content: '';
    display: inline-block;
    width: 90%;
    height: 5px;
    border: 1px solid #1c1c1c;
    margin: auto;
    left: 0;
    right: 0;
    bottom: 7px;
    position: absolute;
}
#header nav:before{
    content: '';
    display: inline-block;
    width: 5px;
    height: 60%;
    border: 1px solid #1c1c1c;
    margin: auto;
    left: 0;
    bottom: 0;
    top: 0;
    position: absolute;
}
#header nav:after{
content: '';
    display: inline-block;
    width: 5px;
    height: 60%;
    border: 1px solid #1c1c1c;
    margin: auto;
    right: 0px;
    bottom: 0;
    top: 0;
    position: absolute;
}
header #header h1 {
    width: 40%;
    max-width: 400px;
    margin: auto;
}
header #header nav {
    margin: auto;
    /* margin-top: 15px; */
    position: relative;
    padding: 25px 0;
}
header #header nav li {
   padding-left: 10px!important;
}
/*
header #header li a::after {
	background-color: #1c1c1c;
	content: '';
	display: block;
	height: 15px;
	left: 0;
	right:0;
	margin: auto;
	position: absolute;
	transition: .5s all;
	width: 1px;
	transform: scale(1,0);
	transform-origin: bottom left;
	transition: transform .3s;
}


header #header li a:hover::after {
	transform-origin: top left;
	transform: scale(1, 1);
}*/
.language_box{
	width: 80%;
    margin: auto;
	z-index: 999;
    position: absolute;
    right: auto;
    top: 160px;
    left: 50%;
    transform: translateX(-50%);
    -webkit- transform: translateX(0%);
	    text-align: right;
    max-width: 600px;
}
.language{
/*    background-color: #dedede;*/
    border-radius: 5px;
    padding: 10px 10px 10px;
    display: inline-block;
}
.language li {
    padding-right: 10px;
    margin-right: 10px;
    border-right: 1px solid #fff;
    -webkit-transform: skewX(150deg);
    -moz-transform: skewX(150deg);
    transform: skewX(150deg);
}
.language li:last-child{
	padding-right: 0px;
    margin-right: 0px;
    border-right: none;
}
.language li a{
	color: #fff;
    line-height: 1;
    display: block;
    transform: skewX(-150deg);
}
.language li a:hover{
	opacity: 0.7;
	transition: 0.3s;
}
.right_contact{
z-index: 99;
    right: 0;
    /* background-color: #dedede; */
    top: 100px;
    padding: 10px 10px 10px 20px;
    letter-spacing: 2px;
    /* border-radius: 5px 0px 0px 5px / 5px 0px 0px 5px; */
    background-image: url(../img/r_contact.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 70px;
}
.right_contact ul{
	width: 38px;
}
.right_contact_wrap p{
	color: #1c1c1c;
    line-height: 1.9;
}
.right_contact_wrap:hover p{
	opacity: 0.7;
	transition: 0.3s;
}


/*-------------------------------------------------------
					フッター
-------------------------------------------------------*/
footer{
	border-bottom: 20px solid #2a2a2a;
	background-color: #1c1c1c; 
	padding-top: 0px!important;
    margin-top: 100px;
}
footer .f_sns li{
	width: 10%;
	max-width: 45px;
}
footer .f_nav li{
	border-color:#fff;
}
footer .footer_cms,footer .f_nav li a,#copyright,#copyright a{
	    color: #fff;
}

/*-------------------------------------------------------
					ページトップ
-------------------------------------------------------*/
#page-top{
	position: fixed;
	right: 10px;
	z-index: 99; 
}
#page-top a{
	display: block;
	width: 70px;
	height: 70px;
	position: relative;
	border-radius: 50%;
}
#page-top a div{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 45px;
	height: 45px;
	line-height: 1.2!important;
}
#page-top a div p{
	font-size: 9px;
}





@media all and (-ms-high-contrast: none){
/*-------------------------------------------------------
					ヘッダー
-------------------------------------------------------*/
header #header{
	padding: 18px 30px 13px;
}
.right_contact p i{
	-webkit-writing-mode: horizontal-tb;
 -ms-writing-mode: lr-tb;
 writing-mode: horizontal-tb;	
}

#header::before {
    top: 10px;
}

#header::after {
    bottom: 10px;
}
#header nav::after {
    right: -22px;
    height: 80%;
    bottom: 5px;
}
#header nav::before {
    left: -22px;
    height: 80%;
    bottom: 5px;
}

}


/*ここからタブレット用（1100px以下）環境の設定
---------------------------------------------------------------------------*/
/*表示を切り替えるウィンドウサイズの指定*/
@media screen and (max-width: 1100px){

.language_box {
    top: 150px;
}
}



/*ここからタブレット用（768px以下）環境の設定
---------------------------------------------------------------------------*/
/*表示を切り替えるウィンドウサイズの指定*/
@media screen and (max-width: 768px){
/*-------------------------------------------------------
					ヘッダー
-------------------------------------------------------*/
header #header {
    background-color: transparent;
    padding: 10px 0px;
    width: 95%;
    background-image: none;
}
#header:before,#header:after,#header nav:before,#header nav:after{
    display: none;
}
.language_box {
    top: 28px;
	    left: 45%;
}
header #header h1 {
    width: 40%;
    max-width: 300px;
	
margin: initial;
margin-right: auto;

}
#wrap{cursor: auto;}
	a{cursor: pointer;}
	.cursor,.follower{
		display: none;
	}
/*-------------------------------------------------------
					フッター
-------------------------------------------------------*/
footer .f_sns li {
    width: 10%;
    max-width: 35px;
}	

/*-------------------------------------------------------
					ページトップ
-------------------------------------------------------*/
#page-top {
    position: fixed;
    bottom: 10px;
    right: 10px;
	z-index: 99;
}
#page-top a img{
	height: 50px;
	width:50px;
}
}
/*ここからスマホ用（667px以下）環境の設定
---------------------------------------------------------------------------*/
/*表示を切り替えるウィンドウサイズの指定*/
@media screen and (max-width: 667px){
	
header #header {
    top: 10px;
    padding: 15px 0px 10px;
}
header #header h1 {
    width: 75%;
    max-width: 300px;
}
.language_box {
    width: 100%;
    top: 60px;
    text-align: left;
	left: 50%;
}
.right_contact {
    right: auto;
    left: 25px;
    top: auto;
    bottom: 25px;
    width: 70%;
    margin: auto;
    padding: 10px 0px 10px;
	border-radius: 5px 5px 5px 5px / 5px 5px 5px 5px;
	background-color: #1c1c1c;
	background-image: none;
}
.right_contact_wrap p {
    color: #ffffff;
}
.right_contact ul{
	width: 100%;
}
.right_contact li {
    border-bottom: none;
    border-right: 1px solid rgba(255, 255, 255, 0.4);
    width: 24%;
    text-align: center;
}
.right_contact li:last-child{
    border-right:none;
}
#copyright{
	margin-bottom: 40px;		
}
}