/* webフォント -源ノ角ゴシック- */
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 100;
    src: url('../font/NotoSansCJKjp-Thin.eot'); /* IE9 Compat Modes */
    src: url('../font/NotoSansCJKjp-Thin.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('../font/NotoSansCJKjp-Thin.woff') format('woff'), /* Modern Browsers */
    url('../font/NotoSansCJKjp-Thin.ttf')  format('truetype'); /* Safari, Android, iOS */
}

@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 200;
    src: url('../font/NotoSansCJKjp-Light.eot');
    src: url('../font/NotoSansCJKjp-Light.eot?#iefix') format('embedded-opentype'),
    url('../font/NotoSansCJKjp-Light.woff') format('woff'),
    url('../font/NotoSansCJKjp-Light.ttf')  format('truetype');
}
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 300;
    src: url('../font/NotoSansCJKjp-DemiLight.eot');
    src: url('../font/NotoSansCJKjp-DemiLight.eot?#iefix') format('embedded-opentype'),
    url('../font/NotoSansCJKjp-DemiLight.woff') format('woff'),
    url('../font/NotoSansCJKjp-DemiLight.ttf')  format('truetype');
}
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 400;
    src: url('../font/NotoSansCJKjp-Regular.eot');
    src: url('../font/NotoSansCJKjp-Regular.eot?#iefix') format('embedded-opentype'),
    url('../font/NotoSansCJKjp-Regular.woff') format('woff'),
    url('../font/NotoSansCJKjp-Regular.ttf')  format('truetype');
}
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 500;
    src: url('../font/NotoSansCJKjp-Medium.eot');
    src: url('../font/NotoSansCJKjp-Medium.eot?#iefix') format('embedded-opentype'),
    url('../font/NotoSansCJKjp-Medium.woff') format('woff'),
    url('../font/NotoSansCJKjp-Medium.ttf')  format('truetype');
}
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 700;
    src: url('../font/NotoSansCJKjp-Bold.eot');
    src: url('../font/NotoSansCJKjp-Bold.eot?#iefix') format('embedded-opentype'),
    url('../font/NotoSansCJKjp-Bold.woff') format('woff'),
    url('../font/NotoSansCJKjp-Bold.ttf')  format('truetype');
}
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 900;
    src: url('../font/NotoSansCJKjp-Black.eot');
    src: url('../font/NotoSansCJKjp-Black.eot?#iefix') format('embedded-opentype'),
    url('../font/NotoSansCJKjp-Black.woff') format('woff'),
    url('../font/NotoSansCJKjp-Black.ttf')  format('truetype');
}

body{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:300;}

.noto100{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:100;}
.noto200{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:200;}
.noto300{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:300;}
.noto400{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:400;}
.noto500{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:500;}
.noto700{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:700;}
.noto900{  font-family: 'Noto Sans Japanese', Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif; font-weight:900;}
.fontEnMain { font-family: 'Cabin Condensed', sans-serif;}
.fontEnSub { font-family: 'Roboto', sans-serif;}

.caution{ color:#cc0066;}
.current{ color:#f893bf;}
.blue{color:#6eb0ec;}
.lPink{color:#efbbd1;}
.lBlue{color:#a2caee;}
.lGreen{color:#aada92;}
.lBlueGreen{color:#96e1e2;}

.imgFit img{
	width: 100%;
}

a:link {
	text-decoration: none;
	color: #000;
}

a:visited {
	text-decoration: none;
	color: #000;
}

a:hover {
	text-decoration: underline;
	color: #000;
}

a:active {
	text-decoration: none;
	color: #000;
}

.btn_a {
	width:250px;
	position: relative;
	background-color: #6eb0ec;
	border-radius: 6px;
	color: #fff;
	line-height: 52px;
	-webkit-transition: none;
	transition: none;
	box-shadow: 0 3px 0 #5595cf;
	text-align: center;
	font-size: 18px;
	cursor: pointer;
}

.btn_a a{
	color: #fff;
	text-decoration: none;
	display: block;
}
.btn_a:hover {
	top: 1px;
	background-color: #8ac0f2;
	box-shadow: 0 2px 0 #5595cf;
}
.btn_a:active {
	top: 2px;
	box-shadow: 0 1px 0 #5595cf;
}
#page-top{
	position:fixed;
	bottom: 10px;
	right: 20px;
	opacity: 0.8;
	color: #999;
	font-size: 50px;
	cursor:pointer;
	display: none;
}

/* Header
********************************************/
@media screen and (max-width: 767px) {
.headerPc{
	display:none;
}
}

@media screen and (min-width: 768px) {
.headerSp{
	display:none;
}
}

.headerPc{
	border-top: 5px solid #e60012;
	color: #e60012;
	background: #fff;
	opacity: 0.9;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1;
}

.headerPc .logo{
	padding: 12px 0 12px 0;
}

.headerPc h1{
	background: url("../img/logo.png") no-repeat;
	background-size: 100px;
	display: inline-block;
	line-height: 52px !important;
	padding: 0 0 0 110px !important;
	margin: 0 !important;
	vertical-align: top;
}

.headerPc p{
	line-height: 1;
}

.headerPc .tel{
	font-size: 40px;
	font-weight: 700;
	font-family: 'Roboto', sans-serif;
}

.headerSp{
	position: relative;
}

.headerSp .logoArea {
	padding:10px 0 10px 0;
	text-align: center;
}

.headerSp .logoArea img{
	width: 80px;
}

.headerSp .info{
	background:#7ec35c;
	padding: 5px;
	border-radius: 3px;		/* CSS3 スタンダード用 */
	-webkit-border-radius: 3px;	/* Safari,Google Chrome用 */
	-moz-border-radius: 3px;	/* Firefox用 */
	color:#fff;
	text-align:center;
	margin: 0 0 10px 0;
	font-size: 20px;
}


/* ナビゲーション
********************************************/

/*トップページ用*/
.gnaviPcIndex{
	width: 100%;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	padding: 6px 0;
}

.gnaviPcIndex ul{
	width: 100%;
	display: table;
	table-layout: fixed;
	margin: 0;
	padding: 0;
}

.gnaviPcIndex li{
	display: table-cell;
	border-left: 1px solid #ccc;
	text-align: center;
	font-size: 16px;
	line-height: 40px;
	margin: 0;
}

.gnaviPcIndex li:last-child{
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
}

.gnaviPcIndex li a{
	display: block;
}

.gnaviPcIndex li a{
	display: block;
}

.gnaviPcIndex li a:hover{
	text-decoration: none;
	background: #f5f5f5;
}

/*下層ページ用*/
.gnaviPc{
	/*position: fixed;
	top: 81px;
	left: 0;
	right: 0;*/
	width: 100%;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	background: #fff;
	opacity: 0.9;
	padding: 6px 0;
	margin: 81px 0 0 0;
	/*z-index: 100;*/
}

.gnaviPc ul{
	width: 100%;
	display: table;
	table-layout: fixed;
	margin: 0;
	padding: 0;
}

.gnaviPc li{
	display: table-cell;
	border-left: 1px solid #ccc;
	text-align: center;
	font-size: 16px;
	line-height: 40px;
	margin: 0;
}

.gnaviPc li:last-child{
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
}

.gnaviPc li a{
	display: block;
}

.gnaviPc li a{
	display: block;
}

.gnaviPc li a:hover{
	text-decoration: none;
	background: #f5f5f5;
}

.gnaviSp{
	position: absolute;
	top: 10px;
	left: 10px;
	font-size: 30px;
	color:#999;
}

@media screen and (max-width: 767px) {
.gnaviPcIndex{
	display: none;
}	
.gnaviPc{
	display: none;
}
}

/* パンくず
********************************************/

.pankuzu{
	width: 100%;
	font-size: 12px;
	padding: 14px 0;
	background: #f5f5f5;
}

.pankuzu i{
	font-size: 16px;
}

.pankuzu ul{
	display: table;
	margin: 0;
	padding: 0;
}

.pankuzu li{
	display: table-cell;
	vertical-align: middle;
	margin: 0;
	padding: 0;
}

.pankuzu li:after{
	display: inline-block;
	font-family: FontAwesome;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: "\f0da";
	margin: 0 12px;
}

.pankuzu li:last-child:after{
	display: inline-block;
	font-family: FontAwesome;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: "";
	margin: 0 12px;
}

/* ページ下部お問い合わせエリア
********************************************/
.bottomContactArea{
	width: 100%;
	background: url(../img/bg_bottom_contact.jpg) no-repeat top center;
	background-size: cover;
	text-align: center;
	padding: 50px 0;
}

.bottomContactArea h3{
	text-align: center;
	margin: 0 0 15px 0;
	padding: 0 0 15px 0;
	border-bottom: 1px solid #999;
	font-size: 24px;
}

.bottomContactArea h4{
	text-align: center;
	margin: 0 0 5px 0;
	padding: 0 0 0 0;
	font-size: 60px;
	font-weight: 600;
	font-family: 'Roboto', sans-serif;
	color: #E60012;
}

.bottomContactArea h4:before {
	content: '\f098';
	font-family: FontAwesome;
	position: relative;
	top: -6px;
	margin: 0 12px 0 0;
	font-size: 40px;
	color: #E60012;
}

.bottomContactArea h5{
	text-align: center;
	margin: 0 0 18px 0;
	padding: 0 0 0 0;
	font-size: 18px;
	color: #E60012;
}

.bottomContactArea h6{
	display: inline-block;
	background: #E60012;
	border-radius: 6px;
	text-align: center;
	margin: 0 0 5px 0;
	padding: 12px 20px;
	font-size: 18px;
	color: #fff;
}

.bottomContactArea h6:before {
	content: '\f0e0';
	font-family: FontAwesome;
	position: relative;
	top: 0;
	margin: 0 12px 0 0;
	font-size: 18px;
	color: #fff;
}

@media screen and (max-width: 768px) {
	.bottomContactArea h3{
		font-size: 16px;
	}
	.bottomContactArea h4{
		font-size: 30px;
	}
	.bottomContactArea h4:before {
		top: 0;
		margin: 0 12px 0 0;
		font-size: 25px;
		color: #E60012;
	}
}

/* footer
********************************************/

.footer{
	width: 100%;
	margin: 1px 0 0 0;
	padding: 40px 0 20px 0;
	border-top: 1px solid #ccc;
}

.footer img{
	max-width: 220px;
}

.footer a:hover{
	text-decoration: none;
}

.footer ul{
	padding: 0;
	margin: 0;
}

.footer ul a:hover{
	text-decoration: underline;
}

.footer li{
	text-decoration: none;
	list-style: none;
	padding: 0 0 0 0;
	margin: 0 0 25px 16px;
	text-indent: -9px;
}

.footer li:before{
    display: inline-block;
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    content: "\f138";
    margin: 0 5px 0 0;
    color: #999;
}

@media screen and (max-width: 991px) {
.footer{
	width: 100%;
	margin: 0 0 0 0;
	padding: 0 0 0 0;
	border-top: 1px solid #ccc;
}
.footer li {
	list-style:none;
	padding: 20px 0 20px 10px;
	margin: 0;
	text-indent: 0;
	border-bottom: 1px solid #ddd;
}
.footer li a{
	display: inline-block;
}
.footer h3{
	display: none;
}
.footer .container{
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}
.footer .row{
	margin: 0 !important;
	padding: 0 !important;
}
.footer .col-md-2{
	margin: 0 !important;
	padding: 0 !important;
}
}

.copyright{
	width: 100%;
	background: #000;
	padding: 15px 0 15px 0;
	text-align: center;
	font-size: 12px;
	color: #fff;
}

/* Contents
********************************************/

.ttl {
	position: relative;
	width: 100%;
	text-align:center;
	padding: 18px 0 18px 0;
}
.ttl h2{
	margin: 0;
	padding: 0;
}
.subTtl {
	position: relative;
	width: 100%;
	text-align:center;
	padding: 15px 0 15px 0;
}
.subTtlA {
	position: relative;
	width: 100%;
	text-align:center;
	padding: 5px 0 15px 0;
}
.subTtlB {
	position: relative;
	width: 100%;
	text-align:center;
	padding: 5px 0 15px 0;
}
.mainBlock{
	padding: 0 15px 0 15px;
}
.mainBlockSmall{
	padding: 0 5px 0 5px;
}
@media screen and (min-width: 768px) {
.subTtl h3{
	margin: 0;
	padding: 0;
	font-size:30px;
}
.subTtlA h3{
	margin: 0;
	padding: 0;
	font-size:30px;
	color:#fff;
}
.subTtlB h3{
	margin: 0;
	padding: 0;
	font-size:30px;
	color:#fff;
}
.mainBlock .icon{
	text-align: center;
	padding: 70px 0 30px 0;
	margin: 0;
}
.mainBlock .text{
	text-align: center;
	font-size: 18px;
	line-height: 40px;
	padding: 0 0 60px 0;
}
.mainBlock .textLeft{
	text-align: left;
	font-size: 18px;
	line-height: 40px;
	padding: 0 0 60px 0;
}
.mainBlock .textOther{
	text-align: center;
	font-size: 18px;
	line-height: 40px;
	padding: 70px 0 60px 0;
}
.mainBlock h3{
	text-align: center;
	padding: 0 0 10px 0;
	margin: 0;
	font-size: 24px;
	line-height: 40px;
	 font-family: 'Noto Sans Japanese', serif;
	 font-weight:200;
}
.mainBlockSmall .icon{
	text-align: center;
	padding: 50px 0 30px 0;
	margin: 0;
}
.mainBlockSmall .text{
	text-align: center;
	font-size: 18px;
	line-height: 40px;
	padding: 0 0 20px 0;
	margin: 0;
}
.mainBlockSmall .textLeft{
	text-align: left;
	font-size: 18px;
	line-height: 40px;
	padding: 0 0 60px 0;
}
.mainBlockSmall h3{
	text-align: center;
	padding: 0 0 10px 0;
	margin: 0;
	font-size: 24px;
	line-height: 40px;
	 font-family: 'Noto Sans Japanese', serif;
	 font-weight:200;
}
}
@media screen and (max-width: 768px) {
.subTtl h3{
	margin: 0;
	padding: 0;
	font-size:24px;
}
.subTtlA h3{
	margin: 0;
	padding: 0;
	font-size:24px;
	color:#fff;
}
.subTtlB h3{
	margin: 0;
	padding: 0;
	font-size:24px;
	color:#fff;
}
.mainBlock .icon{
	text-align:center;
	padding: 40px 0 20px 0;
	margin: 0;
}
.mainBlock .text{
	text-align: center;
	font-size: 16px;
	line-height: 24px;
	padding: 0 0 30px 0;
}
.mainBlock .textLeft{
	text-align: left;
	font-size: 16px;
	line-height: 24px;
	padding: 0 0 30px 0;
}
.mainBlock .textOther{
	text-align: center;
	font-size: 16px;
	line-height: 24px;
	padding: 30px 0 30px 0;
}
.mainBlock h3{
	text-align: center;
	padding: 0 0 10px 0;
	margin: 0;
	font-size: 18px;
	line-height: 24px;
	 font-family: 'Noto Sans Japanese', serif;
	 font-weight:200;
}
.mainBlockSmall .icon{
	text-align:center;
	padding: 30px 0 20px 0;
	margin: 0;
}
.mainBlockSmall .text{
	text-align: left;
	font-size: 16px;
	line-height: 24px;
	padding: 0 0 15px 0;
	margin: 0;
}
.mainBlockSmall .textLeft{
	text-align: left;
	font-size: 16px;
	line-height: 24px;
	padding: 0 0 30px 0;
}
.mainBlockSmall h3{
	text-align: left;
	padding: 0 0 10px 0;
	margin: 0;
	font-size: 18px;
	line-height: 24px;
	 font-family: 'Noto Sans Japanese', serif;
	 font-weight:200;
}
}
.subTtl:before {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 50%;
  margin-left: -20px;
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
}
.subTtlA:before {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 50%;
  margin-left: -20px;
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
}
.subTtlB:before {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 50%;
  margin-left: -20px;
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
}

.contentsBlock{
	padding: 40px 0 60px 0;
}