@charset "utf-8";
/* CSS Document */
/*---------------------------------
_基本ベース
-----------------------------------*/ 
body{
	font-family:"ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro",  "游ゴシック", YuGothic, "メイリオ", "Meiryo", Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size: 16px;
	color: #362e2b;
	margin: 0px;
	padding: 0px;
	line-height: 2em;
	letter-spacing: 1px;
	min-width: 320px;
	-webkit-text-size-adjust: 100%;
}
a:link {
	text-decoration: none;
	color: #362e2b;
}
a:visited {
	text-decoration: underline;
	color: #362e2b;
}
a:hover {
	text-decoration: none;
	color: #362e2b;
}
a:active {
	text-decoration: none;
	color: #362e2b;
}

/*---------------------------------
_汎用スタイル
-----------------------------------*/
h1, h2, h3, h4 ,h5 {
	font-size: 14px;
	padding: 0px;
	margin: 0px;
	font-weight: normal;
}
img {
	border-top-width: 0px;
	border-right-width: 0px;
	border-bottom-width: 0px;
	border-left-width: 0px;
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
	vertical-align: top;
	line-height: 100%;
	max-width: 100%;
}
p {
	margin: 0px;
	padding: 0px;
}
form {
	margin: 0px;
	padding: 0px;
}
ul,ol  {
	margin: 0px;
	padding: 0px;	
	list-style-type: none;
}
li {
	padding: 0px;
	margin: 0px;
}
dl,dt,dd {
	margin: 0px;
	padding: 0px;
}
a {
	margin: 0px;
	padding: 0px;
}

a img:hover {
	filter:alpha(opacity=70);
    -moz-opacity:0.70;
    -khtml-opacity: 0.70;
    opacity:0.70;
	filter:none/9;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/*---------------------------------
_clearfix
-----------------------------------*/
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
.clearfix {
	display: inline-block;
}
/* Hides from IE-mac \*/
* html .clearfix {height: 1%;}
.clearfix {display: block;}

.sp_hide {
	display: none;
}
.sp_cr {
	display: block;
}

.sp_display_none {
	display: none;
}
.pc_cr {
	display: inline;
}
.parag {
	display: block;
	margin-bottom: 30px;
}

.wrapper {
	width: 84%;
	margin: 0 auto;
	position: relative;
}

/*---------------------------------
_スマホ横
-----------------------------------*/
#sp_landscape {
	position: fixed;
	z-index: 5;
	width: 100%;
	height: 100%;
	background-color: #fff;
	background-image: url(../img/landscape.jpg);
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: center 80%;
	display: none;
}
/*---------------------------------
_スタブレット縦
-----------------------------------*/
#tab_portrait {
	position: fixed;
	z-index: 5;
	width: 100%;
	height: 100%;
	background-color: #fff;
	background-image: url(../img/portrait.jpg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-position: center 40%;
	display: none;
}

/*---------------------------------
_g_navi
-----------------------------------*/
#container {
	position: relative;
	width: 100%;
	height: 100%;
	background-image: url(../img/bg_white.jpg);
	background-size: 200px 200px;
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
	z-index: 2;
}

.side-open #container,
.side-open .overlay {
	-webkit-transform: translate3d(-300px, 0, 0);
	transform: translate3d(-300px, 0, 0);
}

.overlay {
	content: '';
	visibility: hidden;
	position: fixed;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0);
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
	z-index: 3;
}

.side-open .overlay {
	visibility: visible;
	cursor: pointer;
	background: rgba(0,0,0,.7);
}

.overlay::after {
	visibility: hidden;
	position: fixed;
	top: 40%;
	left: 0;
	display: block;
	width: 100%;
	height: 50px;
	color: rgba(255,255,255,0);
	font-size: 40px;
	font-weight: bold;
	text-align: center;
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
}

.side-open .overlay::after {
	visibility: visible;
	color: rgba(255,255,255,.8);
}

/* --------------------------------------------------- side menu */
.side-menu {
	position: fixed;
	top: 0;
	right: 0;
	box-sizing: border-box;
	width: 300px;
	height: 100%;
	padding-top: 0px;
	text-align: center;
	z-index: 1;
	background-image: url(../img/bg_white.jpg);
	background-size: 200px 200px;
}

.side-menu__ul {
	width: 100%;
	display: block;
	overflow: auto;
	text-align: center;
	font-size: 18px;
}

.side-menu__ul > li > a,
.side-menu__ul > li span {
	display: block;
	color: #000;
}

.side-menu__ul span {
	cursor: pointer;
	-webkit-transition: all .5s;
	transition: all .5s;
}

/* --------------------------------------------------- ellipsis btn */
.side-menu-btn {
	position: fixed;
	top: 8px;
	right: 10px;
	width: 20px;
	height: 16px;
	padding: 9px 7px 8px 7px;
	cursor: pointer;
	z-index: 4;
}

.ellipsis-v {
	position: relative;
	display: block;
	cursor: pointer;
	width: 16px;
	height: 14px;
}

.ellipsis-v .point {
	position: absolute;
	left: 0;
	right: 0;
	display: block;
	width: 20px;
	height: 2px;
	margin: auto;
	background: #000;
	-webkit-transition: all .3s;
	transition: all .3s;
}

.ellipsis-v .point.top {
	top: 0;
}

.ellipsis-v .point.mid {
	top: 0;
	bottom: 0;
}

.ellipsis-v .point.bot {
	bottom: 0;
}

.side-menu-btn:hover .top {
	-webkit-transform: translateY(-1px);
	-ms-transform: translateY(-1px);
	transform: translateY(-1px);
}

.side-menu-btn:hover .bot {
	-webkit-transform: translateY(1px);
	-ms-transform: translateY(1px);
	transform: translateY(1px);
}

.side-open .side-menu-btn:hover .top,
.side-open .top {
	left: 4px;
	width: 18px;
	background: #000;
	-webkit-transform-origin: left top;
	-ms-transform-origin: left top;
	transform-origin: left top;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

.side-open .mid {
	opacity: 0;
}

.side-open .side-menu-btn:hover .bot,
.side-open .bot {
	left: 4px;
	width: 18px;
	background: #000;
	-webkit-transform-origin: left bottom;
	-ms-transform-origin: left bottom;
	transform-origin: left bottom;
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.contents {
	padding: 0px 0px 0px 0px;
}


/*---------------------------------
_ヘッダー
-----------------------------------*/
.side-menu h1 {
	padding: 20% 0px 15% 0px;
}
.side-menu h1 img {
	width: 40%;
	height: auto;
}
.side-menu .side-menu__ul {
	padding-bottom: 30px;
}
.side-menu .side-menu__ul li {
	margin-bottom: 25px;
}
.side-menu .sns {
	text-align: center;
}
.side-menu .sns li {
	display: inline-block;
}

/*---------------------------------
_段落設定
-----------------------------------*/
.textarea p {
	margin-bottom: 1em;
}

/*---------------------------------
_キャッチコピー
-----------------------------------*/
.catch {
	font-size: 30px;
}

/*---------------------------------
_font
-----------------------------------*/
.ff_maru {
	font-family: "じゅん 201","Jun 201","ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
}

/*---------------------------------
_bt_white
-----------------------------------*/
a.bt_white {
	letter-spacing: 2px;
	text-align: center;
	display: block;
	border: solid 2px #ffffff;
	padding: 20px 0px 20px 0px;
}
a.bt_white:link {
	text-decoration: none;
	color: #fff;
}
a.bt_white:visited {
	text-decoration: none;
	color: #fff;
}
a.bt_white:hover {
	text-decoration: none;
	color: #fff;
}
a.bt_white:active {
	text-decoration: none;
	color: #fff;
}

/*---------------------------------
_bt_black
-----------------------------------*/
a.bt_black {
	letter-spacing: 2px;
	text-align: center;
	display: block;
	padding: 22px 0px 22px 0px;
	background-color: #000000;
}
a.bt_black:link {
	text-decoration: none;
	color: #fff;
}
a.bt_black:visited {
	text-decoration: none;
	color: #fff;
}
a.bt_black:hover {
	text-decoration: none;
	color: #fff;
}
a.bt_black:active {
	text-decoration: none;
	color: #fff;
}

/*---------------------------------
_bt_red
-----------------------------------*/
a.bt_red {
	letter-spacing: 2px;
	text-align: center;
	display: block;
	padding: 1em 0px 1em 0px;
	background-color: #ef4958;
	color: #fff;
	border-radius: 3px;
	line-height: 1;
}
a.bt_red:link {
	text-decoration: none;
	color: #fff!important;
}
a.bt_red:visited {
	text-decoration: none;
	color:#fff!important;
}
a.bt_red:hover {
	text-decoration: none;
	color: #fff!important;
}
a.bt_red:active {
	text-decoration: none;
	color: #fff!important;
}


/*---------------------------------
_セクションタイトル
-----------------------------------*/
h2 {
	font-size: 1.6em;
	text-align: center;
	margin-bottom: 1em;
}
h2 span.block {
	display: block;
}
h2 img {
	margin-bottom: 0.5em;
}

/*---------------------------------
_フッター
-----------------------------------*/
footer {
	background-color: #000;
	color: #fff;
	text-align: center;
	padding: 1em 0 1em 0;
	font-size: 12px;
}
footer img {
	width: 50px; 
	height: auto;
	margin-bottom: 1em;
}
footer address {
	font-size: 0.8em;
	font-style: normal;
}

/*=================================

	Utility parts

=================================*/
.firstChild {margin-top: 0 !important;}

/* Margin-top */
.mt00 {margin-top: 0 !important;}
.mt05 {margin-top: 5px !important;}
.mt10 {margin-top: 10px !important;}
.mt15 {margin-top: 15px !important;}
.mt20 {margin-top: 20px !important;}
.mt25 {margin-top: 25px !important;}
.mt30 {margin-top: 30px !important;}
.mt35 {margin-top: 35px !important;}
.mt40 {margin-top: 40px !important;}
.mt45 {margin-top: 45px !important;}
.mt50 {margin-top: 50px !important;}
/* Margin-bottom */
.mb00 {margin-bottom: 0 !important;}
.mb05 {margin-bottom: 5px !important;}
.mb10 {margin-bottom: 10px !important;}
.mb15 {margin-bottom: 15px !important;}
.mb20 {margin-bottom: 20px !important;}
.mb25 {margin-bottom: 25px !important;}
.mb30 {margin-bottom: 30px !important;}
.mb35 {margin-bottom: 35px !important;}
.mb40 {margin-bottom: 40px !important;}
.mb45 {margin-bottom: 45px !important;}
.mb50 {margin-bottom: 50px !important;}
/* Margin-left */
.ml00 {margin-left: 0 !important;}
.ml05 {margin-left: 5px !important;}
.ml10 {margin-left: 10px !important;}
.ml15 {margin-left: 15px !important;}
.ml20 {margin-left: 20px !important;}
.ml25 {margin-left: 25px !important;}
.ml30 {margin-left: 30px !important;}
.ml35 {margin-left: 35px !important;}
.ml40 {margin-left: 40px !important;}
.ml45 {margin-left: 45px !important;}
.ml50 {margin-left: 50px !important;}
/* Margin-right */
.mr00 {margin-right: 0 !important;}
.mr05 {margin-right: 5px !important;}
.mr10 {margin-right: 10px !important;}
.mr15 {margin-right: 15px !important;}
.mr20 {margin-right: 20px !important;}
.mr25 {margin-right: 25px !important;}
.mr30 {margin-right: 30px !important;}
.mr35 {margin-right: 35px !important;}
.mr40 {margin-right: 40px !important;}
.mr45 {margin-right: 45px !important;}
.mr50 {margin-right: 50px !important;}
.mr60 {margin-right: 60px !important;}
/* text-align */
.aC {text-align: center !important;}
.aL {text-align: left !important;}
.aR {text-align: right !important;}
/* vertical-align */
.vT {vertical-align: text-top !important;}
.vB {vertical-align: text-bottom !important;}
.vM {vertical-align: middle !important;}

.fc_red {color: #ff0000!important;}
.fc_white {color: #ffffff!important;}

.fs_l {font-size: 1.6em!important;}
.fs_ml {font-size: 1.4em!important;}
.fs_italic {font-style: italic!important;}

/*---------------------------------
_loading
-----------------------------------*/
#loading {
	width: 100%;
	height: 100%;
	background: #ffffff; /* gif画像の背景色 */
	/*opacity: 0.9; /* 透過させる */
	position: fixed; /* gif画像をスクロールさせない */
	left: 0; /* gif画像を画面横中央へ */
	top: 0; /* gif画像を画面縦中央へ */
	z-index: 9999;

}

#loading table {
	width: 100%;
	height: 100%;
}
#loading table tr td {
	text-align: center;
	vertical-align: middle;
}
img.loading {
	width: 40px;
	height: auto;
}

@media screen and (min-width : 640px),print {
	
	/*---------------------------------
	_a
	-----------------------------------*/
	a {
		-webkit-transition: all .5s;
		transition: all .5s;
	}
	a:hover {
		filter:alpha(opacity=70);
		-moz-opacity:0.70;
		-khtml-opacity: 0.70;
		opacity:0.70;
		filter:none/9;
	}
	
	#container {
		z-index: 0;
	}
	
	/*---------------------------------
	_sp-pc
	-----------------------------------*/
	.sp_cr {
		display: inline;
	}
	.pc_cr {
		display: block;
	}
	
	.textarea p {
		margin-bottom: 2em;
	}

	
	/*---------------------------------
	_g_navi
	-----------------------------------*/
	.side-menu {
		position: fixed;
		width: 100%;
		height: 85px;
		line-height: 85px;
		text-align: left;
	}
	.side-menu-wrapp {
		width: 1000px;
		margin: 0 auto;
	}
	.side-menu h1 {
		padding: 0px;
		width: 130px;
		float: left;
		margin-right: 20px;
	}
	.side-menu h1 img {
		width: 130px;
		height: auto;
		vertical-align: middle;
	}
	.side-menu .side-menu__ul {
		width: 825px;
		height: 85px;
		float: left;
		margin: 0;
		padding: 0;
		overflow: hidden;
	}
	.side-menu .side-menu__ul li {
		font-size: 14px;
		margin: 0;
		padding: 0 10px;
		float: left;
	}
	.side-menu .sns {
		width: 25px;
		float: left;
	}
	.side-menu .sns li {
		width: 25px;
		float: left;
		margin-right: 15px;
		line-height: 85px;
	}
	.side-menu .sns li img {
		vertical-align: middle;
	}
	.side-menu .sns li:last-child {
		margin-right: 0px;
	}
	.side-menu-btn {
		display: none;
	}
	
	
	.contents {
		padding-top: 85px;
	}
	
	.wrapper {
		width: 1000px;
		margin: 0 auto;
	}

}
