@charset "utf-8";
/**********************************

 clumn style

***********************************/
.containerFluid {
	padding-left: 24px;
	padding-right: 24px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.container {
	width: 1000px;
	max-width: 100%;
	margin: 0 auto;
}

@media screen and (max-width:767px){
	.containerFluid {
		padding-left: 15px;
		padding-right: 15px;
	}
}

.pageColumn {
	width:100%;
	height: auto;
	background-image:url(../img/bg_column.jpg);
	background-repeat: no-repeat;
	background-size: 100% 200px;
	background-position: top left;
	background-color:#fffaf6;
	overflow:hidden;
}
@media screen and (min-width:768px){
	.pageColumn {
		background-size: 100% 450px;
	}
}

.pageColumn_inner {
	height: auto;
	margin:70px 10px;
	background-color:#fff;
	padding:20px 15px 0;
	color:#333;
}
@media screen and (min-width: 768px) {
	.pageColumn_inner {
		margin:70px 10px;
		padding:40px 20px;
	}
}

@media screen and (min-width: 1024px) {
	.pageColumn_inner {
		max-width: 1000px;
		margin:70px auto;
		padding:80px 75px;
	}
}


.pageColumn_inner h1{
	font-size:23px;
	line-height:1.4em;
	font-weight:bold;
	display:block;
	padding:0;
}
@media screen and (min-width: 768px) {
	.pageColumn_inner h1{
		font-size:42px;
	}
}
.update{
	margin: 0 0 40px;
	padding: 20px 0 0;
	text-align: right;
	font-size: 82%;
	color: #666;
}

.boxColumn{
}

.boxColumn p{
	margin-bottom:30px;
	padding-left:15px;
	padding-right:15px;
}
@media screen and (min-width: 768px) {
	.boxColumn p{
		padding-left:5px;
		padding-right:5px;
	}
}

/* =====================
  目次
===================== */
.toc{
	clear:both;
	margin: 30px auto 60px auto;
	padding: 1em;
	font-size: 1.2rem;
    border: dotted #1e366a 1px;
	width: 94%;
}
@media screen and (min-width: 768px) {
	.toc{
		margin: 60px 0 80px 50px;
		padding: 2em 3em;
		font-size: 1rem;
		width: 70%;
	}
}
.toc h2{
	font-size:120%;
	font-weight:bold;
	text-align:center;
	line-height:3em;
}
.toc ol{
	counter-reset: hl_count;
	list-style: none;
}
.toc li{
	counter-increment: hl_count;
	padding:0.25em;
}
.toc li:before{
	content: counters(hl_count, "-")
}

/*-- base style --*/
.toc ol ol,
.toc li ol li{
	margin-top: .5em;
}

.toc li:before{
	margin-right: .8em;
	padding: .1em .5em;
	text-align: center;
	border-radius: 4px;
	font-family: 'Merienda', cursive;
}
.toc li{
	padding-left: 1.4em;
	text-indent: -1.7em;
}
.toc li ol li{
	padding-left: 1em;
	text-indent: -3em;
}
.toc li ol li ol li{
	padding-left: 1em;
	text-indent: -4em;
}

.toc li ol{
	margin: 0 0 0.5em 1.9em;
}
.toc li ol li ol{
	margin-left: 3em;
}

.toc span:after{
	content: ' ';
	display: block;
	height: .6em;
}

/*-- font-color & background --*/
.toc li:before{
	color: #fff;
	background-color: #18933B;
	font-size: 0.6rem;
}

/*-- font-size --*/
.toc li:before{
	font-size: 0.8rem;
}
.toc li{
	font-size: 1.0rem;
	font-weight: bold;
}
.toc li ol li{
	font-size: 0.9rem;
	font-weight: normal;
}
.toc li a{ color:#333; }



/* =====================
  ボックス全体
===================== */
.boxColumn section{
	margin:0 auto 4em;
}

.boxColumn section h2{
	font-size:20px;
	font-weight: normal;
	background-color: #18933b;
	color:#FFF;
	padding: 20px 30px 20px 30px;
	line-height:1.4em;
	margin-bottom:30px;
}
@media screen and (min-width: 768px) {
	.boxColumn section h2{
		padding: 20px 30px 20px 40px;
		font-size:26px;
		line-height:1.2em;
	}
}
.boxColumn section h3{
	font-size:17px;
	font-weight:bold;
	position: relative;
	background: #eef1f2;
	padding: 15px 10px 15px 30px;
	margin-bottom:30px;
	line-height:1.4em;
}
.boxColumn section h3:before{
	position: absolute;
	top: 25%;
	left: 10px;
	width: 6px;
	height: 50%;
	content: '';
	opacity: .2;
	-ms-filter: "alpha(opacity=20)";
	border-radius: 3px;
	background: #5f7276;
}
@media screen and (min-width: 768px) {
	.boxColumn section h3{
		font-size:22px;
		padding: 15px 20px 15px 40px;
	}
	.boxColumn section h3:before{
		left: 20px;
	}
}

.boxColumn section h4 {
    font-size: 18px;
    font-weight: bold;
    position: relative;
    margin-bottom: 15px;
    padding-left: 24px;
    line-height: 1;
	padding-top:0.25em;
	padding-bottom:0.25em;
    border-left: #17933b solid 5px;
	margin-left:5px;
}
@media screen and (min-width: 768px) {
	.boxColumn section h4 {}
}

.boxColumn section h5 {
    font-size: 18px;
    font-weight: bold;
	color: #17933b;
	border-bottom: #17933b solid 2px;
	margin-bottom: 15px;
	line-height: 2em;
	padding-left: 4px;
}
@media screen and (min-width: 768px) {
	.boxColumn section h5 {}
}

.boxColumn section h6 {
    font-size: 16px;
    font-weight: bold;
	padding-left:4px;
}

@media screen and (min-width: 768px) {
	.boxColumn section h6 {}
}

.column_visual{
	margin:2em auto;
	text-align:center;
}
.column_visual figure{ margin:auto; text-align:center; }



/* =====================
  box
===================== */
.imgbox_fl{
	margin:0;
	height: auto;
	width:100%;
}
.imgbox_fl:after {
	clear: both;
	content:".";
	display: block;
	height: 0;
	visibility: hidden;
}
.imgbox_fl figure.flImgL, .imgbox_fl figure.flImgR {
	width: 100%;
	margin:0;
	padding:0;
}
.imgbox_fl figure.flImgL { float: none; margin-bottom:20px; display:block; text-align:center; }
.imgbox_fl figure.flImgR { float: none; margin-bottom:20px; display:block; text-align:center; }

.imgbox_fl p {
	float:left;
	margin-bottom:20px;
	text-align:left;
	width:100%;
	padding:0;
}

@media screen and (min-width: 768px) {
	.imgbox_fl figure.flImgL, .imgbox_fl figure.flImgR {
		width: 45%;
	}
	.imgbox_fl figure.flImgL { float:left; }
	.imgbox_fl figure.flImgR { float:right; }
	.imgbox_fl p {
		float:left;
		text-align:left;
		width:52%;
		padding:0;
	}
}


/* =====================
  リスト
===================== */
.listStyle01 {
	list-style:none;
	padding: 0;
	display:inline-block;
	margin-left:5px;
}
.listStyle01 li{
	display:block;
	position:relative;
	margin:0;
	padding:.2em 0 .2em 1.5em;
	line-height:1.9em;
}
.listStyle01 li:before {
	content:  "";
	width:  10px;
	height:  10px;
	display:  inline-block;
	background-color: #F44336;
	border-radius:  50%;
	position: absolute;
	top: 13px;
	left:2px;
	margin-right: 5px;
}



.list_check {
	list-style:none;
	padding: 0;
	display:inline-block;
	margin:auto;
}
.list_check li{
	display:block;
	position:relative;
	margin:0 0 5px;
	padding:.2em 0 .2em 2em;
	line-height:1.9em;
}
.list_check li:before {
	display:  inline-block;
	position: absolute;
	content: "\f046";
	font-family: FontAwesome;
	font-size:22px;
	left:2px;
}

.boxcheck{
    padding: 2em;
    background: #FFF;
}
@media screen and (min-width: 768px) {
	.boxcheck{
		padding: 2em 4em;
	}
}



/* =====================
  border style
===================== */

/*-- ドット --*/
.bd-style1{
    border: dotted 1px #5d627b;
}

/*-- 角丸 --*/
.bd-radius10{
    border-radius: 10px;
}


/* =====================
  font-color style
===================== */

/*-- 青 --*/
.fc-blue{
    color: #6091d3;
}




/* =====================
  引用
===================== */
blockquote {
    position: relative;
    padding: 15px 15px 5px 70px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    font-style: italic;
    background: #f5f5f5;
    color: #555;
}
blockquote:before{
    display: inline-block;
    position: absolute;
    top: 18px;
    left: 15px;
    content: "\f10d";
    font-family: FontAwesome;
    color: #cfcfcf;
    font-size: 30px;
    line-height: 1;
    font-weight: 900;
}
blockquote p {
    padding: 0;
    margin: 6px 0;
    line-height: 1.7;
}
blockquote p a{ color: #888888 !important;}


/* =====================
  マーカースタイル
===================== */
.marker_yellow{
	background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, rgba(255,247,150,0.8)));
	background: linear-gradient(transparent 50%, rgba(255,247,150,0.8) 50%);
	font-weight: bold;
}

.marker_orange{
	background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, rgba(255,190,128,0.8)));
	background: linear-gradient(transparent 50%, rgba(255,190,128,0.8) 50%);
	font-weight: bold;
}



/* =====================
  アンカーズレ回避
===================== */
section.anchor {
    display: block;
	margin-top:-100px;
	padding-top:100px;
}

/* =====================
  お問い合わせ（汎用版）
===================== */
.boxColumn .i-contectBox {
    width: 100%;
    /*height: 250px;*/
    border : 1px solid #a9a9a9;
	margin: 0 auto 60px;
}

.boxColumn .i-contectBox h4{
	margin:0;
	padding:1em;
	display:block;
	text-align:center;
	font-weight:bold;
	background-color:#EEEEEE;
	color: #2B2B2B;
	border-left: none !important;
}
.boxColumn .i-contectBox_inner {
    padding: 20px 5px 10px;
    text-align: left;
}
.boxColumn .i-contectBox_inner .table-cell {
    display: table;
    margin: auto;
}

.contectBox_btnInfo {
	display: inline-block;
	text-align: center;
	text-decoration: none;
	color: #fff;
	background:#668ad8;
	border-bottom:4px solid #ba7202;
	border-radius: 4px;
	-webkit-transition: .0s;
	transition: .0s;
	line-height:1em;
	font-weight:bold;
	position:relative;
}
.i-contectBox_inner li a{ color: #FFF;}
.contectBox_btnInfo:hover {
	 cursor: pointer;
	 text-decoration: none;
	 background:#3a6bd5;
	 -webkit-transform: translate3d(0, 4px, 0);
	         transform: translate3d(0, 4px, 0);
	 -webkit-transition: .0s;
	 transition: .0s;
	 color:#FFF;
}
.contectBox_btnInfo:before {
	content: "\f0e0";
	display: block;
	line-height: 1;
	font-family: FontAwesome;
	font-weight: normal;
	position: absolute;
	top: 50%;
	left: 40px;
	margin-top: -14px;
}


@media screen and (min-width: 320px) {
.i-contectBox h4{
	font-size:100%;
}
.i-contectBox_inner li {
    padding: 5px 0;
    margin: 10px auto;
	width: 100%;
	display:block;
}
.i-contectBox_inner .table-cell li {
    display: block;
    text-align: center;
}

.i-contectBox_inner li.contectBox_l{ text-align:center; width:100%; padding-left:0;}
.i-contectBox_inner li.contectBox_r{ text-align: center; width:100%;}

.contectBox_btnInfo {
	padding:1em 1em 1em 2em;
	width: 100%;
	font-size:100%;
}
.contectBox_btnInfo:before {
	left: 20px;
	font-size:20px;
	margin-top: -10px;
}
}

@media screen and (min-width: 768px) {
.i-contectBox h4{
	font-size:140% !important;
}
.i-contectBox_inner li {
	padding: 0 0 10px;
	margin: 10px;
	vertical-align:middle;
}
.i-contectBox_inner .table-cell li {
    display: table-cell;
    text-align: center;
}
.i-contectBox_inner li.contectBox_l{ text-align:left; width:420px; padding-left:30px;}
.i-contectBox_inner li.contectBox_r{ text-align: center; width:540px;}

.contectBox_btnInfo {
	width: 80%;
	padding: 1.25em 0.5em 1em 2em;
	font-size:110%;
}
	@media (min-width: 768px) and (max-width: 800px) {
	.contectBox_btnInfo {
		padding: 1.25em 0.5em 1em 2.8em;
		font-size:100%;
	}
	}
.contectBox_btnInfo:before {
	left: 40px;
	font-size: 26px;
	margin-top: -14px;
}
	@media (min-width: 768px) and (max-width: 800px) {
	.contectBox_btnInfo:before {
		left: 30px;
		font-size: 22px;
		margin-top: -14px;
	}
	}

}

/* =====================
  ボタン
===================== */
.info-btn {
	padding: 22px 20px;
	background-color: #f3f3f3;
    margin: 0 auto;
	text-align:center;
}
.btn-fit {
    display: block;
    width: 100%;
}
.btn {
	margin:auto;
    position: relative;
    display: inline-block;
    padding: 15px 15px 11px;
    color: #181818 !important;
	text-decoration:none;
    border: 1px solid #181818;
    border-radius: 4px;
    -webkit-box-shadow: 0 4px 0 0 rgba(0,0,0,.11);
            box-shadow: 0 4px 0 0 rgba(0,0,0,.11);
    text-align: center;
    background-color: #fff;
    cursor: pointer;
    -webkit-transition: background-color .25s ease,color .25s ease;
    transition: background-color .25s ease,color .25s ease;
}
.btn:hover{
	background-color: #4d4d4d;
	color:#FFF !important;
}
.single-info-btn {
    max-width: 480px;
    margin: 0 auto;
}
.btn-text {
	text-align:left;
    padding: 0 10px;
    font-size: 16px;
    letter-spacing: .07em;
    line-height: 1.75;
	font-weight:bold;
}
@media screen and (min-width: 768px) {
	.btn-text {
		text-align: center;
		padding: 0 40px;
	}
}

.btn-icon::before {
    display: inline-block;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
}
.icon-arrow::before {
	content: "\f178";
	line-height: 1;
	font-family: FontAwesome;
}


/* =====================
  h4
===================== */
.h4Style01{
	font-size:108%;
	font-weight:bold;
	border-bottom:solid 1px #333333;
	line-height:normal;
	padding-bottom:10px;
	text-indent:1em;
	display:block;
	margin-bottom:20px;
}



/* =====================
  ol
===================== */
ol.ol_style-num {
	counter-reset:number; /*数字をリセット*/
	list-style-type: none!important; /*数字を一旦消す*/
	padding: 0em 1em 0em 1em;	
}
ol.ol_style-num li {
	position: relative;
	line-height: 1.2em;
	padding: 0.2em 0 0.2em 1.5em;
}
ol.ol_style-num li p{ font-size:16px; padding:0; margin:0; }

ol.ol_style-num li:before{
	/* 以下数字をつける */
	position: absolute;
	counter-increment: number;
	content: counter(number);
	/*以下数字のデザイン変える*/
	display:inline-block;
	background: #444444;
	color: white;
	font-family: 'Avenir','Arial Black','Arial',sans-serif;
	font-weight:bold;
	font-size: 12px;
	border-radius: 50%;
	left: -1em;
	width: 22px;
	height: 22px;
	line-height: 22px;
	text-align: center;
	/*以下 上下中央寄せのため*/
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
@media screen and (max-width: 480px) {
	ol.ol_style-num li:before{
		top: 30%;
	}
}
@media screen and (min-width: 481px) {
	ol.ol_style-num li:before{
		top: 50%;
	}
}


ol.ol_boxStyle1{
	counter-reset:list;
	list-style-type:none;
	padding: 0px;
}

ol.ol_boxStyle1 li{
	position:relative;
	line-height: 20px;
	margin: 10px 0 40px 40px;
	padding-left: 0px;
	font-weight: bold;
}
  
ol.ol_boxStyle1 li:before{
	counter-increment: list;
	content: counter(list);
	position: absolute;
	left: -35px;
	width: 20px;
	height: 20px;
	background: #18933B;
	text-align: center;
	color: #fff;
	font-size:12px;
	top: 15px;
	-moz-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

ol.ol_boxStyle1 p{ margin-bottom:10px; padding:0; }
ol.ol_boxStyle1 span{
	font-weight:normal;
	display:block;
	position:relative;
	margin:0 0 0.8em 0;
	padding:0.2em 0 0.2em 1.4em;
	line-height:1;
}

ol.ol_boxStyle1 span:after, ol.ol_boxStyle1 span:before {
	content:''; 
	display:block; 
	position:absolute; 
	top:6px; 
	left:9px; 
	height:11px; 
	width:3px; 
	background:#aaa; 
	border-radius:10px;
	transform:rotate(45deg);
	-webkit-transform:rotate(45deg);
	-o-transform:rotate(45deg);
}
ol.ol_boxStyle1 span:before{
	top:10px; 
	left:3px;
	height:8px; 
	transform:rotate(-45deg);
	-webkit-transform:rotate(-45deg);
	-o-transform:rotate(-45deg);
}

ol.ol_boxStyle1 span.noStyle{ padding:0.2em 0 0.2em 0; }
	
ol.ol_boxStyle1 span.noStyle:after,
ol.ol_boxStyle1 span.noStyle:before
{
	background:none;
}



/* Section - コラム
======================================================*/
.column_col_4{
	width: 100%;
	display: flex;
	display: -ms-flexbox; /* IE10 */
	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /* IE10 */
	justify-content: space-between;
}
.column_col_4:after{
	content:"";
	display:block;
	width: 31%;
	height:0;
}
.column_col_4 > div{
	width: 31%;
	padding: 0;
	margin:0 0 2%;
	height:auto;
}

@media screen and (max-width: 768px) {
	.column_col_4 > div{
		width: 50%;
		float:none;
		margin:0 auto;
	}
}
	@media screen and (max-width: 480px) {
		.column_col_4 > div{
			width: 100%;
		}
	}

.bgshadow_colum{
	-webkit-box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.1);
	-moz-box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.1);
	box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.1);
	background-color:#FFF;
	margin: 8% auto 5%;
	padding:0;
	min-height:220px;
}

.bgshadow_colum p{ text-align:left; padding:1em 1em 0.5em; margin-bottom:0; font-size:13px; line-height:1.6em; }
.bgshadow_colum span{ display: block; font-size: 11px; color: #AAA; text-align:left; padding:1em 0 0; }
.bgshadow_colum a{ 
	color:#1b1b1b;
	text-decoration:none;
	font-weight:bold;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;	
	
}
.bgshadow_colum a:hover{
	filter: alpha(opacity=70);
	opacity: .7;
	text-decoration:underline;
}

.img_wrap{
	width:100%;
	max-width: 360px;
	max-height: 240px;
	height:auto;
	margin: 0 auto;
	overflow: hidden;
	cursor: pointer;
}
.img_wrap img{ width:100%; height:100%;}
@media screen and (max-width: 768px) {
	.img_wrap img{ margin-top:0px; }
}






.info_wrap {

}

.info_wrap ul {
	margin: 20px -20px -40px;
}

.info_wrap ul li {
	width: 100%;
	padding: 20px;
	margin-bottom: 20px;
}

.info_wrap ul li .inner {
	height: 100%;
	padding: 40px 50px 30px;
	/*background-color: #f6f3f1;*/
	background-color: #fff;
	border: 1px solid #eee;
	position: relative;
}


.info_wrap ul li .inner .num {
	background-color: #ef8337;
	position: absolute;
	top: -20px;
	left: 20px;
}

.info_wrap ul li .inner .num:before {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 11px;
	border-color: transparent transparent transparent #ef8437;
	position: absolute;
	bottom: -11px;
	left: 0;
}

.info_wrap ul li .inner .num p {
	padding: 1px 20px;
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	text-shadow: 0px 2px 0px rgba(0, 0, 0, 0.35);
}

.info_wrap ul li .inner .ttl {
	color: #ef8337;
	font-size: 22px;
	font-weight: bold;
	text-align: left;
	line-height: 1.5;
}

@media screen and (max-width: 768px) {
.info_wrap ul li .inner .ttl {
	font-size: 18px;
}
}
.info_wrap .inner .txtArea {
	width:96%;
}