@charset "utf-8";
/* *******************************************************************************
-------------------------------------------------------------
■ PC
-------------------------------------------------------------
 1. title
 ├ 1-1. h2
 ├ 1-2. h3
 └ 1-3. h4 
 2. bt
 3. base template
 4. SNS
 5. table
 ├ 5-1. default
 ├ 5-3. table01	
 ├ 5-3. table02 
 └ 5-4. hours
 6. 汎用プロパティ
 ├ 6-1. float
 ├ 6-2. margin
 ├ 6-3. text-align
 ├ 6-4. 画像の配置
 ├ 6-5. 画像の装飾
 └ 6-6. rollover（透過）
 7. その他テンプレート
 ├ 7-1. ビフォーアフター
 ├ 7-2. list
 ├ 7-3. flow
 └ 7-4. qa
 8. MAP
 9. コンテンツ非表示
 10. pc sp change

------------------------------------------------------------- 
■ Tablet
-------------------------------------------------------------
 3. base template
 └ 3-1. top bn
 
------------------------------------------------------------- 
■ SmartPhone
-------------------------------------------------------------
 2. bt
 3. base template
 └ 3-1.画像横並び
 5. table
 └ 5-4. hours
 7. その他テンプレート
 └ 7-1. ビフォーアフター
 8. MAP
 10. pc sp change

******************************************************************************* */
/* ----------------------------------------------------------
■ PC
----------------------------------------------------------- */
/* =====================================
 1. title (h2,h3,h4)
===================================== */
/* 1-1. h2 -------------------------- */
.gnv_tmp_h2_bg {
    border-bottom: 1px solid #dedede;
	background: url(/asset/h2_bg.gif) no-repeat bottom center;
    position: relative;
}
.gnv_tmp_h2_bg h2 {
    font-size: 40px;
    padding: 55px 0;
    line-height: 1.2;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
    text-align: center;
    color: #454545;
}
/* h2 titleBg */
h2.titleBg,
#blogBody .contentArea h3 {
    border-bottom: none;
    background: none;
    font-size: 150%;
    line-height: 1.2;
    padding: 15px 0;
    border-radius: 0;
    position: relative;
    color: #802640;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
    font-weight: bold;
	margin: 0;
}
/* 1-2. h3 -------------------------- */
.gnv_tmp_h3_bg {
	position: relative;
	background: #f5f5f5;
	border-bottom: none;
	margin-bottom: 25px !important;
	border-radius: 10px;
}
/*.gnv_tmp_h3_bg:after {
	content: "";
	position: absolute;
	background: #aeaeae;
	top: 50%;
	left: 10px;
	margin-top: -3px;
	height: 8px;
	width: 8px;
	border-radius: 30%;
}*/
.gnv_tmp_h3_bg h3 {
	font-size: 170%;
	font-weight: normal;
	padding: 10px 15px 13px 25px;
	line-height: 1.2;
	color: #8b2945;
	font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
}
/* 1-3. h4 -------------------------- */
.gnv_tmp_h4_bg {
	position: relative;
	line-height: 1;
	border-bottom: none;
	font-weight: bold;
	/*margin-bottom: 30px !important;*/
}
.gnv_tmp_h4_bg:before {
	content: "";
	position: absolute;
	background: #802640;
	top: 35%;
	left: 0px;
	margin-top: -3px;
	height: 20px;
	width: 20px;
	border-radius: 50%;
}
.gnv_tmp_h4_bg:after {
content: "";
    position: absolute;
    background: #fff;top: 58%;left: 5px;margin-top: -3.5px;height: 10px;width: 10px;
    border-radius: 50%;}
.gnv_tmp_h4_bg h4 {
    font-size: 150%;
    font-weight: normal;padding: 0 0 0 30px;color: #802640;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;}

/* =====================================
 2. bt
===================================== */
.gnv_tmp_bt a {
	line-height: 1.4;
	display: block;
	padding: 5px 20px;
	text-align: center;
	font-weight: bold;
	color:#000;
  background: #f2f2f2;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #f5f5f5), color-stop(0.00, #f2f2f2));
	background: -webkit-linear-gradient(top, #f5f5f5 0%, #f2f2f2 100%);
	background: -moz-linear-gradient(top, #f5f5f5 0%, #f2f2f2 100%);
	background: -o-linear-gradient(top, #f5f5f5 0%, #f2f2f2 100%);
	background: -ms-linear-gradient(top, #f5f5f5 0%, #f2f2f2 100%);
	background: linear-gradient(top, #f5f5f5 0%, #f2f2f2 100%);
	-webkit-box-shadow: 0 3px 0 0 #cdcdcd;
	-moz-box-shadow: 0 3px 0 0 #cdcdcd;
	box-shadow: 0 3px 0 0 #cdcdcd;
	border-radius: 5px;
}
.text_image .gnv_tmp_bt a {
	margin-top: 0.5em;
}
.gnv_tmp_bt a:hover,
.gnv_tmp_detail a:hover {
	text-decoration: none;
	background: #fafafa;
}
/* btサイズ指定の場合 */
.gnv_tmp_detail a {
	width: 20%;
	float: left;
}

/* =====================================
 3. 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;
}
.b_01, .b_02 {
	margin: 0 0 1em;
}

/* =====================================
 4. SNS
===================================== */
#line,
#facebook,
.fb-like {
	margin-bottom: 5px;
}

/* =====================================
 5. table
===================================== */
/* 5-1. default -------------------------- */
.b_06 table td,
.b_06 table th {
    border-top: 1px solid #d3d1ca;
    border-bottom: 1px solid #d3d1ca;
	border-right: none;
    border-left: none;
    padding: 30px !important;
    color: #454545;
    font-weight: normal;
}
.b_06_item {
    background: none repeat scroll 0 0 #f9f8f3;
    width: 30%;
}
/* 5-2. table01 -------------------------- */
table.gnv_tmp_table01 {
	margin-bottom: 1.5em;
}
table.gnv_tmp_table01 th,
table.gnv_tmp_table01 td {
    text-align: left;
}
table.gnv_tmp_table01 {
    background: #fff;
	width: 100%;
}
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: #fff;
    border-bottom: 1px dotted #ccc;
    border-top: 1px dotted #ccc;
}
/* 5-3. table02 -------------------------- */
table.gnv_tmp_table02 {
	margin-bottom: 1.5em;
}
table.gnv_tmp_table02 th,
table.gnv_tmp_table02 td {
    text-align: left;
}
table.gnv_tmp_table02 {
	width: 100%;
}
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;
}
/* 5-4. hours -------------------------- */
table.gnv_tmp_hours th,
table.gnv_tmp_hours td {
	text-align: center;
}
table.gnv_tmp_hours tbody th {
	width: 20%;
}

/* =====================================
 6. 汎用プロパティ
===================================== */
/* 6-1. float -------------------------- */
.fl { float: left;}
.fr { float: right;}
/* 6-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;}

/* 6-3. text-align -------------------------- */
.tal { text-align:left;}
.tac { text-align:center;}
.tar { text-align:right;}
/* 6-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;
}
/* 6-5. 画像の装飾 -------------------------- */
/* 角丸 */
.image img,
.text_image img,
.gnv_tmp_style img {

}
/* 6-6. rollover（透過） -------------------------- */
.rollover a img:hover,
.rollover span a img:hover,
.rollover .img_r span a img:hover {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
}

/* =====================================
 7. その他テンプレート
===================================== */
/* 7-1. ビフォーアフター -------------------------- */
.ba_box {
	background: url(/asset/ba_ar.png) no-repeat 49% 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;
}
/* 7-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: 10px;
	left: -16px;
	margin-top: -4px;
	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: 10px;
	left: -16px;
	margin-top :0px;
	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: 10px;
    margin-top: -8px;
} 
.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: 10px;
    margin-top: -4px;  
    -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;
	margin-top: -4px;
}
.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: 10px;
    margin-top: 0;  
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
}
/* 矢印リスト 01 */
.ic_arrow_01 div {
	padding: 5px 5px 5px 25px;
}
.ic_arrow_01 span {
	position: relative;
}
.ic_arrow_01 span:before {
	display: block;
	content: "";
	position: absolute;
	left: -15px;
	width: 0;
	height: 0;
	margin-top: 6px;
	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: 10px;
	left: -15px;
	width: 0;
	height: 0;
	margin-top: -1px;
	border: 5px solid transparent;
	border-left: 5px solid #000;
}
/* 矢印リスト 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: 10px;
	left: -25px;
	width: 16px;
	height: 16px;
	margin-top: -8px;
	border-radius: 50%;
	background: #999;
}
.ic_arrow_02 span:after {
	display: block;
	content: "";
	position: absolute;
    top: 10px;
	left: -19px;
	width: 0;
	height: 0;
	margin-top: -5px;
	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;
	margin-top: -4px;
	border-radius: 50%;
	background: #999;
}
.ic_arrow_02 li:after {
	display: block;
	content: "";
	position: absolute;
    top: 10px;
	left: -19px;
	width: 0;
	height: 0;
	margin-top: -1px;
	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;
}
/* 7-3. flow -------------------------- */
img.gnv_tmp_flow_arrow_01,
img.gnv_tmp_flow_arrow_02 {
	margin: 10px auto 0;
}
/* 7-4. qa -------------------------- */
.gnv_tmp_qa_q {
	border-left: 3px solid #6f99b5;
	margin-bottom: 10px;
	padding: 10px;
	display: table;
}
.gnv_tmp_qa_q span.tit {
	font-size: 200%;
	font-weight: bold;
	color: #6f99b5;
	padding-right: 20px;
	display: table-cell;
	width: 30px;
}
.gnv_tmp_qa_a {
	border-left: 3px solid #802640;
	margin-bottom: 10px;
	padding: 10px;
	display: table;
}
.gnv_tmp_qa_a span.tit {
	font-size: 200%;
	font-weight: bold;
	color: #802640;
	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;
}

/* =====================================
 8. MAP
===================================== */
.gnv_tmp_map {
  position: relative;
  width: 100%;
  padding-top: 40%;
}
.gnv_tmp_map iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

/* =====================================
 9. コンテンツ非表示
===================================== */
.hikoukai {
	display: none !important;
}
#drag-temp-pre-content .parts.hikoukai {
	display: block !important;
	border: 5px solid #777;
	background: #555;
	padding: 20px 0;
}

/* =====================================
 10. pc sp change
===================================== */
.pc {
	display: block !important;
}
.sp {
	display: none !important;
}

.side_pc {
	display: block !important;
}
.side_tab {
	display: none !important;
}

/* ----------------------------------------------------------
■ Tablet
----------------------------------------------------------- */
@media screen and (min-width: 601px) and (max-width: 959px) {
/* =====================================
 3. base template
===================================== */
/* 3-1. top bn -------------------------- */
/* 700px bn (1column) */
.b_10.bn01 img {
    width: 75% !important;
}
/* 345px bn (2column) */
.b_10.b_10_column2.bn02 {
    width: 75% !important;
	margin: 0 auto 2em;
}
.b_10.bn02 img {
    width: 100% !important;
}
/* 224px bn (3column) */
.b_10.b_10_column3.bn03 {
    width: 75% !important;
	margin: 0 auto 2em;
}
.b_10.bn03 img {
    width: 100% !important;
}
/* =====================================
 10. pc sp change
===================================== */
.side_pc {
	display: none !important;
}
.side_tab {
	display: block !important;
}

}

/* ----------------------------------------------------------
■ SmartPhone
----------------------------------------------------------- */
@media screen and (max-width: 600px) {
/* =====================================
 2. bt
===================================== */
.gnv_tmp_detail a {
	width: auto;
	float: none;
}

/* =====================================
 3. base template
===================================== */
.text_box {
	float: none;
	width: 100%;
}
.b_11_3.b_11_3_column3,
.b_11_3.b_11_3_column3 div.column_c,
.b_11_3.b_11_3_column3 div.column_l,
.b_11_3.b_11_3_column3 div.column_r {
	margin: 0 0 1.0em !important;
}
.b_11 .b_11_in span img,
.b_11_2_in span img {
	margin: 0 0 0.5em;
	width: 100%;
}
/* 3-1.画像横並び -------------------------- */
.b_10.b_10_column2.img_list {
    border: medium none;
    border-collapse: collapse;
    display: table;
    line-height: 1px;
    table-layout: fixed;
    width: 100%;
}
.b_10.b_10_column3.img_list {
	display: table;
}
/* 2列 */
.img_list.b_10.b_10_column2 div.column_l {
    display: table-cell;
    line-height: 1px;
    padding-right: 10px;
    vertical-align: top;
    width: auto;
}
.img_list.b_10.b_10_column2 div.column_r {
    display: table-cell;
    line-height: 1px;
    padding-left: 10px;
    vertical-align: top;
    width: auto;
}
/* 3列 */
.b_10.b_10_column3 div.column_blank {
    display: table-cell !important;
    vertical-align: top;
    width: auto;
}
.img_list.b_10_column3 div.column_c,
.img_list.b_10_column3 div.column_l {
    display: table-cell;
    width: 32%;
	margin-right: 1%;
}
.img_list.b_10_column3 div.column_r {
    display: table-cell;
    width: 32%;
	margin-right: 0;
}

/* =====================================
 5. table
===================================== */
/* 5-4. hours -------------------------- */
table.gnv_tmp_hours th,
table.gnv_tmp_hours td {
	font-size: 70%;
}

/* =====================================
 7. その他テンプレート
===================================== */
/* 7-1. ビフォーアフター -------------------------- */
.ba_box {
	background: url(/asset/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;
}

/* =====================================
 8. MAP
===================================== */
.gnv_tmp_map {
  padding-top: 70%;
}
.gnv_tmp_map iframe {
  right: 10%;
  width: 80% !important;
}

/* =====================================
 10. pc sp change
===================================== */
.pc {
	display: none !important;
}
.sp {
	display: block !important;
}

.side_pc {
	display: none!important;
}
.side_tab {
	display: block !important;
}
}

/* =====================================
北原追記_20150623
===================================== */
.b_10.b_10_column2 div.column_r ,.b_11_2.b_11_2_column2 div.column_r {
    padding-left: 10px;
}
.b_10.b_10_column2 div.column_l ,.b_11_2.b_11_2_column2 div.column_l {
    padding-right: 10px;
}
.b_11 .b_11_in span img {
    width: 36%;
}
#content {
    padding-top: 0;
}

@media screen and (max-width: 600px) {
.b_10.b_10_column2 div.column_r ,.b_11_2.b_11_2_column2 div.column_r {
    padding-left: 0;
}
.b_10.b_10_column2 div.column_l ,.b_11_2.b_11_2_column2 div.column_l {
    padding-right: 0;
}
.b_11 .b_11_in span img {
    width: 100%;
}
}

/*==================追記(pc)==================*/

.word_break {
 word-break: break-all;
}
a:focus,
*:focus {
 outline: none;
}
a {
 color: #802640;
}
a:hover {
 color: #802640;
 text-decoration: underline;
}
a:hover img {
 opacity: 0.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 )";
}
.mb0 {
 margin-bottom: 0!important;
}
.mb_h3 {
 margin-bottom: 20px !important;
}
.mb_h4 {
 margin-bottom: 25px!important;
}
.mb_h5 {
 margin-bottom: 10px!important;
}
.mb_01 {
 margin-bottom: 27px!important;
}
.mb_02 {
 margin-bottom: 50px!important;
}
.mb_03 {
 margin-bottom: 75px!important;
}
ul.ul01 {
 list-style: none;
}
ul.ul01 li {
 padding: 0 0 5px 22px;
 position: relative;
 word-wrap: break-word;
}
.ul01 li:before {
    background: none repeat scroll 0 0 #802640;
    border-radius: 50%;
    content: "";
    height: 5px;
    left: 11px;
    position: absolute;
    top: 9px;
    width: 5px;
}
.float_ul01 li {
 margin: 0 20px 0 0;
 float: left;
 width: 40%;
}
ul.ul_check li {
 padding: 5px 0px 5px 24px;
 position: relative;
}
ul.ul02 {
 list-style: none;
}
ul.ul02 li {
 padding: 0 0 5px 14px;
 position: relative;
}
ul.ul02.float_ul01 li {
 box-sizing: border-box;
 float: left;
 margin: 0 2% 0 0;
 padding: 0 0 5px 14px;
 position: relative;
 width: 48%;
}
ul.ul02 li a {
 font-weight: bold;
}
.ul02 li:before {
 display: block;
 content: "";
 position: absolute;
 top: 8px;
 left: 3px;
 width: 0;
 height: 0;
 border: 5px solid transparent;
 border-left: 5px solid #3584d5;
}
ul.ul_check li:before {
 background: none repeat scroll 0 0 #6a91c4;
 border: 1px solid #537eb6;
 border-radius: 3px;
 content: "";
 height: 17px;
 left: 0;
 position: absolute;
 top: 9px;
 width: 17px;
 z-index: 0;
}
ul.ul_check li:after {
 position: absolute;
 top: 9px;
 left: 3px;
 content: "";
 width: 11px;
 height: 4px;
 border: transparent 4px solid;
 border-left: 2px solid #FFFFFF;
 border-bottom: 2px solid #FFFFFF;
 transform: rotate(-40deg);
 -webkit-transform: rotate(-40deg);
 -ms-transform: rotate(-40deg);
 z-index: 10;
}
p.point_p {
 color: #cab52c;
 font-size: 22px;
 font-weight: bold;
 line-height: 1.3;
 padding: 7px 5px 8px 16px;
 position: relative;
 font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
 text-shadow: 2px 2px 1px #fff, -2px -2px 1px #fff, 2px -2px 1px #fff, -2px 2px 1px #fff;
 z-index: 1;
}
p.point_p:before {
 content: "";
 position: absolute;
 top: 0;
 left: 0;
 width: 25px;
 height: 25px;
 border: 9px solid #d7f0f9;
 border-radius: 50%;
 z-index: -1;
}
.number_p {
 font-size: 19px;
 font-weight: bold;
 line-height: 1.4;
 margin: 0 0 10px;
 padding: 0 0 0 110px;
 text-indent: -110px;
}
.number {
 background: none repeat scroll 0 0 #cab52c;
 border-radius: 5px;
 box-shadow: 3px 3px 0 #ccc;
 color: #fff;
 font-size: 23px;
 margin: 0 10px 0 0;
 padding: 0 8px;
}
.arrow_box {
 position: relative;
 height: 40px;
 width: 100%;
}
.arrow_box:before {
 content: "";
 position: absolute;
 background: none;
 top: 10px;
 left: 0px;
 height: 0;
 border-top: dotted #E6DDB8 2px;
 width: 100%;
}
.arrow_box:after {
 display: block;
 content: "";
 position: absolute;
 top: 10px;
 left: 50%;
 margin: 0 0 0 -30px;
 width: 0px;
 height: 0px;
 border: 30px solid transparent;
 border-top: 16px solid #faeaa9;
}
.merit01 {
 padding: 0px 6px 0px 6px;
 border-radius: 5px;
 background: #cdb827;
 font-size: 20px;
 color: #fff;
 margin: 0 0 8px;
 display: inline-block;
}
.merit02 {
 padding: 0px 6px 0px 6px;
 border-radius: 5px;
 margin: 0 0 8px;
 background: #6a91c4;
 font-size: 20px;
 color: #fff;
 display: inline-block;
}
.text_box {
 float: right;
 width: 62%;
}
.border_box01 {
 background-color: #e1f8ff;
 border: 1px solid #ddd;
 border-radius: 7px;
 padding: 10px;
}
.border_box02 {
 background-color: #f8f8f8;
 border: 1px solid #ddd;
 border-radius: 7px;
 padding: 10px;
}
.text_01 {
 color: #cdb827;
 font-size: 24px;
 font-weight: bold;
 letter-spacing: 0;
 line-height: 1.6 !important;
 padding: 0;
 text-align: center;
 font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
}

.link_btn {
 width: 100%;
 max-width: 260px;
}
.link_btn a {
 line-height: 1.4;
 display: block;
 padding: 10px 20px 8px;
 box-sizing: border-box;
 text-align: center;
 position: relative;
 color: #fff;
 border-bottom: 4px solid #4572ad;
 background: none #6a91c4;
 transition: all 0.5s ease 0s;
}
.link_btn a:before {
 border-top: 2px solid #fff;
 border-right: 2px solid #fff;
 content: "";
 display: block;
 height: 8px;
 margin-top: -4px;
 position: absolute;
 right: 10px;
 top: 50%;
 -webkit-transform: rotate(45deg);
 transform: rotate(45deg);
 -ms-transform: rotate(45deg);
 width: 8px;
}
.link_btn a:hover {
 opacity: 0.8;
 color: #fff;
 filter: alpha(opacity=80);
 -ms-filter: "alpha( opacity=80 )";
 text-decoration: none;
 /*-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#3db0e7', endColorstr='#0197e0')";*/
}
.under #content img {
    border-radius: 10px;
}
.b_11_2_in span img {
    display: block;
    float: right;
    width: 40%;
    margin: 0 0 1em 2em!important;
    line-height: 1px;
}
/* top_box01 */
.top_box01.b_11_2.b_11_2_column3 div.column_c, 
.top_box01.b_11_2.b_11_2_column3 div.column_l, 
.top_box01.b_11_2.b_11_2_column3 div.column_r {
    width: auto;
    /*max-width:213px;*/
}

.top_box01.b_11_2.b_11_2_column3 div.column_c img, 
.top_box01.b_11_2.b_11_2_column3 div.column_l img, 
.top_box01.b_11_2.b_11_2_column3 div.column_r img{
    width: 100%;
    max-width:213px;
    margin: 0 auto 20px auto;
}
/* top_box02 */
.top_box02_01, .top_box02_02 {
	border-left: none;
	margin-bottom: 0;
	padding: 0px 0px 25px;
	display: table;
	width: 100%;
}
.top_box02_01 span.tit, .top_box02_02 span.tit {
	font-size: 170%;
	font-weight: normal;
	color: #fff;
	display: table-cell;
	width: 30px;
	font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
	text-align: center;
	position:relative;
	padding: 10px 10px;
	line-height: 1.1em;
}
.top_box02_01 span.tit {
	background: #78a6c4;
}
.top_box02_02 span.tit {
	background: #802640;
}
.top_box02_01 span.tit:before {
    width: 0px;
    height: 0;
    border-top: 20px solid #78A6C4;
    border-right: 25px solid transparent;
    border-bottom: 30px solid transparent;
    border-left: 25px solid transparent;
    position: absolute;
    content: "";
    bottom: -50px;
    left: 0;
}
.top_box02_02 span.tit:before {
    width: 0px;
    height: 0;
    border-top: 20px solid #802640;
    border-right: 25px solid transparent;
    border-bottom: 30px solid transparent;
    border-left: 25px solid transparent;
    position: absolute;
    content: "";
    bottom: -50px;
    left: 0;
}
.top_box02_01 p,
.top_box02_02 p {
	display: table-cell;
	width: 100%;
	vertical-align: top;
}
.top_box02_01 .box,
.top_box02_02 .box {
    margin: 0 0 0 5%;
    width: 95%;
}
.top_box02_02 .con_r {
    float: right;
    margin: 0 0 1em 1em;
    width:34%!important;
}
.top_box02_02 .con_l {
    width: 60%!important;
}
.top_box02_01 h5 {
	position:relative;
    color: #475a6d;
    font-size: 18px;
    padding-bottom: 20px;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
	padding-left: 20px;
}
.top_box02_01 h5:before {
	content: "";
	position: absolute;
	background: #475a6d;
	top: 30%;
	left: 5px;
	margin-top: -3px;
	height: 8px;
	width: 8px;
	border-radius: 50%;
}
.top_box02_02 h5 {
	position:relative;
    color: #802640;
    font-size: 18px;
    padding-bottom: 20px;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
	padding-left: 20px;
}
.top_box02_02 h5:before {
	content: "";
	position: absolute;
	background: #802640;
	top: 30%;
	left: 5px;
	margin-top: -3px;
	height: 8px;
	width: 8px;
	border-radius: 50%;
}
.top_box02 .link_btn a {
 line-height: 1.4;
 display: block;
 padding: 18px 20px 20px;
 box-sizing: border-box;
 text-align: center;
 position: initial;
 color: #fff;
 border-bottom: none;
 background: #802640;
 transition: all 0.5s ease 0s;
 font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
 font-size: 150%;
 border-radius: 10px;
 margin-top: 35px;
}
.top_box02 .link_btn a:before {
	display:none;
}
.top_box02 .link_btn {
    width: auto;
    max-width: 100%;
}


.color01 {
    color: #12344f;
	font-weight:bold;
}
.color02 {
    color: #4a1427;
	font-weight:bold;
}
.color03 {
    color: #802640;
	font-weight:bold;
}
p.catch01 {
    color: #12344f;
    font-size: 150%;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
    padding-bottom: 20px;
}
p.catch02 {
    color: #802640;
    font-size: 150%;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
    padding-bottom: 15px;
}

/* about */
p.name {
    font-size: 130%;
    font-weight: normal;
    color: #5E9291;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
    float: right;
}
h5 {
    color: #802640;
    margin-bottom: 10px;
    padding: 0 0 0 20px;
}

/* divorce */
ol{
	counter-reset: li;
	list-style: none;*
	list-style: decimal;
	font-size: 15px;
	padding: 0;
	margin: 0;
	text-shadow: none;
}
ol ol{
	margin: 0 0 0 2em;}
.ol_number li{
	position: relative;
	display: block;
    padding: .3em .4em .5em 2.8em;
    margin: 0 0 0.5em 3em;
	background: #f9f8f5;
	color: #454545;
	text-decoration: none;
	-moz-border-radius: .3em;
	-webkit-border-radius: .3em;
	border-radius: .3em;
	width: auto;
	/*height: 17px;*/
}
.ol_number li:before{
	content: counter(li);
	counter-increment: li;
	position: absolute;
	left: -20px;
	top: 50%;
	margin-top: -1.3em;
	background: #802640;
	color: #fff;
	height: 2em;
	width: 2em;
	line-height: 2.3em;
	border: .3em solid #fff;
	text-align: center;
	font-weight: bold;
	-moz-border-radius: 2em;
	-webkit-border-radius: 2em;
	border-radius: 2em;
}
.gnv_tmp_h4_bg.h4_02 h4 {
    padding: 1px 0 0 27px;
}
.gnv_tmp_h4_bg.h4_02:after {
  content: "";
  display: inline-block;
  border: 5px solid transparent;
  border-left-color: #fff;
  position: absolute;
  left: 8px;
  top: 45%;
  margin-top: 0px;
  width: 0;
  height: 0;
  border-radius: 0;
  background: none;
}
.border_box01 {
    background-color: #f9f8f5;
    border: none;
    border-radius: 10px;
    padding: 30px;
}

/* first */
.ol_number02 li{
position: relative;
    display: block;
    padding: .3em .4em .5em 2.8em;
    margin: 0 0 0.5em 3em;
    background: #f9f8f5;
    color: #454545;
    text-decoration: none;
    -moz-border-radius: .3em;
    -webkit-border-radius: .3em;
    border-radius: .3em;
    width: auto;
    /* height: 17px; */
}
.ol_number02 li:before{
	content: counter(li);
	counter-increment: li;
	position: absolute;
	left: -20px;
	top: 50%;
	margin-top: -1.3em;
	background: #6f99b5;
	color: #fff;
	height: 2em;
	width: 2em;
	line-height: 2.3em;
	border: .3em solid #fff;
	text-align: center;
	font-weight: bold;
	-moz-border-radius: 2em;
	-webkit-border-radius: 2em;
	border-radius: 2em;
}
.gnv_tmp_h4_bg.h4_03 h4 {
    padding: 1px 0 0 27px;
	color: #6F99B5;
}
.gnv_tmp_h4_bg.h4_03:after {
  content: "";
  display: inline-block;
  border: 5px solid transparent;
  border-left-color: #fff;
  position: absolute;
  left: 8px;
  top: 45%;
  margin-top: 0px;
  width: 0;
  height: 0;
  border-radius: 0;
  background: none;
}

.gnv_tmp_h4_bg.h4_03:before {
    content: "";
    position: absolute;
    background: #6f99b5;
    top: 35%;
    left: 0px;
    margin-top: -3px;
    height: 20px;
    width: 20px;
    border-radius: 50%;
}
.under_dl h5 {
	position:relative;
	font-size: 16px;
	font-weight: normal;
	border-bottom: 1px solid #802640;
	padding: 0px 0 5px 35px;
}
.under_dl p {
    padding: 0 0 0 35px;
}
.under_dl h5:before {
	content: "";
	position: absolute;
	background: #802640;
	top: 13%;
	left: 0px;
	margin-top: -3px;
	height: 20px;
	width: 20px;
	border-radius: 50%;
}
.under_dl h5:after {
    content: "";
    position: absolute;
    background: #fff;
    top: 26%;
    left: 4px;
    margin-top: -3px;
    height: 12px;
    width: 12px;
    border-radius: 50%;
}
table.price td.b_06_content {
    text-align: center;
}

table.price th.b_06_item {
    text-align: center;
    color: #802640;
    width:33%;
}

/* 下層タイトル */
#newsList h2.titleBg, #sitemap h2.titleBg, #notfoundBody h2.titleBg {
    background: #f5f5f5;
    border-bottom: none;
    margin-bottom: 20px !important;
    border-radius: 10px;
    font-size: 170%;
    padding: 10px 15px 10px 20px;
    color: #8b2945;
}

#websiteNewsDetail h2.titleBg, #blogBody h3.entry-title  {
	position: relative;
	line-height: 1;
	border-bottom: none;
	font-weight: bold;
	font-size: 150%;
	font-weight: normal;
	padding: 0 0 8px 30px;
	color: #802640;
	border-bottom: 1px dashed #802640;
	margin-bottom: 15px;
}
#websiteNewsDetail h2.titleBg:before, 
#blogBody h3.entry-title:before {
	content: "";
	position: absolute;
	background: #802640;
	top: 18%;
	left: 0px;
	margin-top: -3px;
	height: 20px;
	width: 20px;
	border-radius: 50%;
}
#websiteNewsDetail h2.titleBg:after, 
#blogBody h3.entry-title:after {
    content: "";
    position: absolute;
    background: #fff;
    top: 37%;
    left: 5px;
    margin-top: -3.5px;
    height: 10px;
    width: 10px;
    border-radius: 50%;
}

@media screen and (min-width: 960px) and (max-width: 1100px) {
}

@media screen and (min-width: 601px) and (max-width: 959px) {
}

@media screen and (max-width: 600px) {
 .mb_h3 {
  margin-bottom: 13px!important;
 }
 .mb_h4 {
  margin-bottom: 10px!important;
 }
 .mb_h5 {
  margin-bottom: 8px!important;
 }
 .mb_01 {
  margin-bottom: 20px!important;
 }
 .mb_02 {
  margin-bottom: 50px!important;
 }
 .mb_03 {
  margin-bottom: 55px!important;
 }
 
 .top_box02_01 span.tit, .top_box02_02 span.tit {
	font-size: 140%;
	color: #fff;
	display: table;
	width: 98%;
	font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
	text-align: left;
	padding: 15px 0px 15px 2%;
	line-height: 1em;
	border-radius: 10px;
	margin-bottom: 15px;
	position:relative;
}
.top_box02_01 span.tit:before, .top_box02_02 span.tit:before {
	display:none;
}
.top_box02_01 .box, .top_box02_02 .box {
    margin: 0;
	width:100%
}
.arrow_box01:before {
    width: 0px;
    height: 0;
    border-top: 20px solid #78a6c4;
    border-right: 25px solid transparent;
    border-bottom: 30px solid transparent;
    border-left: 25px solid transparent;
    position: absolute;
    content: "";
    top: -5px;
    left: 45%;
}
.arrow_box02:before {
    width: 0px;
    height: 0;
    border-top: 20px solid #802640;
    border-right: 25px solid transparent;
    border-bottom: 30px solid transparent;
    border-left: 25px solid transparent;
    position: absolute;
    content: "";
    top: -5px;
    left: 45%;
}
.arrow_box01, .arrow_box02 {
 position: relative;
 width: 100%;
}
.top_box01.b_11_2.b_11_2_column2 {
    display: block;
    width: 90%;
    margin: 0 auto;
}
.top_box01.b_11_2.b_11_2_column2 div.column_r {
    width: 40%;
    float: right;
	margin-bottom: 20px;
}
.top_box01.b_11_2.b_11_2_column2 div.column_l {
    width: 40%;
    float: left;
	margin: 0;
	margin-bottom: 20px;
}
.top_box01.b_11_2.b_11_2_column2 div.column_r img, 
.top_box01.b_11_2.b_11_2_column2 div.column_l img {
	margin-bottom:20px;
}
.top_box02_02 .con_r {
    width: 40%!important;
}
.top_box02_02 .con_l {
    width: 60%!important;
}
.b_11_2_in span img {
    display: block;
    float: none;
    width: 100%;
    margin: 0 0 1em 0!important;
}
.gnv_tmp_h2_bg h2 {
    font-size: 30px;
}
table.price tr, table.price th {
    font-size: 90%;
    padding:20px!important;
}
}
@media screen and (max-width: 480px) {
.ol_number li, .ol_number02 li {
    margin: 0 0 0.5em 1em;
	width:75%;
}
.gnv_tmp_h4_bg h4 {
    font-size: 140%;
}
.gnv_tmp_h4_bg:before {
    top: 30%;
}
.gnv_tmp_h4_bg.h4_02:after, .gnv_tmp_h4_bg.h4_03:after {
    top: 35%;
}
.gnv_tmp_h4_bg.h4_03:before {
    margin-top: -5px;
}
.gnv_tmp_h4_bg:after {
    top: 56%;
}
}
@media screen and (max-width: 360px) {
.gnv_tmp_h4_bg:after {
    top: 54%;
}
.under_dl h5:after {
    top: 26%;
}
#websiteNewsDetail h2.titleBg:after, 
#blogBody h3.entry-title:after {
    top: 34%;
}
}

/* webフォント調整（非公開中） */
/*
#blogBody .gnv_tmp_h2_bg h2, 
#blogBody .contentArea h3, 
#blogBody .nav a, #blogBody .nav span, 
#blogBody h2.titleBg, #blogBody #news .newsBt {
    font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-weight: normal;
}

#newsList .gnv_tmp_h2_bg h2, 
#newsList .contentArea h3, 
#newsList .nav a, #newsList .nav span, 
#newsList h2.titleBg, #newsList #news .newsBt {
    font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-weight: normal;
}

#websiteNewsDetail .gnv_tmp_h2_bg h2, 
#websiteNewsDetail .contentArea h3, 
#websiteNewsDetail .nav a, #websiteNewsDetail .nav span, 
#websiteNewsDetail h2.titleBg, #websiteNewsDetail #news .newsBt {
    font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-weight: normal;
}

#notfoundBody .gnv_tmp_h2_bg h2, 
#notfoundBody .contentArea h3, 
#notfoundBody .nav a, #notfoundBody .nav span, 
#notfoundBody h2.titleBg, #notfoundBody #news .newsBt {
    font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-weight: normal;
}　*/


/*add & overwrite 16022*/
.h5_circle {
	position: relative;
	padding-bottom: 20px;
	font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
	font-size: 18px;
}
.h5_circle:before {
	content: "";
	position: absolute;
	background: #802640;
	left: 5px;
	margin-top: 10px;
	height: 8px;
	width: 8px;
	border-radius: 50%;
}

.contentArea {
	padding-bottom: 0px!important;
}

/*case study*/
.case {
	border: 20px solid #78A6C4;
}
.case div {
	border-bottom: 2px solid #78A6C4;
	padding: 26px 0;
	letter-spacing: 3px;
}
.case h6 {
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    font-family: "A-OTF 教科書ICA Pro M", "KyokaICAPro Medium", "メイリオ", Meiryo, sans-serif;
}

.case div.text {
	padding: 35px;
}
.case ul li {
	color: #000;
	margin: 10px 0;
	font-weight: bold;
}
.case ul li:before {
	content: "●";
	color: #78A6C4;
}

/*汎用クラス*/
.p00 { padding: 0 !important; }

@media screen and (max-width: 600px) {
.pdlr {padding:1em 20px 0 !important;}
}