@charset "UTF-8";
/* *******************************************************************************
-------------------------------------------------------------
■ PC
-------------------------------------------------------------
 1. link
 ├ 1-1. content text link
 ├ 1-2. tel link
 └ 1-3. side link
 2. title (h2,h3,h4)
 ├ 2-1. h2
 ├ 2-2. h3
 └ 2-3. h4
 3. bt
 4. base template
 5. SNS
 6. table
 ├ 6-1. default
 ├ 6-3. table01
 ├ 6-3. table02
 └ 6-4. hours
 7. news
 ├ 7-1. default
 └ 7-2. title change
 8. 汎用プロパティ
 ├ 8-1. float
 ├ 8-2. margin
 ├ 8-3. text-align
 ├ 8-4. 画像の配置
 ├ 8-5. 画像の装飾
 ├ 8-6. rollover（透過）
 └ 8-7. pc sp change
 9. other
 ├ 9-1. before-after
 ├ 9-2. list
 ├ 9-3. flow
 └ 9-4. qa
 10. MAP
 11. full
 12. inquiry
 13. singlebox
 ├ 13-1. 2 column
 ├ 13-2. 3 column
 └ 13-3. 4 column
 14. コンテンツ非表示

-------------------------------------------------------------
■ @media screen and (max-width: 1000px)
-------------------------------------------------------------
 11. full

-------------------------------------------------------------
■ @media screen and (max-width: 767px)
-------------------------------------------------------------
 1. link
 ├ 1-2. tel link
 └ 1-3. side link
 3. bt
 4. base template
 6. table
 └ 6-4. hours
 9. other
 └ 9-1. before-after
 10. MAP
 11. full
 13. singlebox
 └ 13-4. common column

******************************************************************************* */
/* ----------------------------------------------------------
■ PC
----------------------------------------------------------- */
/* =====================================
 1. link
=====================================*/
/* 1-1. content text link -------------------------- */
.link a { text-decoration: underline; }

/* 1-2. tel link -------------------------- */
a[href^="tel:"] {
	pointer-events: none;
	cursor:text;
}

/* 1-3. side link -------------------------- */
#sidecontact{
  display: block;
  position: fixed;
  bottom:22%;
  z-index: 1000;
}
#sidecontact.rightContent{
  right:0;
}

/* =====================================
 2. title (h2,h3,h4)
===================================== */
/* 2-1. h2 -------------------------- */

.gnv_tmp_h2_bg h2 {
	padding: 10px 15px;
	font-size: 130%;
	font-weight: normal;
	color: #fff;
}
.gnv_tmp_h2_bg {border-bottom: 1px solid #ededed;
	border-top: 3px solid #000;
	width: 100%;
	padding: 10px 5px 9px 10px;
	border-left: 5px solid #c20c4b;
	background: #efe8eb;
}

#news h2, h2.titleBg, .static #content h2.titleBg {
	font-size: 22px;
	font-weight: normal;
	position: relative;
	padding: 10px 10px 8px 24px;
	color: #c20c4b;
	border: medium none;
	border-radius: 4px;
	background: #efe8eb none repeat scroll 0% 0%;
}

.top #news h2,.top h2.titleBg{
	font-size:30px;
	background:none;
		text-align: center;
			padding: 0;
}
.top h2.titleBg:after{
	background:none;
}

.static #content h2.titleBg:after,
h2.titleBg:after {
background: #C20C4B none repeat scroll 0px 0px;
border-radius: 3px;
content: "";
height: 33px;
left: 10px;
position: absolute;
top: 7px;
width: 4px;
}

#news h2:before, .static #content h2.titleBg:before {
	font-size: 22px;
	font-weight: normal;
	position: relative;
	padding: 10px 10px 8px 24px;
	color: #c20c4b;
	border: none;
	border-radius: 4px;
	background: #efe8eb;
}


/* 2-2. h3 -------------------------- */

.gnv_tmp_h3_bg h3 {
	color: #fff;
	border-left: 3px solid #ccc;
	padding: 0 0 0 10px;
}
.gnv_tmp_h3_bg h3, .blog #content .contentArea h3 {
	font-size: 22px;
	font-weight: normal;
	position: relative;
	padding: 10px 10px 8px 24px;
	color: #c20c4b;
	border: none;
	border-radius: 4px;
	background: #efe8eb;
}
.gnv_tmp_h3_bg h3:before, .blog #content .contentArea h3:before {
	background: none repeat scroll 0 0 #c20c4b;
	border-radius: 3px;
	content: "";
	height: 33px;
	left: 10px;
	position: absolute;
	top: 7px;
	width: 4px;
}
/* 2-3. h4 -------------------------- */
.gnv_tmp_h4_bg {
	position: relative;
	padding: 10px 5px 10px 30px;
	border-bottom: 1px solid #e5e5e5;
	font-weight: bold;
}

.text_image .gnv_tmp_h4_bg {
	margin-bottom: 1em !important;
}



.gnv_tmp_h4_bg {
	position: relative;
	padding: 5px 5px 3px 24px;
	border-bottom: dotted 1px #ccc;
}
.gnv_tmp_h4_bg h4 {
	font-size: 105%;
	font-weight: bold;
	line-height: 1.5;
	color: #333;
}
.gnv_tmp_h4_bg:before {
	position: absolute;
	top: 9px;
	left: 2px;
	width: 15px;
	height: 15px;
	content: '';
	border-radius: 50%;
	background: #c20c4b;
}
.gnv_tmp_h4_bg:after {
	position: absolute;
	top: 12px;
	left: 5px;
	width: 9px;
	height: 9px;
	content: '';
	border-radius: 50%;
	background: #fff;
}
h5 {   position:relative;
	font-weight: bold;
	color: #462600;
	padding: 5px 5px 3px 24px;
	border-bottom: 1px dashed #462600;
}
h5:before {
	content: "";
	position: absolute;
	left: 2px;
	top: 12px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: #462600 none repeat scroll 0% 0%;
}
h6 {
	font-weight: bold;
	color: #c70c4c;
}



/* =====================================
 3. bt
===================================== */
.gnv_tmp_bt a {
	line-height: 1.4;
	display: block;
	padding: 10px 20px;
	text-align: center;
	color:#fff;

	background: #11b0d2;

	box-shadow: 0px 4px 0px 0px #0d89a4;
}

.gnv_tmp_bt a:hover {
	opacity:0.8;

}
/* btサイズ指定の場合 */
.gnv_tmp_detail a {
	width: 80%;
	float: left;
}

.link_btn a {
	line-height: 1.4;
	position: relative;
	display: block;
	box-sizing: border-box;
	padding: 10px 20px;
	transition: all .5s ease 0s;
	text-align: center;
	border-radius: 3px;
	box-shadow: 2px 2px 5px rgba(0, 0, 0, .2);
}
.link_btn a:hover {
	text-decoration: none;
	opacity: .8;
	filter: alpha(opacity=80);
	-ms-filter: 'alpha( opacity=80 )';
	-ms-filter: 'progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr=\'#F6AA3A\', endColorstr=\'#F6AA3A\')';
}

/* =====================================
 4. base template
===================================== */
.text_box {
	float: right;
	width: 67%;
}

.b_11_2_in span img, .b_11 .b_11_in span img {
	float: right;
	margin: 0 0 20px 2%;
}

/* =====================================
 6. table
===================================== */
/* 6-1. default -------------------------- */
.b_06 table td,
.b_06 table th {
	border: 1px solid #CCCCCC;
}
.b_06_item {
	background: none repeat scroll 0 0 #EEEEEE;
	width: 30%;
}

/* 6-2. table01 -------------------------- */
table.gnv_tmp_table01 {
	margin-bottom: 1.5em;
	background: #FFFFFF;
	width: 100%;
}
table.gnv_tmp_table01 th,
table.gnv_tmp_table01 td {
	padding: 5px;
	text-align: left;
}
table.gnv_tmp_table01 thead th {
	background: #ddd;
	border-top: 1px dotted #ccc;
}
table.gnv_tmp_table01 th {
	background: #efefef;
	border-top: 1px dotted #ccc;
	border-bottom: 1px dotted #ccc;
}
table.gnv_tmp_table01 td {
	background: #FFFFFF;
	border-bottom: 1px dotted #ccc;
	border-top: 1px dotted #ccc;
}
/* 6-3. table02 -------------------------- */
table.gnv_tmp_table02 {
	margin-bottom: 1.5em;
	width: 100%;
}
table.gnv_tmp_table02 th,
table.gnv_tmp_table02 td {
	padding: 5px;
	text-align: left;
}
table.gnv_tmp_table02 thead th {
	background: #efefef;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
}
table.gnv_tmp_table02 th {
	border-bottom: 1px solid #ccc;
	border-top: 1px solid #ccc;
}
table.gnv_tmp_table02 td {
	border-bottom: 1px solid #ccc;
	border-top: 1px solid #ccc;
}

/* 6-4. hours -------------------------- */
table.gnv_tmp_hours th,
table.gnv_tmp_hours td {
	text-align: center !important;
}

/* =====================================
 7. news
===================================== */
/* 7-1. default -------------------------- */
/*#news h2 {
	display: block;
	padding: 10px;
	border-top: 3px solid #000;
	background: none;
	font-size: 130%;
	margin: 0 0 1em !important;
}*/


#news dl {
	border-bottom: 1px dashed #ccc;
	text-align:left;
	font-size:16px;
}
#news dt .newsNew {
	color: #fff;
	background: #000;
}
#news dd a {
	text-decoration: none;
	color: #333;
}
#news dd a:hover{
	text-decoration: underline;
}

#news .ov {
	text-decoration: none;
}
#news .ov:hover {
	text-decoration: underline;
}
#news .newsBt {
	font-size: 14px;
position: absolute;
top: 6px;
right: 10px;
text-decoration: none;
color: #c20c4b;
}
#news .newsBt:hover {
	text-decoration: underline;
}
#news dt {
	position: relative;
	color:#11B0D2;
}
#news dt .newsNew {
	font-size: 10px;
	line-height: 1.4;
	position: absolute;
	top: 3px;
	margin: 0 0 0 10px;
	color: #fff;
	border-radius: 3px;
	background: #c20c4b;
}
/* 7-2. title change -------------------------- */
.gnv_tmp_008_title_block h2.gnv_tmp_news_title {
	padding: 10px;
	font-size: 130%;
	border-bottom: 1px solid #ededed;
	margin-bottom: 1em;
}

/* =====================================
8. 汎用プロパティ
===================================== */
/* 8-1. float -------------------------- */
.fl { float: left;}
.fr { float: right;}

/* 8-2. margin -------------------------- */
.m00 { margin: 0 !important;}
.m05 { margin: 5px !important;}
.m10 { margin: 10px !important;}
.m15 { margin: 15px !important;}
.m20 { margin: 20px !important;}
.m25 { margin: 25px !important;}
.m30 { margin: 30px !important;}
.m35 { margin: 35px !important;}
.m40 { margin: 40px !important;}
.m45 { margin: 45px !important;}
.m50 { margin: 50px !important;}

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

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

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

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

/* 8-3. text-align -------------------------- */
.tal { text-align:left;}
.tac { text-align:center;}
.tar { text-align:right;}

/* 8-4. 画像の配置 -------------------------- */
/* 基本設定 */
/* right
.b_11_2_in span img,
.b_11 .b_11_in span img {
	float: right;
	margin: 0 0 20px 20px;

}*/

/* 個別設定 */
/* left */
.img_l span img {
	float: left !important;
	margin: 0 20px 20px 0 !important;
}

/* right */
.img_r span img {
	float: right !important;
	margin: 0 0 20px 20px !important;
}

/* 8-5. 画像の装飾 -------------------------- */
/* 角丸 */
.image img,
.text_image img,
.gnv_tmp_style img {
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
}

.img_reset img {
	padding: 0!important;
	border: none!important;
}

/* 8-6. rollover（透過） -------------------------- */
.rollover:hover {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
}

/* 8-7. pc sp change -------------------------- */
.pc {
	display: block !important;
}
.sp {
	display: none !important;
}
@media screen and (max-width: 767px) {
.pc {
	display: none !important;
}
.sp {
	display: block !important;
}
.top_con.sp{
	margin-bottom:1em!important;
}
}

/* =====================================
9. other
===================================== */
/* 9-1. before-after -------------------------- */
.ba_box {
	background: url(../img/ba_ar.png) no-repeat center 55%;
	display: table;
	width: 100%;
}
.ba_box div.column_l,
.ba_box div.column_r {
	display: table-cell;
	width: 30%;
}
.ba_box div.column_l span,
.ba_box div.column_r span {
	width: 100%;
}
.ba_box div.column_l p,
.ba_box div.column_r p,
.ba_box div.column_l span img,
.ba_box div.column_r span img {
	width: 95% !important;
	margin: 0 auto !important;
}
.ba_box .column_r, .ba_box .column_l {
	text-align: center;
	color: #B69440;
	font-size: 120%;
	font-weight: bold;
}
.ba_box .column_r span {
	text-align: right;
}

/* 9-2. list -------------------------- */
/* 通常リスト 01 */
.ic_01 {
	width: 100%;
}
.ic_01 .clearfix {
	padding: 5px 5px 5px 25px;
}
.ic_01 span {
	position: relative;
	line-height: 1;
}
.ic_01 span:before {
	content: "";
	position: absolute;
	background: #000;
	top: 6px;
	left: -16px;
	height: 7px;
	width: 7px;
	border-radius: 50%;

}
/* ul */
.ic_01 ul {
	margin: 25px;
}
.ic_01 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_01 li:before {
	content: "";
	position: absolute;
	background: #000;
	top: 14px;
	left: -16px;
	height: 7px;
	width: 7px;
	border-radius: 50%;

}

/* 通常リスト 02 */
.ic_02 .clearfix {
	padding: 5px 5px 5px 35px;
}
.ic_02 .clearfix span {
	position: relative;
	line-height: 1;
}
.ic_02 span:before{
	content:"\00a0";
	display: block;
	border: solid 9px #000;
	height: 0;
	width: 0;
	position: absolute;
	left: -29px;
	top: 2px;
}
.ic_02 span:after{
	content:"\00a0";
	display:block;
	width: 4px;
	height: 7px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	position:absolute;
	left: -23px;
	top: 6px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
/* ul */
.ic_02 ul {
	margin: 35px;
}
.ic_02 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_02 li:before {
	content:"\00a0";
	display: block;
	border: solid 9px #000;
	height: 0;
	width: 0;
	position: absolute;
	left: -29px;
	top: 10px;
}
.ic_02 li:after{
	content:"\00a0";
	display:block;
	width: 4px;
	height: 7px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	position:absolute;
	left: -23px;
	top: 14px;
	margin-top: 0;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* 矢印リスト 01 */
.ic_arrow_01 .clearfix {
	padding: 5px 5px 5px 25px;
}
.ic_arrow_01 span {
	position: relative;
}
.ic_arrow_01 span:before {
	display: block;
	content: "";
	position: absolute;
	top: 5px;
	left: -15px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #000;
}
.ic_arrow_01 span:hover:before {
	left: -12px;
}
/* ul */
.ic_arrow_01 ul {
	margin: 25px;
}
.ic_arrow_01 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_arrow_01 li:before {
	display: block;
	content: "";
	position: absolute;
	top: 13px;
	left: -15px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #000;
}
.ic_arrow_01 li:hover:before {
	left: -12px;
}

/* 矢印リスト 02 */
.ic_arrow_02 .clearfix {
	padding: 5px 5px 5px 30px;
}
.ic_arrow_02 span {
	position: relative;
}
.ic_arrow_02 span:before {
	display: block;
	content: "";
	position: absolute;
	top: 2px;
	left: -25px;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #999;
}
.ic_arrow_02 span:after {
	display: block;
	content: "";
	position: absolute;
	top: 5px;
	left: -19px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #fff;
}
.ic_arrow_02 span:hover:before {
	left: -22px;
}
.ic_arrow_02 span:hover:after {
	left: -16px;
}

/* ul */
.ic_arrow_02 ul {
	margin: 30px;
}
.ic_arrow_02 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_arrow_02 li:before {
	display: block;
	content: "";
	position: absolute;
	top: 10px;
	left: -25px;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #999;
}
.ic_arrow_02 li:after {
	display: block;
	content: "";
	position: absolute;
	top: 13px;
	left: -19px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #fff;
}
.ic_arrow_02 li:hover:before {
	left: -22px;
}
.ic_arrow_02 li:hover:after {
	left: -16px;
}

/* 9-3. flow -------------------------- */
img.gnv_tmp_flow_arrow_01 {
	margin: 0 auto;
}
img.gnv_tmp_flow_arrow_02 {
	margin: 10px auto 0;
}

/* 9-4. qa -------------------------- */
.gnv_tmp_qa_q {
	border-left: 3px solid #333;
	margin-bottom: 10px;
	padding: 10px;
	display: table;
}
.gnv_tmp_qa_q span.tit {
	font-size: 200%;
	font-weight: bold;
	color: #333;
	padding-right: 20px;
	display: table-cell;
	width: 30px;
}
.gnv_tmp_qa_a {
	border-left: 3px solid #ccc;
	margin-bottom: 10px;
	padding: 10px;
	display: table;
}
.gnv_tmp_qa_a span.tit {
	font-size: 200%;
	font-weight: bold;
	color: #ccc;
	padding-right: 20px;
	display: table-cell;
	width: 30px;
}
.gnv_tmp_qa_a p,
.gnv_tmp_qa_q p {
	display: table-cell;
	width: 100%;
	vertical-align: top;
	padding-top: 15px;
}

/* =====================================
 10. MAP
===================================== */
.gnv_tmp_map {
  position: relative;
  width: 100%;
}
.gnv_tmp_map iframe {
  width: 100% !important;
  height: 400px;
}

/*.gnv_tmp_map {
	position: relative;
	overflow: hidden;
	height: 0;
	margin-right: 15px;
	margin-left: 15px;
	padding-bottom: 40%;
}*/

/* =====================================
 11. full
===================================== */
.content_width_full .parts {
	background: #efefef;
}

/* =====================================
 12. inquiry
===================================== */
/*
■問合せタイトルを付けたい場合
1）下記のコメントアウトを削除する
2）パーツ内の「テキスト」でタイトルを「テキスト」に入力する
 */
/*
.inquiry #content .contentArea {
	margin-top: 0;
}
.inquiry #content .contentArea {
	margin: 0 0 4em;
}
.inquiry #content .btBox {
	margin: 1em 0 0;
}
body#inquiryBody .message {
	display: none;
}
body#inquiryBody .inquiry_textbox {
	margin-bottom: 20px;
}
body#inquiryBody .inquiry_textbox:first-child {
	border-bottom: 1px solid #dedede;
	background: url(../img/h2_bg.gif) no-repeat bottom left;
	font-size: 130%;
	line-height: 1.2;
	padding: 15px;
	border-radius: 0;
	position: relative;
}
.inquiryFormTable {
	border: none;
}
*/
/* =====================================
 13. singlebox
===================================== */
/* 2-1. 2 column -------------------------- */
.singlebox2 {
	float: left;
	margin-left: 0;
	margin-right: 0;
	padding: 10px;
	width: 47% !important;
}
/* 2-2. 3 column -------------------------- */
.singlebox3 {
	float: left;
	margin-left: 0;
	margin-right: 0;
	padding: 10px;
	width: 30% !important;
}
/* 2-3. 4 column -------------------------- */
.singlebox4 {
	float: left;
	margin-left: 0;
	margin-right: 10px;
	margin-bottom: 20px;
	padding: 10px;
	width: 22% !important;
	background: #fff;
}
/* =====================================
 14. コンテンツ非表示
===================================== */
/* TOPのみ解除 上書き（解除しない） */
.top .hikoukai {
	display: none !important;
}
.top #drag-temp-pre-content .parts.hikoukai {
	background: none repeat scroll 0 0 #555;
	border: 5px solid #777;
	display: block !important;
	padding: 20px 0;
}
/* =====================================
15.追記
===================================== */


a:focus, *:focus {
	outline: none;
}
body {
	font-family: 'メイリオ', 'Meiryo', verdana, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Osaka', 'ＭＳ Ｐゴシック', 'MS PGothic', Sans-Serif;
	font-size: 16px;
	line-height: 180%;
	color: #333;
	background: #fff!important;
}
a:hover img {
	opacity: .8;
	filter: alpha(opacity=80);
	-ms-filter: 'alpha( opacity=80 )';
}
#header h1 a:hover img {
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: 'alpha( opacity=100 )';
}
br.br01 {
	display: block;
}
.clearfix:after {
	font-size: .1em;
	line-height: 0;
	display: block;
	visibility: hidden;
	clear: both;
	height: .1px;
	content: ' ';
}
a:visited { color: #c20c4b;
text-decoration: none; }
.mb0 {
	margin-bottom: 0!important;
}
.mb_h3 {
	margin-bottom: 17px!important;
}
.mb_h4 {
	margin-bottom: 13px!important;
}
.mb_h5 {
	margin-bottom: 12px!important;
}
.mb_h6 {
	margin-bottom: 11px!important;
}
.mb_01 {
	margin-bottom: 30px!important;
}
.mb_02 {
	margin-bottom: 50px!important;
}
.mb_03 {
	margin-bottom: 65px!important;
}
ul.ul_left li{
	float:left;}

ul.ul01 {
	list-style: none;
}
ul.ul01 li {
	position: relative;
	padding: 0 0 5px 22px;
}
ul.ul01.float_ul01 li {
	float: left;
	margin: 0 15px 0 0;
}
.ul01 li:before {
	position: absolute;
	top: 9px;
	left: 11px;
	width: 5px;
	height: 5px;
	content: '';
	border-radius: 50%;
	background: #c20c4b;
}
ul.ul02 {
	list-style: none;
}
ul.ul02 li {
	position: relative;
	padding: 0 0 5px 22px;
}
.ul02 li:before {
	position: absolute;
	top: 10px;
	left: 11px;
	width: 5px;
	height: 5px;
	content: '';
	border-radius: 50%;
	background: #c20c4b;
}
ul.sitemap_ic li a {
	font-weight: normal;
}
ul.sitemap_ic li a:hover {
	text-decoration: underline;
}
.blog #content .contentArea h3 a {
	color: #c20c4b;
}
.blog #content .contentArea .date {
	color: #333;
}
.blogside h3 {
	color: #c20c4b;
	border-top: 2px solid #c20c4b;
}
.blogside li:before {
	color: #c20c4b;
}
#blogBody #pagenation a.active:hover, .blog #content #pagenation .active a {
	background: #c20c4b;
}
#blogBody #pagenation a:hover {
	background: #ccc!important;
}
#pagenation .active a, #pagenation a.active:hover {
	/*新着のページ番号の色*/

	background: #c20c4b;
}
.inquiry #content .backBt, .inquiry #content .confirmBt, .inquiry #content .submitBt, .inquiry #content .topBt {
	border: none;
	border-radius: 3px;
	background:#c70c4c;
	border: 1px solid #c70c4c;
	box-shadow: none;
}
.inquiry #content .backBt:hover, .inquiry #content .confirmBt:hover, .inquiry #content .submitBt:hover, .inquiry #content .topBt:hover {
	opacity: .8;
	filter: alpha(opacity=80);
	-ms-filter: 'alpha( opacity=80 )';
}

.b_11_2_in span img, .b_11 .b_11_in span img {
	width: 35%;
	border-radius: 0;
}
ul.ul_check li {
	position: relative;
	padding: 5px 0 5px 24px;
}
ul.ul_check li:before {
	position: absolute;
	z-index: 0;
	top: 9px;
	left: 0;
	width: 17px;
	height: 17px;
	content: '';
	border: 1px solid #c20c4b;
	border-radius: 3px;
	background: none repeat scroll 0 0 #F53679;
}
ul.ul_check li:after {
	position: absolute;
	z-index: 10;
	top: 9px;
	left: 3px;
	width: 11px;
	height: 4px;
	content: '';
	-webkit-transform: rotate(-40deg);
	-ms-transform: rotate(-40deg);
	transform: rotate(-40deg);
	border: transparent 4px solid;
	border-bottom: 2px solid #fff;
	border-left: 2px solid #fff;
}
.number_p {
	font-size: 18px;
font-weight: bold;
line-height: 1.4;
margin: 0px 0px 10px;
padding: 0px 0px 0px 4.5em;
text-indent: -4.5em;
}

.number {
	font-size: 23px;
	margin: 0 9px 0 0;
	padding: 0 6px 0 6px;
	box-shadow: 4px 4px 0px 0px #ddd;
	color: #fff;

	border-radius: 5px;
	background: #c20c4b;
}
/*コンテンツ下部*/
.btn_box01{
max-width: 660px;
margin: 0 auto;
width: 96%;
}
.btn_box01 a {
	/*display: block;*/

}
.btn_box01 a img{
width: 100%;
}
.logo_box{
	margin:0 auto;
	float:none;
	text-align: center;
}
.logo_box img{
max-width:443px;
margin: 0 auto 20px;
}
.inq_box{
	width:660px;
}
.tel_box{
	width:320px;
	float:left;
	margin-bottom: 20px;
}
.blog_box{
	width:320px;
	float:right;
	margin-bottom: 20px;
}
.official{
	width:660px;
	float:none;
	clear:both;
}
.official img{
	margin: 0 auto;

}
.top_box02{
	background: url(../img/bg01.png) no-repeat right 0;
	height:250px;
}
 .top_box03{
	margin: 60px 0px 40px!important;
}
.top h2{

 font-size: 40px;
 color: #c20c4b;
 line-height: 1.3;

 font-family: "メイリオ", "Meiryo", verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
 font-weight: normal;
 padding-top: 95px;
}

 span.title01{
	color:#1A0004;
}

.top_box04{
	background: url(../img/bg02.png) no-repeat left 0;
	height:250px;
}
.top_box04 h2 {

	text-align: right;
}
.grid_12 {
	position: relative;
	width: 1000px;
	margin: 0px auto;
	padding: 0px;
}
.top_box05 h5{
		font-weight: normal;
		font-size:20px;
		padding: 0 0 10px 0;

	color:#C00C4B;
	border-bottom: 0px;

}
.top_box05 p{
	color:#1B0004;
	padding: 0 0 10px 0;}
	.top_box05{
		background: url(../img/bg03.png);
		padding: 65px 0;}
		.box_inner{
			padding:10px;
		}
.top_box05 .gnv_tmp_bt a {

	margin-bottom: 20px;
	position:relative;
}
.top_box05 .gnv_tmp_bt a:visited {
	color:#fff;

}
.top_box05 .gnv_tmp_bt a:hover {
	text-decoration:none;

}
.top_box05 .gnv_tmp_bt a:before{

	position:absolute;
	content:"";
		border-right: 2px solid #fff;
	border-top: 2px solid #fff;

	display: block;
	height: 8px;
	margin-top: -3px;
	right: 15px;
	top: 50%;
	transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	width: 8px;
}
.top_box06{
	width:100%;
	background:#1cc6ea;
		height: 400px;
		margin-bottom:60px!important;
}
.top_box06 .top_access01{
	width: 50%;
	float:left;
}
.top_box06 .top_access02{
float: right;
width: 45%;
		padding: 75px 0 0 5%;
}
.top_access02 h4{
	color:#fff;
	font-size:30px;
	margin-bottom: 20px;}

.top_access02 p{
color:#fff;
}
.gnv_tmp_hours thead th {
	color: #190004;
	background: #fdf2f7 none repeat scroll 0% 0%;
	border: 1px solid #ede2e7;
}
.co {
	color: #c10c4b;
}
table.gnv_tmp_hours tbody th {
	width: 20%;
	border: 1px solid #ede2e7;
}
table.gnv_tmp_hours tbody td {
	border: 1px solid #ede2e7;
}
table.gnv_tmp_hours th, table.gnv_tmp_hours td {
	padding: 5px 2px;
	text-align: center;
}
.time_left p{
font-size:14px;
}
.time_left p.title{
	font-size:30px;
	text-align:center;
	color:#C10C4B;
		margin-bottom: 30px;
}
.b_04_2, .b_09 {
	margin: 0;
}

.top_box07 {
max-width: 1000px;
width: 1000px!important;
margin: 0 auto 4em;
}
.time_left {
float: left;
margin-top: 25px;
width: 58%;
font-size: 18px;
}

.time_left table.gnv_tmp_hours {
width: 100%;
margin-bottom: 10px;
}
.news_right {
float: right;
margin-top: 16px;
width: 38%;
font-size: 13px;
}
.logo_box a:hover img{
opacity:1.0;
}
.top_box05 h5{
font-weight:bold;
}
.top_box05 h5:before {
background:none;
}
.top .contents02_in {
max-width: 1000px;
}
.top .contents02 .menu_box li a {
height: 320px;
margin: 0 0 7px;
}
.tablet .contents02 .menu_box li a {
height: auto;
margin: 0 0 7px;
}
.top .contents02 .menu_box li a:hover img {
opacity: 1;
filter: alpha(opacity=100);
-ms-filter: "alpha( opacity=100 )";
}
.top_box08 {
max-width: 980px;
margin: 60px auto!important;
}
.top_box08 img {
width: auto;
max-width: 100%;
}
.top_box08.b_10.b_10_column3 div.column_c, .top_box08.b_10.b_10_column3 div.column_l, .top_box08.b_10.b_10_column3 div.column_r {
display: table-cell;
width: 33%;
}
/* caption_box */
.caption_box {
width: 35%;
display: table;
float: right;
margin-left: 20px!important;
}
.caption_box img {
width: 100%!important;
margin-bottom: 5px!important;
}
.caption_box .caption_p {
	width:35%!important;
}
/* ----------------------------------------------------------
■ @media screen and (max-width: 1000px)
----------------------------------------------------------- */
@media screen and (max-width: 1000px) {
/* =====================================
 11. full
===================================== */
.content_width_full.under .contents_block {
	margin: 0;
}

.content_width_full .parts {
	background: none;
}

#sidecontact {
	display: block;
	position: fixed;
	bottom: 30%;
	z-index: 1000;
	width: 60px;
}

.grid_12 {
	position: relative;
	width: auto;
	margin: 0px auto;
	padding: 0px;
}
.top_box05 ul{
	margin-left:8%;
	margin-right:8%;
}
.singlebox4 {
float: left;
margin-left: 0;
margin-right: 2%;
margin-bottom: 20px;
padding: 10px;
width: 48% !important;
background: #fff;
box-sizing:border-box;
}
	.top_box07 {
max-width: 96%;
width: 96% !important;
}
.top .contents02 .menu_box li a {
height: auto;
margin: 0;
}
}

/* ----------------------------------------------------------
■ @media screen and (max-width: 767px)
----------------------------------------------------------- */
@media screen and (max-width: 767px) {
/* =====================================
 1. link
=====================================*/
/* 1-2. tel link -------------------------- */
a[href^="tel:"] {
	pointer-events: auto;
	cursor:pointer;
}
/* 1-3. side link -------------------------- */
#sidecontact{
	display: none;
}

/* =====================================
 3. bt
===================================== */
.gnv_tmp_detail a {
	width: auto;
	margin: 0 auto;
	float: none;
}

/* =====================================
 4. base template: ;
===================================== */
.text_box {
	float: right;
	width: 67%;
}
.b_11_2_in span img,
.b_11 .b_11_in span img {
	margin: 0 1em 1em 0;
}

/* =====================================
 6. table
===================================== */
/* 6-4. hours -------------------------- */
table.gnv_tmp_hours th,
table.gnv_tmp_hours td {

}

/* =====================================
9. other
===================================== */
/* 9-1. before-after -------------------------- */
.ba_box {
	background: url(../img/ba_ar_sp.png) no-repeat center 50%;
	margin: 0 auto 5em !important;
}
.ba_box div.column_l,
.ba_box div.column_r {
	width: 100%;
	display: block;
}
.ba_box .column_l {
	margin-bottom: 2em!important;
}
.ba_box .column_r span {
	text-align: center;
}

/* =====================================
 10. MAP
===================================== */


.top_box06 .top_access01{
	width: 100%;
float: none;
}
.top_box06 .top_access02{
float: none;
width: 95%;
padding: 40px 0 40px 5%;
}
.top_box06 {
height: auto;
}
/* =====================================
 11. full
===================================== */
.content_width_full .b_10.b_10_column3 div.column_blank,
.content_width_full .b_11_2.b_11_2_column3 div.column_blank,
.content_width_full .b_11.b_11_column3 div.column_blank,
.content_width_full .b_11_3.b_11_3_column3 div.column_blank {
	display: block !important;
}


/*==================追記(～767px)==================*/

.mb_h3 {
	margin-bottom: 13px!important;
}
.mb_h4 {
	margin-bottom: 10px!important;
}
.mb_h5 {
	margin-bottom: 8px!important;
}
.mb01 {
	margin-bottom: 20px!important;
}
.mb02 {
	margin-bottom: 33px!important;
}
.mb03 {
	margin-bottom: 45px!important;
}
br.br01 {
	display: none;
}
table {
	font-size: 13px;
}
ul.ul01 li {
	display: block;
}
.b_11_2_in span img, .b_11 .b_11_in span img {
	width: 100%;
	margin: 0 0 10px;
	float: none;
}
#news h2, h2.titleBg, .static #content h2.titleBg, .gnv_tmp_h3_bg h3, .blog #content .contentArea h3 {
	font-size: 19px;
}

.gnv_tmp_h3_bg h3 a{
	text-decoration:none;
}
ul.ul_check {
	display: inline-block;
}
.number_p {
	font-size: 17px;
	line-height: 1.8;
	margin: 0;
}

/*コンテンツ下部*/
.btn_box01{
max-width: 660px;
margin: 0 auto;
width: 96%;
}
.btn_box01 a {
	/*display: block;*/

}
.btn_box01 a img{
width: 100%;
/*display: block;*/
}
.logo_box{
	margin:0 auto;
	float:none;
	text-align:center;
}
.logo_box img{
max-width:443px;
margin: 0 auto 20px;
}
.inq_box{
	width:auto;
	width:100%;
}
.tel_box{
	max-width:320px;
	float:left;
	margin-bottom: 20px;
	width:49%;
}
/*.tel_box a img{
	width:50%;

}*/
.blog_box{
	max-width:320px;
	float:right;
	margin-bottom: 20px;
	width:49%;
}
/*.blog_box a img{
	width:50%;

}*/
.official{
	width:auto;
	float:none;
	clear:both;
}
.official img{
	margin: 0 auto;

}
.grid_12 {
	position: relative;
	width: auto;
	margin: 0px auto;
	padding: 0px;
}
.top_box02 {
	background: transparent url("../img/bg01_sp.png") repeat scroll 0% 0%;
	height: 250px;

}
.top_box04 {
	background: transparent url("../img/bg02_sp.png") repeat scroll 0% 0%;
	height: 250px;

}
.top_box05 {
	background: transparent url("../img/bg03_sp.png") repeat scroll 0% 0%;
  background-size: cover;

}


.time_left {
width: 100%;
float: none;
margin: 0 auto 2em;
}
.news_right {
width: 100%;
float: none;
}
.sp_box01 {
display: block;
padding: 0px 0 0 !important;
  width: 95%;
margin-left: auto;
margin-right: auto;
}
.sp_box01_in {
margin: 20px auto 10px;
max-width: none;
width: 100%;
}
.sp_box01 .btn_l {
display: block;
float: left;
width: 48%;
}
.sp_btn01 a,
.sp_btn01 a img {
display: block;
width: 100%;
}
.sp_box01 .btn_r {
display: block;
float: right;
width: 48%;
}
.sp_box01 a {
display: block;
width: 100%;
max-width: 350px;
margin-left: auto;
margin-right: auto;
}
.top .contents02 .menu_box {
padding: 30px 0;
}
.top h2{
		padding-top: 49px;
 font-size: 24px;
}
.top_box02 {
height: 120px;
	background-size: cover;
}
.top_box04 {
height: 120px;
	background-size: cover;
}
.top_box03 {
margin: 30px 0px 0px!important;
}
.top_box08 img {
width: auto;
max-width: 100%;
}
.top_box08.b_10.b_10_column3 div.column_c, .top_box08.b_10.b_10_column3 div.column_l, .top_box08.b_10.b_10_column3 div.column_r {
display: block;
width: 100%;
}
/* caption_box */
.caption_box {
width: 100%;
display: table;
float: none;
margin-left: 0px!important;
}
.caption_box img {
width: 100%!important;
margin-bottom: 5px!important;
}
.caption_box .caption_p {
width: 100%!important;
padding-bottom: 15px;
display: block;
}
}
@media (min-width: 601px) and (max-width: 767px) {
.top_box05 p {
    color: #1B0004;
    padding: 0 0 10px 0;
    min-height: 200px;
}
}
@media screen and (max-width: 600px) {

.singlebox4 {
float: none;
margin-left: 0;
margin-right:0;
margin-bottom: 20px;
padding: 3px;
width: 100% !important;
}
}
