@charset "UTF-8";

/***********************************
* bootstrap拡張	*
***********************************/
/* 天地中央寄せ --------------------*/
.va-middle,va-bottom{
	letter-spacing:-0.4em;
}
.va-middle > [class*='col-'] {
display:inline-block;
letter-spacing:0;
vertical-align:top;
float:none !important;
vertical-align:middle;
}

.va-bottom > [class*='col-'] {
	display:inline-block;
	letter-spacing:0;
	vertical-align:top;
	float:none !important;
	vertical-align:bottom;
}

/***********************************
* base設定 *
***********************************/
/*ul li--------------------*/
li{
	list-style:none;
}

/*clearfix--------------------*/
.clearfix:after {
	content: " ";
	display: block;
	visibility: hidden;
	clear: both;
	height: 0.1px;
	font-size: 0.1em;
	line-height: 0;
}
.clearfix {
	display: inline-block;
	min-height: 1%;
}

/* ¥ */
* html .clearfix { height: 1%;}
.clearfix { display: block;}

/* */

 /* IE6 */
* html .clearfix { zoom: 1;}
 /* IE7 */
*:first-child+html .clearfix { zoom: 1;}

/* clear-------------------- */
.clear {
	clear: both;
	display: block;
}

/* float-------------------- */
.float_l { float: left; }
.float_r { float: right; }

.float_l_img { float: left; margin-right: 20px; margin-bottom: 15px; }
.float_r_img { float: right; margin-left: 20px; margin-bottom: 15px; }

.img_float_l_nob { float: left; margin-right: 20px; }
.img_float_r_nob { float: right; margin-left: 20px; }

/* 表示・非表示-------------------- */
/* パソコンで見たときは"pc"が表示される */
.pc { display: none !important; }
.sp { display: block !important; }
/* スマートフォンで見たときは"sp"が表示される */
@media only screen and (min-width: 768px) {
	.pc { display: block !important; }
	.sp { display: none !important; }
}
/* 576以下の場合非表示 */
@media (max-width: 575px){
	.sm-none{
		display: none;
	}
}


/* 576以下の場合改行------------------- */
@media screen and (min-width: 576px){
  .br-xs { display:none; }
}
@media screen and (max-width: 575px){
  .br-xs { display:block; }
}
/* 768以下の場合改行------------------- */
@media screen and (min-width: 768px){
  .br-sm { display:none; }
}
@media screen and (max-width: 767px){
  .br-sm { display:block; }
}
/* 768px以上の場合改行・センター------------------- */
@media screen and (min-width: 768px){
  .br-md { display:block; }
	.center-md{text-align: center;}
}
@media screen and (max-width: 767px){
  .br-md { display:none; }
}

/* 992px以上の場合改行------------------- */
@media screen and (min-width: 992px){
  .br-lg { display:block; }
}
@media screen and (max-width: 991px){
  .br-lg { display:none; }
}


/* text-align-------------------- */
.center { text-align: center !important; }
.right { text-align: right !important; }
.left { text-align: left !important; }

/* スマフォの場合は中央寄せ*/
.center-xs{
	text-align:center;
}
	@media (min-width: 768px) {
		.center-xs{
			text-align:left;
		}
	}

/* vertical-align-------------------- */
.v_top{ vertical-align:top !important;}
.v_bottom{ vertical-align: bottom !important;}

/* ※印付きの注意書き用-------------------- */
.note{
	padding-left:1em;
	text-indent:-1em;
}

/* ブロック要素-------------------- */
/* 可変幅中央寄せ */
.block-center {
	display: table;
	margin-left: auto;
	margin-right: auto;
}

/* 可変幅左寄せ */
.block-left {
	display: table;
	margin-right: auto;
}

/* 可変幅右寄せ */
.block-right {
	display: table;
	margin-left: auto;
}

/* インラインブロック-------------------- */
.in_b { display: inline-block; }

/* マウスオーバー-------------------- */
.ov a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-moz-opacity: 0.8;
}

.ov a img {
	opacity: 1;
	filter: alpha(opacity=100);
	-moz-opacity: 1;
}
/*  フェードイン -------------------- */
/* 画面外にいる状態 */
.fadein {
    opacity : 0.7;
    transform : translate(0, 20px);
    transition : all 500ms;
}

/* 画面内に入った状態 */
.fadein.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

/* font-------------------- */
.font10 { font-size: 77% !important; }
.font11 { font-size: 85% !important; }
.font12 { font-size: 93% !important; }
.font14 { font-size: 108% !important; }
.font15 { font-size: 116% !important; }
.font16 { font-size: 123.1% !important; }
.font17 { font-size: 131% !important; }
.font18 { font-size: 138.5% !important; }
.font19 { font-size: 146.5% !important; }
.font20 { font-size: 153.9% !important; }
.font21 { font-size: 161.6% !important; }
.font22 { font-size: 167% !important; }
.font23 { font-size: 174% !important; }
.font24 { font-size: 182% !important; }
.font25 { font-size: 189% !important; }
.font26 { font-size: 197% !important; }

.fontb { font-weight: bold !important; }
.fontn { font-weight: normal !important; }

/* margin-------------------- */
.m_auto{ margin-left:auto; margin-right:auto;}

.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; }

.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; }
.mr40{ margin-right: 40px !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; }

.mb0 { 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; }
.mb60 {	margin-bottom: 60px !important; }

.m_auto { margin: 0 auto; }

/* padding-------------------- */
.pt05 {	padding-top: 5px !important; }
.pt10 {	padding-top: 10px !important; }
.pt15 {	padding-top: 15px !important; }
.pt20 {	padding-top: 20px !important; }
.pt30 {	padding-top: 30px !important; }
.pt40 {	padding-top: 40px !important; }
.pt50 {	padding-top: 50px !important; }

.pb05 {	padding-bottom: 5px !important; }
.pb10 {	padding-bottom: 10px !important; }
.pb15 {	padding-bottom: 15px !important; }
.pb20 {	padding-bottom: 20px !important; }
.pb30 {	padding-bottom: 30px !important; }
.pb40 {	padding-bottom: 40px !important; }
.pb50 {	padding-bottom: 50px !important; }

.pl10{ padding-left:10px !important;}

/*width--------------------*/
.w100 { width: 100px !important; }
.w150 { width: 150px !important; }
.w200 { width: 200px !important; }
.w250 { width: 250px !important; }
.w300 { width: 300px !important; }
.w350 { width: 350px !important; }
.w400 { width: 400px !important; }
.w450 { width: 450px !important; }

/* googleマップレスポンシブ対応用-------------------- */
.g-stv{
position: relative;
padding-bottom: 60%;
height: 0;
overflow: hidden;
}
.g-stv iframe{
position: absolute;
top: 0;
left: 0;
width: 100% !important;
height: 100% !important;
}
/*youtubeマップレスポンシブ対応用-------------------- */
.movie-wrap{
	position: relative;
	padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
}
.movie-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
