﻿@import url("add.css");
@import url("print.css") print;
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
main, article, aside, dialog, figure, footer, header,button,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;

	font-size: 1em;
}

* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

html {
	font-size: 62.5%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

body {
	-webkit-text-size-adjust: 100%;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
	display: block;
}

audio, canvas, progress, video {
	display: inline-block;
	vertical-align: baseline;
}

audio:not([controls]) {
	display: none;
	height: 0;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: bold;
}

table,
input, select, option {
	line-height: 1.1;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

ins {
	text-decoration: none;
}

del {
	text-decoration: line-through;
}

button, input:not([type="text"]), select {
	margin: 0;
	cursor: pointer;
}

button, input, select {
	overflow: visible;
}

button, select {
	text-transform: none;
}

img {
	vertical-align: top;
}

a {
	background-color: transparent;
	text-decoration: none;
}

a:active,
a:hover {
	outline-width: 0;
	text-decoration: underline;
}

/*SPへ切り替え*/
@media only screen and (max-width: 1012px) {
	img {
		max-width: 100%;
		height: auto;
	}
	.pc{display:none; }
	.sp { display:inline; }
}

/*------------------------------------------------------------
	clearfix
------------------------------------------------------------*/
	* html .clearfix {
		zoom: 1;
	}

	*+html .clearfix {
		zoom: 1;
	}

.clearfix:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}

/*------------------------------------------------------------
	表示非表示
------------------------------------------------------------*/
/*PCへ切り替え*/
@media only screen and (min-width: 1013px) {
	.is_hide_pc {
		display: none !important;
	}
}

/*SPへ切り替え*/
@media only screen and (max-width: 1012px) {
	.is_hide_sp {
		display: none !important;
	}
}

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1012px;
	line-height: 1.5;
	text-align: center;
	-webkit-text-size-adjust: none;
	text-size-adjust: none;
}

@media only screen and (max-width: 1012px) {
	body {
		min-width: 320px;
	}
}

#container {
	text-align: left;
}

#main {
	margin: 0 auto 80px;
	width: 960px;
}

@media only screen and (max-width: 1012px) {
	#main {
		margin-bottom: 0;
		width: auto;
	}
}

	* html #main {
		zoom: 1;
	}

	*+html #main {
		zoom: 1;
	}

#main:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}

/*#xp1 {
	position: absolute !important;
	top: 50%;
	left: 50%;

	-webkit-transform: translate(-50%, -50%);
	   -moz-transform: translate(-50%, -50%);
	    -ms-transform: translate(-50%, -50%);
	        transform: translate(-50%, -50%);
}-/

/*------------------------------------------------------------
	SP戻るボタン
------------------------------------------------------------*/
.return_area {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	padding: 20px;
	height: 145px;
	background-color: #FFF;
	display: none;
}

.return_area .sp_return_btn {
	padding-top: 30px;
	padding-bottom: 30px;
	background: -moz-linear-gradient(top,  #ffffff 0%, #f4f4f4 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(top,  #ffffff 0%,#f4f4f4 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to bottom,  #ffffff 0%,#f4f4f4 100%);

	border: 1px solid #CCC;
	-webkit-border-radius: 5px;
	        border-radius: 5px;
	-webkit-box-shadow: 0 0 1px #fff inline;
	        box-shadow: 0 0 1px #fff inline;
	display: block;
	font-size: 28px;
	font-weight: bold;
}

.return_area .sp_return_btn:hover {
	text-decoration: none;
}

.return_area .sp_return_btn .icon {
	padding-left: 40px;
	position: relative;
	font-size: 28px;
}
.return_area .sp_return_btn .icon:before {
	margin-top: -16px;
	width: 18px;
	height: 32px;
	background: url(/images/common/icon/sp_icon.png) no-repeat;
	-webkit-background-size: contain;
	     -o-background-size: contain;
	        background-size: contain;
	position: absolute;
	top: 50%;
	left: 0;
	content: "";
}

.touch_device.pc .return_area {
	display: block;
}

.tablet.touch_device.pc .return_area {
	display: none;
}

@media only screen and (max-width: 1012px) {
	.return_area {
		display: none;
	}
}

/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/

/*IE 9 message*/
div#ie9message{
	background:#fefef5;
	color:#000000!important;
	font-size:1.3rem;
	text-align: center;
	width:100%;
	padding:5px 0px 5px 0px;
	margin: 0 auto;
	border:3px solid #ecbf9d;
	}

@media only screen and (max-width: 1012px) {
	div#ie9message{
		padding:5px 65px 5px 15px;
		text-align: left;
	}
}
/*IE 9 message*/

#header {
	padding-bottom: 94px;
	*padding-bottom: 60px;
}

#header .hInner {
	margin: 0 auto;
	padding: 15px 0;
	width: 930px;
	height: 90px;
	position: relative;
}

#header .lBox {
	padding-top: 20px;
	position: absolute;
	top: 0;
	left: 0;
}

#header .logo {
	padding-left: 4px;
	display: inline-block;
	vertical-align: middle;
	*display:inline;
	*zoom:1;
}

#header .lBox p {
	margin-left: 15px;
	display: inline-block;
	font-size: 1.1rem;
	vertical-align: middle;
	*display:inline;
	*zoom:1;
}

#header .rBox {
	float: right;
	position:absolute;
	top:10px;
	left:290px;
}

#header .rBox .topBox {
	margin-bottom: 10px;
	text-align: right;
	float:right;
}

#header .rBox .fontChange {
	padding: 0 10px 0 50px;
	display: inline-block;
	vertical-align: middle;
	width: 214px;
	*display:inline;
	*zoom:1;
}

#header .rBox .fontChange li {
	float: left;
	width: 26px;
}

#header .rBox .fontChange .ttl {
	margin-top: 4px;
	width: 75px;
	font-size: 11px;
	text-align: left;
}

#header .rBox .fontChange li a {
	padding: 4px 0;
	display: block;
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	border-radius: 2px 0 0 2px;
}

#header .rBox .fontChange .on,
#header .rBox .fontChange li a:hover {
	text-decoration: none;
}

#header .rBox .fontChange .fm a {
	border-radius: 0;
}

#header .rBox .fontChange .fl a {
	border-radius: 0 2px 2px 0;
}

#header .rBox .hLink {
	display: inline-block;
	vertical-align: middle;
	width: 153px;
	*display:inline;
	*zoom:1;
}

#header .rBox .hLink a {
	display: block;
}

#header .rBox .hTxt {
	margin: 3px 0 0 15px;
	display: inline-block;
	vertical-align: middle;
	*display:inline;
	*zoom:1;
}

#header .rBox .otherNavi {
	float: left;
	width: 475px;
	text-align: right;
}

#header .rBox .otherNavi li {
	display: inline;
	font-size: 1.2rem;
}

#header .rBox .otherNavi li a {
	margin: 0 16px;
}

#siteSearch {
	margin-top: -5px;
	float: right;
	overflow: hidden;
	zoom: 1;
	position: relative;
	width: 160px;
	-webkit-border-radius: 2px!important;
	-moz-border-radius: 2px!important;
	border-radius: 2px!important;
	background-color: #eee!important;
}

#siteSearch:before {
	display: none;
	/* アイコンを一旦リセット
	margin-top: -8px;
	width: 17px;
	height: 16px;
	background: url(/images/common/icon/icon01.png) no-repeat left top;
	background-size: 17px 16px;
	position: absolute;
	top: 50%;
	right: 7px;

	content: "";*/
}

#siteSearch .gsc-control-cse {
	padding: 0 !important;
	/*width: 130px !important;*/
	width: 100%;/* ★ 2018/03/16 ★ */
	background-color: transparent!important;
	border: none!important;
}

#siteSearch .gsc-search-box-tools .gsc-search-box .gsc-input {
	padding: 0 5px !important;
	height: 26px !important;
	background: none !important;
	background-color: none!important;
	box-shadow: none!important;
	font-size: 12px!important;
	-webkit-box-sizing: border-box!important;
	-moz-box-sizing: border-box!important;
	box-sizing: border-box!important;
}

/* 検索ボタン */
#siteSearch input.gsc-search-button, input.gsc-search-button:hover, input.gsc-search-button:focus {
	margin: 0 !important;
	width: 20px!important;
	cursor: pointer!important;
}
#siteSearch input.gsc-search-button {
	position: absolute!important;
	margin-top: -12px!important;
	top: 50%;
	right: 5px!important;
	width: 20px!important;
	height: 24px!important;
	padding: 0 12px;
	border: none!important;
	border-radius: 0!important;
	background: transparent url(/images/common/icon/icon01.png) no-repeat center center!important;
	-webkit-background-size: 17px 16px!important;
	-moz-background-size: 17px 16px!important;
	background-size: 17px 16px!important;
	}

/* 検索欄 */
#siteSearch .gsc-input-box {
	border: none !important;
	background: none !important;
}

#siteSearch .gsc-search-box .gsc-input,
#siteSearch .gsc-input-box-hover {
	box-shadow: none!important;
	}
#siteSearch .gsc-search-box .gsc-input:focus,
#siteSearch .gsc-input-box-hover:focus {
	outline: none!important;
	-webkit-border-radius: 2px!important;
	-moz-border-radius: 2px!important;
	border-radius: 2px!important;
	border: 2px solid #9ec0f7!important;
	}

#siteSearch td.gsc-search-button {
	/*display: block!important;*//* ★ 2018/03/16 ★ */
}

#siteSearch form.gsc-search-box,
#siteSearch table.gsc-search-box {
	margin: 0 !important;
}

#siteSearch .gsib_a {
	padding: 0 !important;
}

#header .spBox {
	display: none;
}

/* 結果をクリアボタン */
.gsc-search-box-tools .gsc-clear-button {
	display: none!important;
	/*position: absolute!important;
	top: 3px!important;
	right: 18px!important;*/
	}

/* 検索ボタン調整 ★ 2018/03/16 ★ */
.cse .gsc-search-button-v2, .gsc-search-button-v2 {
	padding: 6px 10px!important;
	border: none!important;
}


@media only screen and (max-width: 1012px) {
	#header {
		padding-bottom: 0;
	}

	#header .hInner {
		padding: 0;
		width: auto;
		height: auto;
	}

	#header .lBox {
		margin: 10px 0 5px 9px;
		padding-top: 0;
		width: 140px;
		float: left;
		position: static;
	}

	#header .logo {
		padding-bottom: 4px;
		float: none;
		display: block;
	}

	#header .logo img {
		width: 131px;
		height: auto;
	}

	#header .lBox p {
		margin-left: 0;
		padding: 0;
		float: none;
		display: block;
		font-size: 0.6rem;
	}

	#header .rBox {
		display: none;
	}

	#header .spBox {
		display: block;
		float: right;
		width: 135px;
	}

	#header .spBox .hList {
		float: left;
		width: 75px;
	}

	#header .spBox li {
		margin: 7px 10px 0 0;
		float: left;
	}

	#header .spBox li:last-child {
		margin-right: 0;
	}

	#header .spBox .menu {
		position: fixed;
		right: 0;
		top: 0;
		z-index: 201;
		width: 55px;

		-webkit-transform: scale(1);
		   -moz-transform: scale(1);
		    -ms-transform: scale(1);
		     -o-transform: scale(1);
		        transform: scale(1);

		-webkit-transition: transform 300ms ease;
		   -moz-transition: transform 300ms ease;
		    -ms-transition: transform 300ms ease;
		     -o-transition: transform 300ms ease;
		        transition: transform 300ms ease;

		-webkit-transform-origin: bottom left;
		   -moz-transform-origin: bottom left;
		    -ms-transform-origin: bottom left;
		     -o-transform-origin: bottom left;
		        transform-origin: bottom left;
	}

	#header .spBox .menu a {
		padding: 9px 8px 8px;
		display: block;
		font-size: 0.9rem;
		text-align: center;
		text-decoration: none;
	}

	/* 固定時 */
	.fix_header#header .spBox .menu {
		-webkit-transform: scale(.8);
		   -moz-transform: scale(.8);
		    -ms-transform: scale(.8);
		     -o-transform: scale(.8);
		        transform: scale(.8);
	}

	#header .menu a .close {
		display: none;
	}

	#header .menu .active .open,
	#header .close .active .open {
		display: none;
	}

	#header .menu .active .close,
	#header .close .active .close {
		display: block;
	}

	#header .menuBtn {
		position: relative;
		left: 11px;
		display: block;
		height: 20px;
		width: 20px;
		cursor: pointer;
		z-index: 100;
		transition: opacity .25s ease;
		-webkit-transition: all .3s ease;
		transition: all .3s ease;
	}

	#header .menu .active .top,
	#header .close .active .top {
		height: 3px;
	  -webkit-transform: translateY(7px) translateX(0) rotate(45deg);
		  -ms-transform: translateY(7px) translateX(0) rotate(45deg);
			  transform: translateY(7px) translateX(0) rotate(45deg);
	}

	#header .menu .active .middle,
	#header .close .active .middle {
		height: 3px;
	  opacity: 0;
	}

	#header .menu .active .bottom,
	#header .close .active .bottom {
		height: 3px;
	  -webkit-transform: translateY(-7px) translateX(0) rotate(-45deg);
		  -ms-transform: translateY(-7px) translateX(0) rotate(-45deg);
			  transform: translateY(-7px) translateX(0) rotate(-45deg);
	}

	#header .menuBtn span {
	  background: #FFF;
	  border: none;
	  height: 2px;
	  width: 100%;
	  position: absolute;
	  top: 0;
	  left: 0;
	  -webkit-transition: all .35s ease;
			  transition: all .35s ease;
	  cursor: pointer;
	}

	#header .menuBtn span:nth-of-type(2) {
	  top: 7px;
	}

	#header .menuBtn span:nth-of-type(3) {
	  top: 14px;
	}

	#header .close .menuBtn {
		margin-left: -10px;
		left: 50%;
		width: 23px;
	}

	#header .close .menuBtn span {
		background: #666;
	}

	#header .spNavi .close a {
		padding: 7px 0 5px;
		display: block;
		font-size: 0.9rem;
		text-align: center;
		text-decoration: none;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}

	#header .spNavi .close a img {
		margin: 0 auto 5px;
		display: block;
		width: 19px;
		height: 19px;
	}
}

/*------------------------------------------------------------
	グローバルナビ
------------------------------------------------------------*/
#navigation {
	width: 100%;
	height: 101px;
	position: absolute;
	top: 84px;
	left: 0;
	z-index: 100;
}

/* 固定時 */
.fix_header #navigation {
	position: fixed;
	top: 0;
}

.fix_header #navigation:after {
	width: 100%;
	height: 61px;
	position: absolute;
	bottom: 0;
	left: 0;
	content: "";
}

/* スマホで閲覧時PC表示にしたとき */
.touch_device.pc:not(.tablet) #navigation {
	top: 229px;
}

/* スマホで閲覧時PC表示にしたとき 固定した時 */
.touch_device.pc:not(.tablet) .fix_header #navigation {
	position: absolute;
}

.touch_device.pc:not(.tablet) .fix_header #gNavi:after {
	display: block;
	content: "";
}

.touch_device.pc:not(.tablet) .fix_header #navigation:after {
	display: none;
	content: none;
}

#gNavi {
	padding-bottom: 60px;
	position: relative;
	z-index: 1;
}

#gNavi:after {
	width: 100%;
	height: 1px;
	position: absolute;
	top: 0;
	left: 0;
	content: "";
}

.fix_header #gNavi:after {
	display: none;
	content: none;
}

#gNavi > ul {
	margin: 0 auto;
	width: 960px;
	background: url(/images/common/g_navi_bg.png) no-repeat left center;
}

#gNavi li {
	float: left;
	width: 240px;
}

#gNavi li a {
	padding: 11px 0 10px;
	display: block;
	font-size: 1.3rem;
	font-weight: bold;
	text-align: center;
	background: url(/images/common/g_navi_bg.png) no-repeat right center;
}

#gNavi li a:hover,
#gNavi .on a {
	text-decoration: none;
}

#gNavi .menuBox {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	display: none;
}

#gNavi .current > .menuBox {
	display: block;
}

#gNavi .menuList {
	margin: 0 auto;
	width: 960px;
}

#gNavi .menuList li {
	width: 20%;
}

#gNavi .menuList li a {
	padding: 19px 0;
	font-size: 1.5rem;
	background: none;
}

#gNavi .menuList li a img {
	margin-right: 8px;
	vertical-align: middle;
}

#gNavi .navi02 .menuList li {
/*	width: 33.3%;*/
	width: 20%;
}

#gNavi .navi02 .menuList > li:last-child a {
	padding: 13px 0 11px 50px;
	overflow: hidden;
	line-height: 1.3;
	text-align: left;
}

#gNavi .navi02 .menuList > li:last-child a img {
	margin-top: 10px;
	float: left;
}

#gNavi .navi02 .menuList > li:last-child a .txt {
	display: block;
	padding-left: 20px;
}

#gNavi .navi02 .menuList > li:last-child a .small {
	display: block;
	font-size: 1.3rem;
}

#gNavi .navi03 .menuList li {
	width: 25%;
}

#gNavi .menuList li .pullInner {
	position: absolute;
	left: 0;
	top: 60px;
	width: 100%;
	z-index: 100;
	border-top-width: 3px;
	border-top-style: solid;
	display: none;
}

#gNavi .menuList li .pullBox {
	padding: 30px 0 10px;
	margin: 0 auto;
	width: 960px;
}

#gNavi .menuList li .pullBox .btn {
	margin-right: 30px;
	float: left;
	width: 300px;
}

#gNavi .menuList li .pullBox .btn a {
	padding: 8px 20px 7px;
	position: relative;
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
	text-align: left;
	text-decoration: none;
	border-radius: 4px;
	border-width: 2px;
	border-style: solid;
}

#gNavi .menuList li .pullBox .btn a:after {
	margin-top: -4px;
	width: 6px;
	height: 6px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 12px;

	content: "";
}

#gNavi .menuList li .txtInner {
	margin-bottom: 15px;
}

#gNavi .menuList li .txtInner p {
	font-size: 1.3rem;
	line-height: 1.7;
}

#gNavi .menuList li .pullList {
	margin-right: -30px;
}

#gNavi .menuList li .pullList li {
	margin: 0 30px 20px 0;
	float: left;
	width: 135px;
}

#gNavi .menuList li .pullList li a {
	padding: 0;
	height: 135px;
	display: table;
	width: 100%;
	font-size: 1.4rem;
	line-height: 1.2;
	text-align: center;
	border-width: 1px;
	border-style: solid;
	border-radius: 4px;
}

#gNavi .menuList li .pullList li a .bgLink {
	padding: 10px 0;
	display: table-cell;
	vertical-align: middle;
}

#gNavi .menuList li .pullList li a img {
	margin: 0 auto 17px;
	display: block;
}

#gNavi .menuList li .pullList .liStyle a img {
	margin-bottom: 9px;
}

#gNavi .menuList li .pullList li a .small {
	font-size: 1.2rem;
}

#gNavi .menuList li .close a {
	padding: 8px 0;
	font-size: 1.4rem;
	font-weight: normal;
	text-align: center;
	border-top-width: 1px;
	border-top-style: solid;
	border-bottom-width: 1px;
	border-bottom-style: solid;
}

@media only screen and (min-width: 1013px) {
	.spNavi {
		display: block !important;
	}
}

@media only screen and (max-width: 1012px) {
	#navigation {
		height: auto;
	}

	.fix_header #navigation:after {
		display: none;
		content: none;
	}

	.fix_header #gNavi {
		border-top-width: 1px;
		border-top-style: solid;
	}

	#navigation {
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		max-height: 100%;
		padding-top: 50px;
		box-sizing: border-box;
		overflow-x: hidden;
		overflow-y: auto;
		z-index: 200;
		display: none;
	}

	#gNavi {
		padding-bottom: 0;
		width: auto;
		border-top-width: 2px;
		border-top-style: solid;
	}

	#gNavi > ul {
		width: auto;
		background: none;
	}

	#gNavi li {
		float: none;
		width: auto;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}

	#gNavi li a {
		padding: 14px 15px;
		position: relative;
		font-size: 1.5rem;
		text-align: left;
		background: none;
	}

	#gNavi li a:after {
		margin-top: -4px;
		width: 6px;
		height: 6px;
		border-bottom-width: 3px;
		border-bottom-style: solid;
		border-right-width: 3px;
		border-right-style: solid;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 15px;

		content: "";
	}

	#gNavi li .active:after {
		border-top-width: 3px;
		border-top-style: solid;
		border-bottom: none;
		border-right: none;
		border-left-width: 3px;
		border-left-style: solid;
	}

	#gNavi .menuBox {
		position: relative;
		left: auto;
		top: auto;
		border-top-width: 1px;
		border-top-style: solid;
	}

	#gNavi .menuList {
		margin: 0;
		padding: 0;
		width: 50%;
		border-radius: 0;
	}

	#gNavi .menuList li {
		width: auto !important;
	}

	#gNavi .menuList li a {
		padding: 0 !important;
		display: table;
		width: 100%;
		height: 46px;
		font-size: 1.3rem;
		font-weight: normal;
	}

	#gNavi .menuList li a .menuLink {
		padding: 2px 15px;
		display: table-cell;
		vertical-align: middle;
	}

	#gNavi .menuList li a img {
		display: none;
	}

	#gNavi .menuList li a:after {
		display: none;
	}

	#gNavi .menuList li .on:before,
	#gNavi .menuList li a:hover:before {
		margin-top: -5px;
		content: "";
		position: absolute;
		top: 50%;
		right: 0;
		width: 0;
		height: 0;
		border-top: 5px solid transparent;
		border-right: 10px solid #FFF;
		border-bottom: 5px solid transparent;
		overflow:hidden;
	}

	#gNavi .menuList li .on + .comPull {
		display: block;
	}

	#gNavi .menuList .liStyle02 a:before,
	#gNavi .menuList .liStyle02 a:hover:before {
		margin-top: -4px;
		width: 4px;
		height: 4px;
		border-bottom: none;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
		border-right-style: solid;
		transform: rotate(45deg);
		-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 10px;

		content: "";
	}

	#gNavi .menuList li .pullInner {
		left: auto;
		top: 0;
		right: 0;
		width: 50%;
		border-top: none;
		display: none;
	}

	#gNavi .menuList li .pullBox {
		padding: 0;
		margin: 0 0 -1px;
		width: auto;
		overflow: hidden;
	}

	#gNavi .menuList li .pullBox .txtInner {
		display: none;
	}

	#gNavi .menuList li .pullList {
		margin-right: 0;
	}

	#gNavi .menuList li .pullList li {
		margin: 0;
		float: none;
		width: auto;
	}

	#gNavi .menuList li .pullList li a {
		position: relative;
		height: 46px;
		padding: 15px;
		font-size: 1.3rem;
		text-align: left;
		border: none;
		border-radius: 0;
	}

	#gNavi .menuList li .pullList .spStyle a {
		font-size: 1.2rem;
	}

	#gNavi .menuList li .pullList li a:before {
		margin-top: -4px;
		width: 4px;
		height: 4px;
		border-bottom: none;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
		border-right-style: solid;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 10px;

		content: "";
	}

	#gNavi .menuList li .pullList li a .bgLink {
		padding: 2px 15px;
	}

	#gNavi .menuList li .pullList li a img {
		display: none;
	}

	#gNavi .menuList li .pullList li a .small {
		font-size: 1.2rem;
	}

	#gNavi .menuList li .close {
		display: none;
	}

	#gNavi .navi02 .menuList .liStyle03 > a {
		font-size: 1.1rem;
	}

	#gNavi .navi02 .menuList .liStyle03 a .small {
		display: block;
	}

	#gNavi .navi02 .menuList > li:last-child a {
		line-height: 1.5;
	}

	#gNavi .navi02 .menuList .liStyle04 > a:after,
	#gNavi .navi02 .menuList .liStyle04 > a:hover:before {
		display: block;
		margin-top: -5px;
		width: 10px;
		height: 10px;
		border: none;
		background: url(/images/common/icon/icon13.png) no-repeat;
		background-size: 10px 10px;
		-webkit-background-size: 10px 10px;
		transform: rotate(0);
		position: absolute;
		top: 50%;
		right: 10px;

		content: "";
	}

	#gNavi .navi02 .menuList li,
	#gNavi .navi03 .menuList li {
		position: static;
	}

	#gNavi .menuList li .dropMenu {
		margin-bottom: -1px;
		padding: 0;
		left: auto;
		top: 0;
		right: 0;
		width: 50%;
		overflow: hidden;
		background: none;
	}

	#gNavi .menuList li .dropMenu li:last-child {
		margin-bottom: -1px;
	}

	#gNavi .menuList li .dropMenu li {
		padding-bottom: 0;
	}

	#gNavi .menuList li .dropMenu li a,
	#gNavi .menuList li .dropMenu li a:hover {
		padding: 0 !important;
		width: 100%;
		height: 46px;
		display: table;
		font-size: 1.3rem;
		line-height: 1.2;
		background: none;
	}

	#gNavi .menuList li .dropMenu .liStyle01 a,
	#gNavi .menuList li .dropMenu .liStyle01 a:hover {
		font-size: 1.1em;
	}

	#gNavi .menuList li .dropMenu li a .menuLink {
		padding: 2px 15px;
		display: table-cell;
		vertical-align: middle;
	}

	#gNavi .menuList li .dropMenu li a:before {
		margin-top: -4px;
		width: 4px;
		height: 4px;
		border-bottom: none;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
		border-right-style: solid;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 10px;
		left: auto;

		content: "";
	}
}

/*------------------------------------------------------------
	パンクズリスト
------------------------------------------------------------*/
#pagePath {
	margin: 0 auto 20px;
	padding: 8px 12px 9px;
	width: 960px;
}

#pagePath li {
	margin-right: 2px;
	display: inline;
	font-size: 1.1rem;
}

#pagePath li a {
	margin-right: 6px;
	text-decoration: underline;
}

#pagePath li a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	#pagePath {
		display: none;
	}
}

/*------------------------------------------------------------
	コンテンツ
------------------------------------------------------------*/
#conts {
	float: right;
	width: 680px;
	font-size: 1.4rem;
}

#conts p {
	line-height: 1.75;
}

@media only screen and (max-width: 1012px) {
	#conts {
		margin: 0 15px 30px;
		float: none;
		width: auto;
		font-size: 1.2rem;
	}

	#conts p {
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	サイドバー
------------------------------------------------------------*/
#sideBar {
	float: left;
	width: 240px;
}

.sNavi01 {
	margin-bottom: 10px;
}

.sNavi01 a {
	display: block;
	position: relative;
	padding: 8px 10px 2px;
	overflow: hidden;
	border-width: 2px;
	border-style: solid;
	background: url(/images/common/s_bg.png) repeat left top;
}

.sNavi01 a:hover {
	text-decoration: none;
}

.sNavi01 a:after {
	width: 10px;
	height: 10px;
	background: url(/images/common/icon/icon03.png);
	-webkit-background-size: contain;
	     -o-background-size: contain;
	        background-size: contain;
	position: absolute;
	top: 5px;
	right: 5px;

	content: "";
}

.sNavi01 a .img {
	float: left;
}

.sNavi01 a dl {
	padding-left: 10px;
	float: left;
}

.sNavi01 a dd {
	font-size: 1.2rem;
}


.sBdBox,.sBdBox02 {
	margin-bottom: 10px;
	padding: 15px 15px 15px;
	border-width: 2px;
	border-style: solid;
}

.sBdBox p,.sBdBox02 p {
	margin-bottom: 10px;
	font-size: 1.4rem;
	line-height: 1.2;
	text-align: center;
	font-weight: bold;
}

.sBdBox p img,.sBdBox02 p img {
	margin-right: 7px;
}

.sBdBox .link01,.sBdBox02 .link01 {
	margin-bottom: 5px;
}

.sBdBox .link01 a {
	padding: 10px 15px 11px;
	display: block;
	font-size: 1.9rem;
	font-weight: bold;
	text-decoration: none;
	overflow: hidden;
	border-radius: 2px;
}
.sBdBox02 .link01 a {
	padding: 10px 15px 5px;
	display: block;
	font-size: 1.9rem;
	font-weight: bold;
	text-decoration: none;
	overflow: hidden;
	border-radius: 2px;
}

.sBdBox .link01 a img {
	margin: 4px 15px 0 0;
	float: left;
}
.sBdBox02 .link01 a img {
	margin: 10px 15px 0 0;
	float: left;
}

.sBdBox02 .link01 a .txt2 {
	margin-right: 12px;
	display: block;
	font-size: 1.2rem;
	vertical-align: middle;
	line-height: 1.2;
}

.sBdBox .link01 a .txt {
	margin-right: 12px;
	display: block;
	float: left;
	width: 49px;
	font-size: 1.2rem;
	vertical-align: middle;
	line-height: 1.2;
}

.sBdBox .link01 a .txt .subSpan {
	display: block;
}

.sBdBox .link02 a,.sBdBox02 .link02 a {
	padding: 6px 10px 5px;
	position: relative;
	display: block;
	font-size: 1.2rem;
	font-weight: bold;
	text-decoration: none;
	border-radius: 5px;
	border-width: 1px;
	border-style: solid;
}

.sBdBox .link02 a:after,.sBdBox02 .link02 a:after {
	margin-top: -3px;
	width: 4px;
	height: 4px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 7px;

	content: "";
}

#sideBar .sBox {
	margin-bottom: 10px;
	padding: 5px;
}

#sideBar .sBox .ttl {
	margin: 8px 10px 11px;
	font-size: 1.5rem;
	font-weight: bold;
	overflow: hidden;
}

#sideBar .sBox .ttl img {
	margin-right: 7px;
	vertical-align: middle;
}

#sideBar .sBox .ttlStyle01 {
	margin: 3px 10px 4px;
	line-height: 1.2;
}

#sideBar .sBox .ttlStyle01 img {
	margin: 6px 0 0;
	float: left;
}

#sideBar .sBox .ttl .txt {
	padding-left: 27px;
	display: block;
}

#sideBar .sBox .ttl .small {
	display: block;
	font-size: 1.3rem;
}

#sideBar .sBox li {
	border-top-width: 1px;
	border-top-style: solid;
}

#sideBar .sBox li:first-child {
	border-top: none;
}

#sideBar .sBox li a {
	padding: 12px 15px 11px;
	position: relative;
	display: block;
	font-size: 1.3rem;
	font-weight: bold;
	line-height: 1.3;
}

#sideBar .sBox .liStyle a {
	padding: 4px 15px;
}

#sideBar .sBox li a:after {
	margin-top: -3px;
	width: 4px;
	height: 4px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 11px;

	content: "";
}

#sideBar .sBox li a:hover {
	text-decoration: none;
}

#sideBar .sLink {
	margin-bottom: 10px;
}

#sideBar .sLink a {
	padding: 9px;
	position: relative;
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
	border-width: 2px;
	border-style: solid;
	overflow: hidden;
}

#sideBar .sLink a:after {
	margin-top: -5px;
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 11px;

	content: "";
}

#sideBar .sLink a img {
	height: auto;
	float: left;
}

#sideBar .sLink a .txt {
	padding: 5px 0 0 40px;
	display: block;
}

#sideBar .sNavi02 {
	margin-bottom: 10px;
}

#sideBar .sNavi02 a {
	padding: 43px 0 41px;
	display: block;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	border-width: 2px;
	border-style: solid;
	text-shadow: 2px 2px 2px #FFF,-2px 2px 2px #FFF,2px -2px 2px #FFF,-2px -2px 2px #FFF,2px 2px 2px #FFF,-2px 2px 2px #FFF,2px -2px 2px #FFF,-2px -2px 2px #FFF;
	background: url(/images/common/s_navi02_bg.jpg) no-repeat left top;
}

#sideBar .sNavi02 a img {
	margin: -4px 4px 0 0;
}

#sideBar .sLink a:hover,
#sideBar .sNavi02 a:hover {
	text-decoration: none;
}

/*2018.03.20*/
.sNavi03 {
	margin-bottom: 10px;
}
.sNavi03 a {
	display: block;
	position: relative;
	overflow: hidden;
}
/*2018.03.20*/

#sideBar .sLinkBox {
	margin-bottom: 10px;
	padding: 5px;
}

#sideBar .sLinkBox ul {
	border-width: 1px;
	border-style: solid;
	border-radius: 4px;
}

#sideBar .sLinkBox li {
	border-top-width: 1px;
	border-top-style: solid;
}

#sideBar .sLinkBox li:first-child {
	border-top: none;
}

#sideBar .sLinkBox li a {
	padding: 10px 22px 10px 15px;
	font-size: 1.3rem;
	font-weight: bold;
	display: block;
	overflow: hidden;
}

#sideBar .sLinkBox li a img {
	/*margin-top: 2px;*/
	height: auto;
	/*float: left;*/
	display: inline-block;
	vertical-align: middle;
	margin-right: 7px;
}

#sideBar .sLinkBox li a .txt {
	/*padding-left: 25px;
	display: block;*/
	display: inline-block;
	vertical-align: middle;
}

#sideBar .sLinkBox li a .txt01 {
	font-size: 1.1rem;
	line-height: 1.1;
}

.sPhoBox .phoList {
	display: none;
}

/* 2016.12.13 */
.sPhoBox .phoList img{
	display: none;
}

.sPhoBox .detailLink {
	display: table;
	border-width: 1px;
	border-style: solid;
}

.sPhoBox .detailLink a {
	padding: 23px 15px;
	display: table-cell;
	text-align: center;
	vertical-align: middle;
}

.sPhoBox .detailLink .link {
	margin: 10px auto 0;
	padding: 5px 0;
	position: relative;
	width: 198px;
	display: block;
	font-size: 1.2rem;
	font-weight: bold;
	border-width: 1px;
	border-style: solid;
}

.sPhoBox .detailLink .link:after {
	margin-top: -4px;
	width: 6px;
	height: 6px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 12px;

	content: "";
}

#sideBar .sLinkBox li a:hover,
.sPhoBox .detailLink a:hover {
	text-decoration: none;
}

@media only screen and (min-width: 1013px) {
#sideBar .sBox ul {
	display: block !important;
}
}

@media only screen and (max-width: 1012px) {
	#sideBar {
		float: none;
		width: auto;
	}

	.sNavi01 {
		margin: 0 15px 15px;
	}

	.sNavi01 a {
		padding-bottom: 5px;
		background-size: 7px 7px;
		-webkit-background-size: 7px 7px;
	}

	.sNavi01 a:after {
		margin-top: -5px;
		top: 50%;
		right: 10px;
	}

	.sNavi01 a .img {
		width: 26px;
		height: auto;
	}

	.sNavi01 a dl {
		padding-left: 8px;
	}

	.sNavi01 a dt {
		float: left;
	}

	.sNavi01 a dt img {
		width: 102px;
	}

	.sNavi01 a dd {
		padding: 4px 0 0 5px;
		float: left;
	}

	.sBdBox {
		margin-bottom: 15px;
		padding-top: 12px;
		border-width: 3px;
		border-right: none;
		border-left: none;
		border-bottom: none;
	}

	.sBdBox .link01 a {
		padding: 13px 15px 11px;
		font-size: 1.6rem;
		line-height: 1;
	}

	.sBdBox .link01 a img {
		margin-top: 1px;
		width: 18px;
		height: 24px;
	}

	.sBdBox .link01 a .txt {
		margin-right: 0;
		display: inline-block;
		float: none;
		width: auto;
		font-size: 1.6rem;
		vertical-align: baseline;
		line-height: 1.5;
	}

	.sBdBox .link01 a .txt .subSpan {
		display: inline;
	}

	.sBdBox .link02 a {
		padding: 8px 14px 8px;
		font-size: 1.1rem;
		border-radius: 2px;
	}

	#sideBar .sBox {
		margin-bottom: 15px;
		padding: 13px 15px 15px;
	}

	#sideBar .sBox .ttl {
		margin: 0;
		position: relative;
		background: url(/images/common/s_icon01.png) no-repeat right center;
		background-size: 18px 18px;
		-webkit-background-size: 18px 18px;
	}

	#sideBar .sBox .ttlStyle01 {
		margin: 8px 0 0;
	}

	#sideBar .sBox .ttl.on {
		background: url(/images/common/s_icon01_on.png) no-repeat right center;
		background-size: 18px 18px;
		-webkit-background-size: 18px 18px;
	}

	#sideBar .sBox .ttl img {
		display: none;
	}

	#sideBar .sBox .ttl .txt {
		padding-left: 0;
	}

	#sideBar .sBox .ttl .small {
		display: inline-block;
		font-size: 1.5rem;
	}

	#sideBar .sBox ul {
		margin-top: 15px;
		display: none;
	}

	#sideBar .sBox .spStyle a {
		padding: 12px 15px 11px;
	}

	#sideBar .sLink {
		margin: 0 15px 10px;
	}

	#sideBar .sLink a {
		font-size: 1rem;
		border-width: 1px;
	}

	#sideBar .sLink a:after {
		margin-top: -3px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-right-width: 2px;
	}

	#sideBar .sLink a img {
		width: 21px;
		height: 21px;
	}

	#sideBar .sLink a .txt {
		padding: 4px 0 0 25px;
	}

	#sideBar .sNavi02 {
		margin: 0 15px 10px;
	}

	#sideBar .sNavi02 a {
		padding: 8px 10px 7px;
		font-size: 1.4rem;
		text-align: left;
		border-width: 1px;
		background: url(/images/common/sp_s_navi02_bg.jpg) no-repeat left top;
		background-size: 100% auto;
		-webkit-background-size: 100% auto;
	}

	#sideBar .sNavi02 a img {
		margin: -2px 0 0 0;
		width: 28px;
		height: 25px;
	}

	/*2018.03.20*/
	.sNavi03 {
		margin: 0 15px 10px;
	}
	.sNavi03 a img {
		width: 100%;
		height: auto;
	}
	/*2018.03.20*/

	#sideBar .sLinkBox {
		margin-bottom: 0;
		padding: 15px;
	}

	#sideBar .sLinkBox ul {
		border-radius: 2px;
		overflow: hidden;
		letter-spacing: -.40em;
	}

	#sideBar .sLinkBox li {
		/*float: left;*/
		display: inline-block;
		vertical-align: top;
		letter-spacing: normal;
		width: 50%;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
	}

	#sideBar .sLinkBox li:first-child,
	#sideBar .sLinkBox li:nth-child(2) {
		border-top: none;
	}

	#sideBar .sLinkBox li:nth-child(2n) {
		/*border-left-width: 1px;
		border-left-style: solid;*/
	}

	#sideBar .sLinkBox li:nth-child(2n+1) {
		border-right: solid 1px #D2D2D2;
	}

	#sideBar .sLinkBox li a {
		padding: 12px 0 12px 10px;
		font-size: 1rem;
	}

	#sideBar .sLinkBox li a img {
		/*float: left;*/
	}

	#sideBar .sLinkBox li a .txt {
		/*padding: 2px 0 0 25px;*/
	}

	#sideBar .sLinkBox li a .txt01 {
		font-size: 0.8rem;
	}

	#sideBar .sLinkBox li:nth-child(5) a {
		padding: 12px 10px 10px;
		line-height: 1.2;
	}
	#sideBar .sLinkBox li:nth-child(6) a{
		padding: 8px 10px 6px;
		line-height: 1.2;
	}

	#sideBar .sLinkBox li:nth-child(6) a img,
	#sideBar .sLinkBox li:nth-child(5) a img {
		/*margin-top: 4px;*/
	}

	/**/
	#sideBar .sLinkBox li:nth-child(9) {
		width: 100%!important;
		border-right: none;
		}
	/**/

	.sPhoBox {
		width: 100%;
		display: table;
		padding: 0;
		border-collapse: collapse;
  		border-spacing: 0;
		table-layout: fixed;
		overflow: hidden;
		}

	.sPhoBox .phoBox {
		border-width: 1px;
		border-style: solid;
	}

	.sPhoBox .phoList {
		/*float: left;*/
		width: 26%;
		/*display: block;*/
		display: table-cell;
		vertical-align: middle;
	}

	.sPhoBox .phoList li {
		width: 100%;
		height: auto;
	}

	.sPhoBox .phoList li img {
		/*width: 100%;
		height: auto;*/
		display:block;
	}

	.sPhoBox .detailLink {
		/*float: left;*/
		width: 48%;
		border: none;
		/*display: block;*/
		display: table-cell;
		vertical-align: middle;
	}

	.sPhoBox .detailLink a {
		display: block;
		padding: 23px 0;
	}

	.sPhoBox .detailLink img {
		width: 101px;
		height: auto;
	}

	.sPhoBox .detailLink .link {
		padding: 2px 0;
		width: 67%;
		font-size: 0.9rem;
	}

	.sPhoBox .detailLink .link:after {
		margin-top: -3px;
		width: 4px;
		height: 4px;
		border-top-width: 1px;
		border-right-width: 1px;
		right: 7px;
	}
}

/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#footer {
	padding-top: 112px;
	overflow: hidden;
	clear: both;
	background: url(/images/common/footer_bg.jpg) repeat-x center top;
}

#footer .subNavi {
	margin: 0 auto 50px;
	width: 960px;
}

#footer .subNavi li {
	margin-right: 35px;
	width: 160px;
	float: left;
}

#footer .subNavi li:last-child {
	margin-right: 0;
}

#footer .subNavi li li {
	line-height: 2;
}

#footer .subNavi li li:first-child {
	margin-bottom: 5px;
}

#footer .subNavi li li p {
	padding-bottom: 2px;
	font-size: 1.2rem;
	font-weight: bold;
}

#footer .subNavi li li a {
	padding-left: 12px;
	display: inline-block;
	position: relative;
	font-size: 1.2rem;
}

#footer .subNavi li li a:before {
	width: 4px;
	height: 4px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 9px;
	left: 0;

	content: "";
}

#footer .fBox {
	padding: 18px 0 10px;
	position: relative;
	border-top-width: 1px;
	border-top-style: solid;
}

#footer .fBox .pageTop {
	position: absolute;
	right: 80px;
	top: -110px;
}

#footer .fLink {
	margin: 0 auto;
	width: 980px;
}

#footer .fLink li {
	margin: 0 9px 5px;
	display: inline-block;
	*display:inline;
	*zoom:1px;
}

#footer .fLink li a {
	padding-left: 13px;
	display: inline-block;
	font-size: 1.1rem;
	background: url(/images/common/icon/icon05.png) no-repeat left 2px;
	-webkit-background-size: 10px auto;
	background-size: 10px auto;
}

#footer .copyright {
	padding: 8px 0 6px;
	display: block;
	font-size: 1.1rem;
	text-align: center;
}

@media only screen and (max-width: 1012px) {
	#footer {
		padding-top: 21px;
		padding-bottom: 57px;
		background: url(/images/common/footer_bg.jpg) repeat-x center top;
		background-size: 380px auto;
		-webkit-background-size: 380px auto;
	}

	#footer .subNavi {
		display: none;
	}

	#footer .fNavi li {
		float: left;
		width: 50%;
	}

	#footer .fNavi li a {
		padding: 14px 10px;
		display: block;
		font-size: 1.1rem;
		font-weight: bold;
		position: relative;
		text-decoration: none;
		border-top-width: 1px;
		border-top-style: solid;
	}

	#footer .fNavi li a:after {
		margin-top: -2px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
		border-right-style: solid;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 10px;

		content: "";
	}

	#footer .fNavi li:first-child a,
	#footer .fNavi li:nth-child(2) a {
		border-top: none;
	}

	#footer .fNavi li:nth-child(2n) a {
		border-left-width: 1px;
		border-left-style: solid;
	}

	#footer .fBox {
		padding: 0 0 0 4px;
		border-top: none;
	}

	#footer .fBox .pageTop {
		position: inherit;
		right: auto;
		top: auto;
	}

	#footer .fBox .pageTop a {
		padding: 12px 0;
		display: block;
		font-size: 1.4rem;
		font-weight: bold;
		text-align: center;
		text-decoration: none;
	}

	#footer .fBox .pageTop a img {
		margin-right: 10px;
		vertical-align: middle;
	}

	#footer .fLink {
		padding: 10px 5px;
		width: auto;
		border-top-width: 1px;
		border-top-style: solid;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}

	#footer .fLink li {
		margin: 0 4px 5px;
	}

	#footer .fLink li a {
		padding-left: 13px;
		font-size: 0.9rem;
	}

	#footer .copyright {
		padding: 6px 0;
		font-size: 1rem;
	}

}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
.spArea {
	display: none !important;
}

.opcLink a {
	-webkit-transition:opacity  0.3s ease-in-out;
            transition:opacity 0.3s ease-in-out;
}

.opcLink a:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
}

@media only screen and (max-width: 1012px) {
	.spArea {
		display: block !important;
	}

	.pcArea {
		display: none !important;
	}

	.opcLink a:hover {
		opacity: 1;
		filter: alpha(opacity=100);
	}
}

/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 25px;
	padding: 10px 17px;
	font-size: 2.2rem;
	position: relative;
	border-width: 1px;
	border-style: solid;
	border-radius: 4px;
}

.headLine01:before {
	margin-top: -17.5px;
	width: 4px;
	height: 35px;
	border-left-width: 4px;
	border-left-style: solid;
	position: absolute;
	top: 50%;
	left: -1px;

	content: "";
}

.headLine01 + p {
	margin-bottom: 40px;
	font-size: 1.4rem;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {/*media_att*/
	.headLine01 {
		margin: 0 -15px 15px;
		padding: 7px 10px 7px 70px;
		font-size: 1.9rem;
		line-height: 1.25;
		border-radius: 0;
		border-left: none;
		border-right: none;
		position: relative;
	}

	.headLine01 a {
		margin-right: 5px;
		padding: 4px 10px 4px 20px;
		display: inline-block !important;
		font-size: 1.2rem;
		font-weight: normal;
		position: absolute;
		left: 10px;
		top: 7px;
	}

	.headLine01 .spStyle {
		margin-top: 10px;
	}

	.headLine01 a:hover {
		text-decoration: none;
	}

	.headLine01:before {
		display: none;
	}

	.headLine01 a:before {
		margin-top: -3px;
		width: 4px;
		height: 4px;
		border-bottom-width: 2px;
		border-bottom-style: solid;
		border-left-width: 2px;
		border-left-style: solid;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		left: 8px;

		content: "";
	}

	.headLine01 + p {
		margin-bottom: 30px;
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
	margin-top: 40px;
	margin-bottom: 20px;
	padding: 0 0 10px 15px;
	font-size: 1.8rem;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	position: relative;
}

.headLine02:before {
	width: 4px;
	height: 72%;
	border-left-width: 4px;
	border-left-style: solid;
	position: absolute;
	left: -1px;

	content: "";
}

.headLine02 + p {
	margin-bottom: 40px;
	font-size: 1.4rem;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.headLine02 {
		margin-top: 30px;
		margin-bottom: 15px;
		padding: 0 0 6px 10px;
		font-size: 1.6rem;
		line-height: 1.2;
	}

	.headLine02:before {
		width: 3px;
		border-left-width: 3px;
	}

	.headLine02 + p {
		margin-bottom: 30px;
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
.headLine03 {
	margin-top: 40px;
	margin-bottom: 20px;
	font-size: 1.6rem;
}

.headLine03 + p {
	margin-bottom: 40px;
	font-size: 1.4rem;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.headLine03 {
		margin-top: 30px;
		margin-bottom: 10px;
		font-size: 1.4rem;
		line-height: 1.2;
	}

	.headLine03 + p {
		margin-bottom: 30px;
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	headLine04
------------------------------------------------------------*/
.headLine04 {
	margin-top: 40px;
	margin-bottom: 15px;
	font-size: 1.4rem;
}

.headLine04 + p {
	margin-bottom: 40px;
	font-size: 1.4rem;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.headLine04 {
		margin-bottom:
		margin-top: 30px 10px;
		font-size: 1.3rem;
		line-height: 1.2;
	}

	.headLine04 + p {
		margin-bottom: 30px;
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	line
------------------------------------------------------------*/
.line {
	margin-top: 40px;
	margin-bottom: 40px;
	border: none;
	border-top-width: 1px;
	border-top-style: solid;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.line {
		margin-top: 20px;
		margin-bottom: 20px;
	}
}

/*------------------------------------------------------------
	contsBox
------------------------------------------------------------*/
.contsBox {
	margin-top: 40px;
	margin-bottom: 40px;
	padding: 30px;
}

.contsBox p {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.contsBox {
		margin-top: 20px;
		margin-bottom: 20px;
		padding: 15px;
	}

	.contsBox p {
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	list01
------------------------------------------------------------*/
.list01 {
	margin-top: 40px;
	margin-bottom: 40px;
}

.list01 li {
	margin-top: 3px;
	margin-left: 1.5em;/*★★★★★*/
	/*padding-left: 10px;★★★★★*/
	font-size: 1.4rem;
	line-height: 1.75;
	position: relative;
	list-style-type: disc;/*★★★★★*/
}

/*.list01 li:before {
	width: 6px;
	height: 6px;
	border-radius: 5px;
	position: absolute;
	top: 9px;
	left: 0;
	content: "";
}★★★★★*/

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.list01 {
		margin-top: 20px;
		margin-bottom: 20px;
	}

	.list01 li {
		/*margin-top: 3px;
		padding-left: 10px;*/
		font-size: 1.2rem;
		line-height: 1.4;
	}

	/*.list01 li:before {
		width: 5px;
		height: 5px;
		top: 5px;
	}★★★★★*/
}

/*------------------------------------------------------------
	linkList01
------------------------------------------------------------*/
.linkList01 {
	margin-top: 40px;
	margin-bottom: 40px;
}

.linkList01 li {
	margin-top: 3px;
	font-size: 1.4rem;
	line-height: 1.75;
}

.linkList01 li a {
	padding-left: 15px;
	display: inline-block;
	text-decoration: underline;
	position: relative;
}

.linkList01 li a:before {
	width: 4px;
	height: 4px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 9px;
	left: 0;

	content: "";
}

.linkList01 .blank .blankSpan {
	padding-right: 20px;
	background: url(/images/common/icon/icon07.png) no-repeat right center;
	-webkit-background-size: 10px auto;
	background-size: 10px auto;
}

.linkList01 .pdf .pdfSpan {
	padding-right: 25px;
	background: url(/images/common/icon/icon08.png) no-repeat right center;
	-webkit-background-size: 14px auto;
	background-size: 14px auto;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.linkList01 {
		margin-top: 20px;
		margin-bottom: 20px;
	}

	.linkList01 li {
		font-size: 1.2rem;
	}

	.linkList01 li a {
		padding-left: 10px;
	}

	.linkList01 .blank .blankSpan {
		padding-right: 10px;
		background-size: 10px 10px;
	}

	.linkList01 .pdf .pdfSpan {
		padding-right: 14px;
		background-size: 14px 14px;
	}
}

/*------------------------------------------------------------
	tableType
------------------------------------------------------------*/
.tableType {
	margin-top: 40px;
	margin-bottom: 40px;
	width: 100%;
}

.tableType th,
.tableType td {
	padding: 8px 15px;
	font-size: 1.4rem;
	line-height: 1.75;
	border-width: 1px;
	border-style: solid;
}

.tableType th {
	width: 30%;
	text-align: center;/**/
}

.tableType td {
	width: 70%;
}

.tableType .back {
	width: 18%;
}

.tableType .cellL {
	text-align: left;/**/
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.tableType {
		margin-top: 20px;
		margin-bottom: 20px;
	}

	.tableType th,
	.tableType td {
		padding: 8px 10px;
		font-size: 1.2rem;
		line-height: 1.4;
	}

	.tableType .back .back {
		width: 100%;
	}
}

/*------------------------------------------------------------
	detailTable
------------------------------------------------------------*/
.detailTable {
	margin-top: 40px;
	margin-bottom: 40px;
	border-width: 1px;
	border-style: solid;
	border-bottom: none;
}

.detailTable .detailDl {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	font-size: 1.4rem;
	line-height: 1.75;
	position: relative;
}

.detailTable .detailDl dt {
	padding: 8px;
	font-weight: bold;
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	box-sizing: border-box;
	width: 100px;
	border-right-width: 1px;
	border-right-style: solid;
}

.detailTable .detailDl dt p {
	display: table;
	height: 100%;
	width: 100%;
}

.detailTable .detailDl dt p .txt {
	display: table-cell;
	text-align: left;
	vertical-align: middle;
}

.detailTable .detailDl dd {
	padding-left: 7.2em;
}

.detailTable .detailDl dd dl {
	position: relative;
	border-top-width: 1px;
	border-top-style: solid;
}

.detailTable .detailDl dd dl:first-child {
	border-top: none;
}

.detailTable .detailDl dd dt {
	width: 178px;
}

.detailTable .detailDl dd dd {
	padding: 9px 9px 8px 7em;
	padding-left: 13.7em;
}

.detailTable .detailDl dd dd .topTxt {
	margin: 0 -9px 10px -16px;
	padding: 0 9px 9px 16px;
	display: block;
	border-bottom-width: 1px;
	border-bottom-style: solid;
}

.detailTable .detailDl01 dt {
	width: 278px;
}

.detailTable .detailDl01 dd {
	padding: 8px 9px 6px 21em;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.detailTable {
		margin-top: 20px;
		margin-bottom: 20px;
	}
	.detailTable .detailDl {
		margin: 0;
		font-size: 1.2rem;
		line-height: 1.4;
	}

	.detailTable .detailDl > dt {
		padding: 7px;
		position: inherit;
		width: 100%;
		border: none;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}

	.detailTable .detailDl > dt p .txt {
		text-align: center;
	}

	.detailTable .detailDl > dd {
		padding: 0;
	}

	.detailTable .detailDl dd dt {
		width: 34.8%;
	}

	.detailTable .detailDl dd dd {
		padding: 8px 8px 8px 37%;
	}

	.detailTable .detailDl dd .list01 {
		margin: 0;
	}

	.detailTable .detailDl01 > dd {
		padding: 5px 10px 10px;
	}
}

/*------------------------------------------------------------
	categoryUl01
------------------------------------------------------------*/
.categoryUl01 li {
	margin-bottom: 20px;
	width: 330px;
	float: left;
	border-width: 1px;
	border-style: solid;
	border-radius: 5px 5px 0 0;
}

.categoryUl01 li:nth-child(2n) {
	float: right;
}

.categoryUl01 li a {
	display: block;
}

.categoryUl01 li a:hover {
	text-decoration: none;
}

.categoryUl01 li a .bg {
	padding-bottom: 30px;
	display: block;
	border-bottom-width: 2px;
	border-bottom-style: solid;
	border-radius: 5px 5px 0 0;
}

.categoryUl01 li a .ttl {
	width: 100%;
	display: table;
	box-sizing: border-box;
}

.categoryUl01 li a .ttl .txt {
	padding: 0 20px;
	width: 100%;
	height: 60px;
	display: table-cell;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.25;
	vertical-align: middle;
	position: relative;
}

.categoryUl01 li a .arrowTtl {
	position: relative;
	display: block;
}

.categoryUl01 li a .arrowTtl:after {
	margin-top: -5px;
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 15px;

	content: "";
}

.categoryUl01 li a .icon {
	margin: 0 auto;
	/*width: 70px;
	height: 70px;*/
	width: 60px;/*★★★★★*/
	height: 60px;/*★★★★★*/
	display: block;
}

.categoryUl01 li a .icon img {
	max-width: 100%;
	height: auto;
}

.categoryUl01 li a .text {
	padding: 15px 20px;
	display: block;
	font-size: 1.4rem;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.categoryUl01 li {
		margin-bottom: 20px;
		width: auto;
		float: none !important;
	}

	.categoryUl01 li a .bg {
		padding-bottom: 0;
		position: relative;
	}

	.categoryUl01 li a .ttl .txt {
		padding: 15px 50px;
		height: 50px;
		font-size: 1.5rem;
	}

	.categoryUl01 li a .arrowTtl:after {
		margin-top: -2px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
	}

	.categoryUl01 li a .icon {
		position: absolute;
		width: 36px;
		height: 36px;
		top: 6px;
		left: 6px;
	}

	.categoryUl01 li a .text {
		padding: 10px 15px;
		font-size: 1.2rem;
		line-height: 1.4;
	}
}


/*------------------------------------------------------------
	categoryUl02
------------------------------------------------------------*/
.categoryUl02 {
	margin: -20px 0 40px;
}

.categoryUl02 li {
	margin-top: 20px;
	width: 330px;
	float: left;
	border-width: 1px;
	border-style: solid;
	border-radius: 5px 5px 0 0;
}

.categoryUl02 li:nth-child(2n) {
	float: right;
}

.categoryUl02 li a {
	display: block;
}

.categoryUl02 li a:hover {
	text-decoration: none;
}

.categoryUl02 li a .ttl {
	width: 100%;
	display: table;
	box-sizing: border-box;
	border-bottom-width: 2px;
	border-bottom-style: solid;
	border-radius: 5px 5px 0 0;
}

.categoryUl02 li a .ttl .txt {
	padding: 0 20px;
	width: 100%;
	height: 60px;
	display: table-cell;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.25;
	vertical-align: middle;
	position: relative;
}

.categoryUl02 li a .arrowTtl {
	position: relative;
	display: block;
}

.categoryUl02 li a .arrowTtl:after {
	margin-top: -5px;
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 15px;

	content: "";
}

.categoryUl02 li a .text {
	padding: 15px 20px;
	display: block;
	font-size: 1.4rem;
	line-height: 1.75;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.categoryUl02 {
		margin: -10px 0 30px;
	}

	.categoryUl02 li {
		margin-top: 10px;
		width: auto;
		float: none !important;
	}

	.categoryUl02 li a .ttl .txt {
		padding: 10px 15px;
		height: 50px;
		font-size: 1.5rem;
	}

	.categoryUl02 li a .arrowTtl:after {
		margin-top: -4px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
	}

	.categoryUl02 li a .text {
		padding: 10px 15px;
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

/*------------------------------------------------------------
	btn01
------------------------------------------------------------*/
.btn01 {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.25;
	width: 330px;
	border-width: 1px;
	border-style: solid;
}

.btn01 a {
	padding: 15px 18px;
	display: block;
	position: relative;
}

.btn01 a:after {
	margin-top: -5px;
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 10px;

	content: "";

}

.btn01 a:hover {
	text-decoration: none;
}

.btn01 a .txt {
	margin: -9px 0;
	display: block;
}

.btn01List {
	margin-bottom: 20px;
}

.btn01List li {
	float: left;
}

.btn01List li:nth-child(2n) {
	float: right;
}

@media only screen and (max-width: 1012px) {
	.btn01 {
		margin-top: 10px;
		margin-bottom: 10px;
		font-size: 1.3rem;
		width: auto;
	}

	.btn01 a {
		padding: 10px 12px;
	}

	.btn01 a:after {
		margin-top: -2px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
	}

	.btn01 a .txt {
		margin: -8px 0;
	}

	.btn01List li {
		float: none !important;
	}
}

/*------------------------------------------------------------
	btn02
------------------------------------------------------------*/
.btn02 {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.25;
	width: 330px;
	border-width: 1px;
	border-style: solid;
}

.btn02 a {
	padding: 15px 18px;
	display: block;
	position: relative;
}

.btn02 a:after {
	margin-top: -6px;
	width: 12px;
	height: 12px;
	position: absolute;
	top: 50%;
	right: 10px;
	background: url(/images/common/icon/icon09.png) no-repeat;
	-webkit-background-size: 10px auto;
	background-size: 10px auto;

	content: "";
	border: none;
}

.btn02 a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	.btn02 {
		margin-top: 10px;
		margin-bottom: 10px;
		font-size: 1.3rem;
		width: auto;
	}

	.btn02 a {
		padding: 10px 12px;
	}

	.btn02 a:after {
		margin-top: -5px;
		width: 10px;
		height: 10px;
		background-size: 10px 10px;
	}
}

/*------------------------------------------------------------
	btn03
------------------------------------------------------------*/
.btn03 {
	margin: 20px auto;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.25;
	width: 330px;
	border-width: 1px;
	border-style: solid;
}

.btn03 a {
	padding: 15px 18px;
	display: block;
	position: relative;
}

.btn03 a:after {
	margin-top: -9px;
	width: 17px;
	height: 18px;
	position: absolute;
	top: 50%;
	right: 10px;
	background: url(/images/common/icon/icon08.png) no-repeat;
	-webkit-background-size: 14px auto;
	background-size: 14px auto;

	content: "";
	border: none;
}

.btn03 a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	.btn03 {
		margin-top: 0;
		margin-bottom: 30px;
		font-size: 1.3rem;
		width: auto;
	}

	.btn03 a {
		padding: 10px 12px;
	}

	.btn03 a:after {
		width: 14px;
		height: 14px;
		background-size: 14px 14px;
	}
}

/*------------------------------------------------------------
	sBtn01
------------------------------------------------------------*/
.sBtn01 {
	margin-top: 20px;
	width: 220px;
	font-size: 1.3rem;
	font-weight: bold;
	border-width: 1px;
	border-style: solid;
}

.sBtn01 a {
	padding: 10px 18px;
	display: block;
	position: relative;
}

.sBtn01 a:after {
	margin-top: -5px;
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 10px;

	content: "";

}

.sBtn01 a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	.sBtn01 {
		margin-top: 10px;
		margin-bottom: 10px;
		width: auto;
		font-size: 1.2rem;
	}

	.sBtn01 a {
		padding: 10px 12px;
	}

	.sBtn01 a:after {
		margin-top: -2px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-top-style: solid;
		border-right-width: 2px;
		border-right-style: solid;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		position: absolute;
		top: 50%;
		right: 10px;

		content: "";

	}
}

/*------------------------------------------------------------
	sBtn02
------------------------------------------------------------*/
.sBtn02 {
	margin-top: 20px;
	width: 220px;
	font-size: 1.3rem;
	font-weight: bold;
	border-width: 1px;
	border-style: solid;
}

.sBtn02 a {
	padding: 10px 18px;
	display: block;
	position: relative;
}

.sBtn02 a:after {
	margin-top: -6px;
	width: 12px;
	height: 12px;
	position: absolute;
	top: 50%;
	right: 10px;
	background: url(/images/common/icon/icon09.png) no-repeat;
	-webkit-background-size: 10px auto;
	background-size: 10px auto;

	content: "";
	border: none;
}

.sBtn02 a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	.sBtn02 {
		margin-top: 10px;
		margin-bottom: 10px;
		width: auto;
		font-size: 1.2rem;
	}

	.sBtn02 a {
		padding: 10px 12px;
	}

	.sBtn02 a:after {
		margin-top: -5px;
		width: 10px;
		height: 10px;
		background-size: 10px 10px;
	}
}

/*------------------------------------------------------------
	sBtn03
------------------------------------------------------------*/
.sBtn03 {
	margin-top: 20px;
	width: 220px;
	font-size: 1.3rem;
	font-weight: bold;
	border-width: 1px;
	border-style: solid;
}

.sBtn03 a {
	padding: 10px 18px;
	display: block;
	position: relative;
}

.sBtn03 a:after {
	margin-top: -9px;
	width: 17px;
	height: 18px;
	position: absolute;
	top: 50%;
	right: 10px;
	background: url(/images/common/icon/icon08.png) no-repeat;
	-webkit-background-size: 14px auto;
	background-size: 14px auto;

	content: "";
	border: none;
}

.sBtn03 a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	.sBtn03 {
		margin-top: 10px;
		margin-bottom: 10px;
		width: auto;
		font-size: 1.2rem;
	}

	.sBtn03 a {
		padding: 10px 12px;
	}

	.sBtn03 a:after {
		margin-top: -7px;
		width: 14px;
		height: 14px;
		background-size: 14px 14px;
	}
}

/*------------------------------------------------------------
	comBannerBox
------------------------------------------------------------*/
.comBannerBox {
	margin-bottom: 60px;
	padding: 20px 0;
}

.comBannerBox .subBox {
	margin: 0 auto;
	width: 960px;
}

.comBannerBox .subBox ul li {
	padding-left: 10px;
	float: left;
}

.comBannerBox .subBox ul li:first-child {
	padding: 0 !important;
}

.comBannerBox .subBox ul li:nth-child(3) {
	padding-left: 11px;
}

.comBannerBox .subBox ul:first-child {
	margin-bottom: 10px;
}

.comBannerBox .subBox ul:first-child li {
	padding-left: 10px;
}

.comBannerBox .subBox .linkUl {
	margin-top: 10px;
}

.comBannerBox .subBox .linkUl li {
	padding: 0 !important;
	border-left-width: 1px;
	border-left-style: solid;
}

.comBannerBox .subBox .linkUl li:first-child {
	border: none;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.comBannerBox {
		padding: 15px;
	}

	.comBannerBox .subBox {
		width: auto;
	}

	.comBannerBox .subBox ul {
		margin-top: -10px;
	}

	.comBannerBox .subBox ul li {
		margin: 10px 4% 0 0;
		padding: 0 !important;
		width: 48%;
	}

	.comBannerBox .subBox ul li:nth-child(2n) {
		margin-right: 0;
	}

	.comBannerBox .subBox ul li img {
		width: 100%;
		height: auto;
	}

	.comBannerBox .subBox ul:first-child li {
		float: none;
		width: auto;
		margin: 10px 0 0;
	}

	.comBannerBox .subBox .linkUl li {
		margin: 0;
		width: 50%;
		box-sizing: border-box;
	}

	.comBannerBox .subBox .linkUl li:nth-child(2) {
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}

	.comBannerBox .subBox .linkUl li:nth-child(3) {
		border-left: none;
		border-top-width: 1px;
		border-top-style: solid;
	}
}

/*------------------------------------------------------------
	comContact
------------------------------------------------------------*/
.comContact {
	width: 100%;
	display: table;
	text-align: center;
	border-collapse: collapse;
}

.comContact .contact {
	padding: 30px 0 25px;
	width: 50%;
	display: table-cell;
	vertical-align: middle;
	border-width: 1px;
	border-style: solid;
	border-top-width: 1px;
	border-top-style: solid;
}

.comContact .contact p {
	font-size: 1.4rem;
	line-height: 1.75;
}

.comContact .contact .txt {
	margin-bottom: 7px;
	font-size: 1.3rem;
	line-height: 1.4;
}

.comContact .contact .ttl {
	font-size: 1.6rem;
	font-weight: bold;
}

.comContact .contact .tel {
	margin-bottom: 10px;
	font-size: 3rem;
	font-weight: bold;
	line-height: 1;
}

.comContact .contact .tel img {
	margin-top: -5px;
	height: auto;
	vertical-align: middle;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.comContact .contact {
		margin-bottom: 20px;
		padding: 15px;
		width: 100%;
		float: left;
		box-sizing: border-box;
	}

	.comContact .contact .txt {
		margin-bottom: 3px;
		font-size: 1.2rem;
	}

	.comContact .contact .ttl {
		margin-bottom: 7px;
	}

	..comContact .contact .tel {
		margin-bottom: 7px;
		line-height: 0.9;
	}

	.comContact .contact .tel a {
		padding: 13px 10px 10px;
		display: block;
		font-size: 2.2rem;
		text-decoration: none;
		border-width: 1px;
		border-style: solid;
	}

	.comContact .contact .tel img {
		margin-top: 0;
		margin-right: 5px;
		width: 18px;
		height: auto;
		vertical-align: top;
	}

	.comContact .contact p {
		font-size: 1.2rem;
		line-height: 1.4;
	}
}

.comSideUl {
	position: fixed;
	top: 214px;
	right: 0;
	width: 51px;
	text-align: center;
	border-width: 1px;
	border-style: solid;
	border-right: none;
	border-radius: 4px 0 0 4px;
	z-index: 100;
}

.comSideUl li {
	font-size: 11px;
	line-height: 1.2;
	border-top-width: 1px;
	border-top-style: solid;
}

.comSideUl li a {
	padding: 6px 0 10px;
	display: block;
}

.comSideUl li:first-child {
	border: none;
}

.comSideUl li img {
	margin: 0 auto 6px;
	display: block;
}

.comSideUl li .txt {
	font-size: 0.9rem;
}

.comSideUl li a:hover {
	text-decoration: none;
}

@media only screen and (max-width: 1012px) {
	.comSideUl {
		bottom: 0;
		top: auto;
		width: 100%;
		border-left: none;
		border-bottom: none;
		border-radius: 0;
	}

	.comSideUl li {
		float: left;
		font-size: 0.9rem;
		width: 20%;
		box-sizing: border-box;
		border: none;
		border-left-width: 1px;
		border-left-style: solid;
	}

	.comSideUl li a {
		padding: 5px 0;
		height: 56px;
	}

	.comSideUl li a .spArea {
		display: inline-block !important;
	}

	.comSideUl li img {
		margin-bottom: 10px;
		width: 24px;
		height: auto;
	}

	.comSideUl li:last-child img {
		margin-bottom: 2px;
	}
}

/*------------------------------------------------------------
	comNews
------------------------------------------------------------*/
.newsTtl {
	margin-bottom: 0;
	padding: 10px 15px;
	font-size: 1.4rem;
	border-radius: 4px 4px 0 0;
}

.comNews {
	margin-bottom: 40px;
	border-width: 1px;
	border-style: solid;
	border-top: none;
	overflow: hidden;
}

.comNews .btn01 {
	margin: 10px;
	float: right;
	width: 96px;
	font-size: 1.1rem;
	font-weight: normal;
}

.comNews .btn01 a {
	padding: 5px 10px 5px 5px;
	text-align: center;
}

.comNews .btn01 a:after {
	margin-top: -3px;
	width: 4px;
	height: 4px;
	border-top-width: 2px;
	border-right-width: 2px;
}

.newsDl {
	clear: both;
}

.newsDl dt {
	padding: 13px 0 0 20px;
	float: left;
	font-size: 1.2rem;
	font-weight: bold;
	letter-spacing: 1px;
}

.ieLess8 .newsDl dt {
    font-size: 12px;
}

.newsDl dt .news {
	margin-left: 10px;
	padding: 2px 6px;
	font-size: 1.1rem;
	border-radius: 2px;
}

.newsDl dd {
	padding: 11px 0 11px 9em;
	font-size: 1.3rem;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
}

.ieLess8 .newsDl dd {
    font-size: 13px;
}

.newsDl dd:nth-child(2) {
	border-top-width: 1px;
	border-top-style: dotted;
}

.ieLess8 .newsDl > *:first-child + * {
    border-top-width: 1px;
    border-top-style: dotted;
    border-top-color: #ccc;
}


.newsDl dd:last-child {
	border-bottom: none;
}

.newsDl .ddStyle {
	padding: 13px 0 9px 14.5em;
}

.newsDl dd a {
	text-decoration: underline;
}

.newsDl dd a:hover {
	text-decoration: none;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	/*------------------------------------------------------------
		comNews
	------------------------------------------------------------*/
	.comNews {
		margin: 0 -15px 30px;
		padding-bottom: 42px;
		position: relative;
		border: none;
		border-top-width: 2px;
		border-top-style: solid;
	}

	.comNews .btn01 {
		margin: 0;
		float: none;
		width: auto;
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		font-size: 1.4rem;
	}

	.comNews .btn01 a {
		padding: 10px;
	}

	.comNews .btn01 a:after {
		margin-right: -45px;
		right: 50%;
	}

	.newsDl dt {
		padding: 10px 15px 2px;
		float: none;
		font-size: 1.1rem;
	}

	.newsDl dt .news {
		margin-left: 3px;
		padding: 2px 5px 0;
		font-size: 0.9rem;
	}

	.newsDl dd {
		padding: 0 15px 5px!important;
		font-size: 1.2rem;
	}

	.newsDl dd:nth-child(2) {
		border-top: none;
	}

}

/**/
.newsDl .blank .blankSpan {
	padding-right: 20px;
	background: url(/images/common/icon/icon07.png) no-repeat right center;
	-webkit-background-size: 10px auto;
	background-size: 10px auto;
}

.newsDl .pdf .pdfSpan {
	padding-right: 25px;
	background: url(/images/common/icon/icon08.png) no-repeat right center;
	-webkit-background-size: 14px auto;
	background-size: 14px auto;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.newsDl {
		margin-top: 0;
		margin-bottom: 0;
	}

	.newsDl li {
		font-size: 1.2rem;
	}

	.newsDl li a {
		padding-left: 10px;
	}

	.newsDl .blank .blankSpan {
		padding-right: 10px;
		background-size: 10px 10px;
	}

	.newsDl .pdf .pdfSpan {
		padding-right: 14px;
		background-size: 14px 14px;
	}
}
/**/


/*------------------------------------------------------------
	detail
------------------------------------------------------------*/
#main .photo {
	margin-bottom: 39px;
	text-align: center;
}

#main .detailList {
	margin-bottom: 34px;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	#main .photo {
		margin: 0 auto 19px;
		width: 91%;
	}

	#main .photo img {
		width: 100%;
		height: auto;
	}

	#main .detailList {
		margin: 0 0 27px;
	}
}

/*------------------------------------------------------------
	/index.html
------------------------------------------------------------*/
.topVisual {
	padding: 15px 0;
	min-height: 605px;
	position: relative;
	background: url(/images/index/top_visual_bg.jpg) no-repeat center top;
	background-size: cover;
	z-index: 1;
}

.topVisual #header {
	margin: 0 auto;
	width: 960px;
}

.topVisual #navigation {
	top: 99px;
}

.touch_device.pc:not(.tablet) .topVisual #navigation {
	top: 99px;
}

.topVisual .fix_header #navigation {
	top: 0;
}

.topVisual #gNavi:after {
	margin-left: -480px;
	width: 960px;
	left: 50%;
}

.topVisual #gNavi .menuBox {
	bottom: auto;
}

.topVisual .topInner {
	margin:0 auto;
	/*padding: 15px 0 62px;*/
	padding: 15px 0 0;/*2018.03.20*/
	width: 960px;
	position: relative;
}

.topVisual .topInner .lBox {
	float: left;
	width: 245px;
}

.topVisual .topInner .sBdBox {
	margin-bottom: 0;
	padding-bottom: 10px;
	border: none;
}

.topVisual .topInner .sBdBox01 {
	padding: 0 15px 15px;
}

.topVisual .topInner .sBdBox01 p {
	display: none;
}

.topVisual .topInner .rBox {
	float: right;
	width: 700px;
	overflow: hidden;
}

.topVisual .topInner .rBox .mainImg {
	margin-bottom: 10px;
	height: 230px;
	overflow: hidden;
	position: relative;
}

.topVisual .topInner .rBox .mainImg li img {
	width: 100%;
}

.topVisual .topInner .rBox .bx-controls {
	margin-top: -15px;
	position: absolute;
	top: 50%;
	width: 100%;
}

.topVisual .topInner .rBox .bx-controls .bx-prev,
.topVisual .topInner .rBox .bx-controls .bx-next {
	width: 30px;
	height: 30px;
	position: absolute;
}

.topVisual .topInner .rBox .bx-controls .bx-prev {
	left: 2px;
	background: url(/images/index/prev.png) no-repeat;
}

.topVisual .topInner .rBox .bx-controls .bx-next {
	right: 2px;
	background: url(/images/index/next.png) no-repeat;
}

.topVisual .topInner .rBox .icoList {
	display: none;
}

.topVisual .topInner .rBox p {
	position: absolute;
	right: 17px;
	top: 183px;
	z-index: 10;
	text-align: right;
}

.sliderBox {
	position: relative;
}

.sliderBox .prev,
.sliderBox .next {
	position: absolute;
	top: 0;
	width: 21px;
	height: 70px;
}

.sliderBox .prev {
	left: 0;
}

.sliderBox .next {
	right: 0;
}

.sliderBox .prev a,
.sliderBox .next a {
	display: block;
	width: 21px;
	height: 70px;
}

.sliderBox .prev:before,
.sliderBox .next:before {
	margin-top: -4px;
	width: 4px;
	height: 4px;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	left: 5px;

	content: "";
}

.sliderBox .prev:before {
	left: 7px;
}

.topVisual .topInner .rBox .sliderBox {
	padding: 4px 30px 8px;
}

.topVisual .topInner .rBox .slider li {
	margin-right: 10px;
	float: left;
	width: 152px;
	padding-top: 5px;
}

.topVisual .topInner .rBox .slider li:last-child {
	margin-right: 0;
}

.topVisual .topInner .rBox .slider li a {
	position: relative;
	display: block;
	font-size: 1.1rem;
	font-weight: bold;
	line-height: 1.25;
	text-align: center;
	text-decoration: none;
	border-width: 2px;
	border-style: solid;
	padding:0;
}

.topVisual .topInner .rBox .slider li a:hover,
.topVisual .topInner .rBox .slider .active {
	padding: 0;
	border-width: 2px;
}

.topVisual .topInner .rBox .slider li a:hover:before,
.topVisual .topInner .rBox .slider .active:before {
	margin-left: -3px;
	content: "";
	position: absolute;
	top: -11px;
	left: 50%;
	width: 0;
	height: 0;
	border-width: 4px;
	border-style: solid;
	border-bottom-width: 6px;
	overflow: hidden;
}

/**/
.topVisual .topInner .rBox .slider li a img {
	width:100%;
	height:auto;
}
/**/

.topVisual .newsBox {
	margin-top: 10px;
	padding: 13px 30px 13px 10px;/*2018.03.20*/
	float: right;
	width: 700px;/*2018.03.20*/
	min-height: 64px;
	/*width: 100%;*//*2018.03.20*/
	/*position: absolute;*//*2018.03.20*/
	/*left: 0;*//*2018.03.20*/
	/*bottom: 0;*//*2018.03.20*/
	position: relative;
}

.topVisual .newsBox dt {
	padding: 5px 0;
	width: 160px;
	font-size: 1.3rem;
	*font-size: 1.3em;/*2016.12.03*/
	text-align: center;
	display: inline-block;/*2018.03.20*/
	vertical-align: middle;/*2018.03.20*/
	/*float: left;*//*2018.03.20*/
}

.topVisual .newsBox dt img {
	margin-right: 8px;
}

.topVisual .newsBox dd {
	/*padding: 4px 0 0 174px;*/
	padding: 10px 0 10px 20px;
	display: inline-block;/*2018.03.20*/
	vertical-align: middle;/*2018.03.20*/
	width: 480px;
	font-size: 1.2rem;
	*font-size: 1.2em;/*2016.12.03*/
}

.topVisual .newsBox dd a {
	text-decoration: underline;
}

.topVisual .newsBox dd a:hover {
	text-decoration: none;
}

.topVisual .newsBox .arrowUl {
	position: absolute;
	right: 10px;
	/*top: 6px;*//*2018.03.20*/
	top: 50%;/*2018.03.20*/
	margin-top: -17px;/*2018.03.20*/
}

.topVisual .newsBox .arrowUl li {
	width: 18px;
	height: 17px;
	position: relative;
	border-width: 1px;
	border-style: solid;
}

.topVisual .newsBox .arrowUl li a {
	display: block;
	width: 18px;
	height: 17px;
	position: relative;
}

.topVisual .newsBox .arrowUl li:last-child {
	border-top: none;
}

.topVisual .newsBox .arrowUl li a:before {
	width: 4px;
	height: 4px;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 5px;
	left: 5px;

	content: "";
}

.topVisual .newsBox .arrowUl li:last-child a:before {
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.topVisual {
		padding: 0;
		min-height: 0;
		background: none;
	}

	.topVisual #header {
		width: auto;
	}

	.topVisual #navigation {
		top: 0;
	}

	.topVisual #gNavi {
		position: relative;
	}

	.topVisual #gNavi .menuBox {
		top: auto;
	}

	.topVisual .topInner {
		margin: 0;
		padding: 0;
		width: auto;
	}

	.topVisual .topInner .lBox {
		float: none;
		width: auto;
	}

	.topVisual .topInner .sBdBox {
		padding-bottom: 15px;
		border: none;
		border-top-width: 2px;
		border-top-style: solid;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}

	.topVisual .topInner .sBdBox01 {
		display: none;
	}

	.topVisual .topInner .rBox {
		margin-bottom: 115px;
		float: none;
		width: auto;
	}

	.topVisual .topInner .rBox .mainImg {
		margin-bottom: 10px;
		height: auto;
		display: block;
	}

	.topVisual .topInner .rBox .bx-controls {
		margin-top: -12px;
	}

	.topVisual .topInner .rBox .bx-controls .bx-prev,
	.topVisual .topInner .rBox .bx-controls .bx-next {
		width: 20px;
		height: 25px;
	}

	.topVisual .topInner .rBox .bx-controls .bx-prev {
		left: 0;
		background: url(/images/index/sp_prev.png) no-repeat;
		background-size: 20px 25px;
		-webkit-background-size: 20px 25px;
	}

	.topVisual .topInner .rBox .bx-controls .bx-next {
		right: 0;
		background: url(/images/index/sp_next.png) no-repeat;
		background-size: 20px 25px;
		-webkit-background-size: 20px 25px;
	}

	.topVisual .topInner .rBox .bx-controls .bx-prev img,
	.topVisual .topInner .rBox .bx-controls .bx-next img {
		display: none;
	}

	.topVisual .topInner .rBox .icoList {
		display: block;
		text-align: center;
	}

	.topVisual .topInner .rBox .icoList .bx-pager-item,
	.topVisual .topInner .rBox .icoList .bx-wrapper .bx-controls-auto .bx-controls-auto-item {
		display: inline-block;
		*zoom: 1;
		*display: inline;
	}

	.topVisual .topInner .rBox .icoList .bx-pager.bx-default-pager a {
		text-indent: -9999px;
		display: block;
		width: 11px;
		height: 11px;
		margin: 0 5px;
		outline: 0;
		-moz-border-radius: 5px;
		-webkit-border-radius: 5px;
		border-radius: 8px;
	}

	.topVisual .topInner .rBox p {
		display: none;
	}

	.sliderBox {
		display: none;
	}

	.topVisual .newsBox {
		padding: 0 15px;
		float: none;
		min-height: initial;
		min-height: auto;
		bottom: 38%;/*2018.03.20*/
		width: 100%;
		-webkit-box-sizing: border-box;/*2018.03.20*/
		-moz-box-sizing: border-box;/*2018.03.20*/
		box-sizing: border-box;/*2018.03.20*/
		position: absolute;/*2018.03.20*/
		margin: 0 0 20px;/*2018.03.20*/
		height: auto;
	}

	.topVisual .newsBox dt {
		padding: 5px 0 2px;
		float: none;
		width: auto;
		font-size: 1.4rem;
		display: block;/*2018.03.20*/
	}

	.topVisual .newsBox dd {
		padding: 3% 35px 3% 13px;
		border-width: 1px;
		border-style: solid;
		height: 55px;
		display: block;/*2018.03.20*/
		width: 100%;/*2018.03.20*/
		overflow: hidden;/*2018.03.20*/
	}

	.topVisual .newsBox .arrowUl {
		/*position: absolute;*/
		right: 25px;
		/*bottom: 12%;*/
		margin-top: 0;
	}
}

@media only screen and (min-width: 0) and (max-width: 640px) {
	.topVisual .newsBox {
		bottom: 41%;/*2018.03.20*/
	}
}
@media only screen and (min-width: 0) and (max-width: 480px) {
	.topVisual .newsBox {
		bottom: 45%;/*2018.03.20*/
	}
}
@media only screen and (min-width: 0) and (max-width: 320px) {
	.topVisual .newsBox {
		bottom: 46%;/*2018.03.20*/
	}
}

.bgSec {
	padding: 20px 0 30px;
}

.mainBox {
	margin: 0 auto;
	width: 960px;
}

.bgSec .bgTxt {
	margin-bottom: 10px;
	padding: 15px 20px;
	font-size: 1.3rem;
	line-height: 1.4;
	border-width: 1px;
	border-style: solid;
}

.bgSec .bgTxt .ttlSpan {
	margin-bottom: 4px;
	display: block;
	font-weight: bold;
}

.bgSec .naviList {
	margin-bottom: 10px;
	border-width: 1px;
	border-style: solid;
	border-radius: 4px;
	border-top: none;
}

.bgSec .naviList li {
	float: left;
	width: 239px;
}

.bgSec .naviList li:nth-child(4n) {
	width: 241px;
}

.bgSec .naviList li a {
	border-right-width: 1px;
	border-right-style: solid;
	border-top-width: 1px;
	border-top-style: solid;
	padding: 11px 20px 10px;
	display: block;
	font-size: 1.3rem;
	font-weight: bold;
	text-decoration: none;
	overflow: hidden;
	box-sizing: border-box;
}
.bgSec .naviList li:nth-child(5n) a {
/*	padding: 6px 20px 5px;
	font-size: 1.1rem;
	line-height: 1.3;
*/
}
.bgSec .naviList li:nth-child(4n) a {
	border-right: none;
}

.bgSec .naviList li a img {
	/*margin-top: 2px;
	float: left;*/
	display: inline-block;
	vertical-align: middle;
	margin-right: 7px;
}

.bgSec .naviList li a .txt {
	/*padding-left: 25px;
	display: block;*/
	display: inline-block;
	vertical-align: middle;
}

.bgSec .linkList li {
	float: left;
	width: 640px;
}

.bgSec .linkList li a {
	padding: 13px 19px;
	position: relative;
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
	text-decoration: none;
	border-width: 2px;
	border-style: solid;
}

.bgSec .linkList li a:after {
	margin-top: -5px;
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 15px;

	content: "";
}

.bgSec .linkList > *:first-child + * {
	margin-left: 10px;
	width: 310px;
}

.bgSec .linkList > *:first-child + * a {
	padding: 9px;
	overflow: hidden;
}

.bgSec .linkList > *:first-child + * a:after {
	right: 11px;
}

.bgSec .linkList > *:first-child + * a img {
	float: left;
}

.bgSec .linkList > *:first-child + * a .txt {
	padding: 5px 0 0 40px;
	display: block;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.bgSec {
		padding: 20px 15px 15px;
	}

	.mainBox {
		width: auto;
	}

	.bgSec .bgTxt {
		padding: 10px 15px 13px;
		font-size: 1rem;
	}

	.bgSec .bgTxt .ttlSpan {
		margin-bottom: 4px;
		font-size: 1.2rem;
	}

	.bgSec .naviList {
		margin-bottom: 10px;
		letter-spacing: -.40em;
	}

	.bgSec .naviList li {
		width: 50% !important;
		display: inline-block;
		vertical-align: top;
		letter-spacing: normal;
	}

	.bgSec .naviList li:nth-child(2n) {
		/*float: right;*/
	}

	.bgSec .naviList li a {
		padding: 12px 10px;
		font-size: 1rem;
	}

	.bgSec .naviList li:nth-child(2n) a {
		border-right: none;
	}

	.bgSec .naviList li a img {
		margin-top: 0;
	}

	.bgSec .naviList li a .txt {
		/*padding-left: 25px;*/
	}

	.bgSec .naviList li:nth-child(5) a {
/*
		padding: 10px 0 9px 10px;
		font-size: 0.9rem!important;
		line-height: 1.3;
*/
	}

	.bgSec .naviList li:nth-child(6) a {
		padding: 10px 5px 9px 10px;
		line-height: 1.1;
	}

	.bgSec .naviList li:nth-child(6) a img {
		margin-top: 4px;
	}

	.bgSec .linkList li {
		float: none;
		width: auto;
	}

	.bgSec .linkList li a {
		padding: 10px 10px;
		font-size: 1.1rem;
		border-width: 1px;
	}

	.bgSec .linkList li a:after {
		margin-top: -3px;
		width: 4px;
		height: 4px;
		border-top-width: 2px;
		border-right-width: 2px;
		right: 10px;
	}

	.bgSec .linkList li:last-child {
		margin: 10px 0 0;
		width: auto;
	}

	.bgSec .linkList li:last-child a {
		padding: 9px;
	}

	.bgSec .linkList li:last-child a img {
		width: 20px;
		height: 20px;
	}

	.bgSec .linkList li:last-child a:after {
		right: 10px;
	}

	.bgSec .linkList li:last-child a .txt {
		padding: 3px 0 0 22px;
	}
}

.linkSec {
	padding: 32px 0;
	background: url(/images/index/link_bg.jpg) no-repeat center top;
	background-size: cover;
}

.linkSec .ttl {
	margin-bottom: 15px;
	font-size: 2.4rem;
	font-weight: bold;
	text-align: center;
}

.linkSec .ttl img {
	margin-top: -2px;
}

.linkSec li {
	float: left;
	width: 160px;
}

.linkSec li a {
	padding: 22px 0 30px;
	display: block;
	position: relative;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
}

.linkSec li a:after {
	width: 6px;
	height: 6px;
	border-top-width: 3px;
	border-top-style: solid;
	border-right-width: 3px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	bottom: 10px;
	right: 12px;

	content: "";
}

.linkSec li a img {
	margin: 19px auto 0;
	display: block;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.linkSec {
		padding: 17px 25px 25px;
		background: url(/images/index/link_bg.jpg) no-repeat left top;
	}

	.linkSec .ttl {
		margin-bottom: 10px;
		font-size: 1.6rem;
	}

	.linkSec .ttl img {
		width: 28px;
		height: auto;
	}

	.linkSec li {
		width: 33.3%;
	}

	.linkSec li a {
		padding: 14px 0;
		font-size: 1.1rem;
	}

	.linkSec li a:after {
		width: 4px;
		height: 4px;
		border-top-width: 1px;
		border-right-width: 1px;
		bottom: 5px;
		right: 7px;
	}

	.linkSec li a img {
		margin: 8px auto 0;
		height: 36px;
		width: auto;
	}
}

.tabPanel {
	margin: 28px auto 50px;
	width: 960px;
}

.tabPanel .tabUl {
	border-bottom-width: 2px;
	border-bottom-style: solid;
}

.tabPanel .tabUl li {
	padding: 10px;
	float: left;
	width: 479px;
	font-size: 1.4rem;
	font-weight: bold;
	text-align: center;
	cursor: pointer;
	border-radius: 4px 4px 0 0;
}

.ieLess8 .tabPanel .tabUl li {
    padding: 10px 0px 10px 0px;
    font-size: 14px;
}

.tabPanel .tabUl li:last-child {
	float: right;
}

/*お知らせタブ*/
.notice-tab {
    float: right !important;
}
.notice-tab:after {
    clear: both;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.tabPanel {
		margin: 14px auto 30px;
		width: auto;
	}

	.tabPanel .tabUl {
		padding: 0 15px;
		border-bottom: none;
	}

	.tabPanel .tabUl li {
		padding: 8px;
		width: 49.8%;
		font-size: 1.3rem;
		border-radius: 2px 2px 0 0;
	}

	.tabPanel .comNews {
		margin: 0;
	}
}

.notice {
	position:relative;
	margin: -30px 0 30px;
	padding: 3px;
	background: url(/images/index/news_bg.png) repeat left top;
}

.notice .ttl {
	padding: 12px;
	font-size: 2em;
	font-weight: bold;
	text-align: center;
}

.notice .ttl img {
	/*margin-top: 12px;*/
	margin-right: 12px;
}

.notice .newsDl dt .news {
	padding: 1px 5px;
	border-width: 1px;
	border-style: solid;
}

.notice .newsDl dd:nth-child(2) {
	border-top: none;
}

/*TGC追加*/
.notice .newsDl dd {
	padding: 11px 0 11px 26px;
}

.notice .newsDl dd a {
	position: relative;
}

.notice .newsDl dd a:before {
	width: 4px;
	height: 4px;
	border-top-width: 2px;
	border-top-style: solid;
	border-right-width: 2px;
	border-right-style: solid;
  	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	position: absolute;
	top: 7px;
	left: -15px;

	content: "";
}

.notice .blank .blankSpan {
	padding-right: 20px;
	background: url(/images/common/icon/icon07.png) no-repeat right center;
	-webkit-background-size: 10px auto;
	background-size: 10px auto;
}

.notice .pdf .pdfSpan {
	padding-right: 25px;
	background: url(/images/common/icon/icon08.png) no-repeat right center;
	-webkit-background-size: 14px auto;
	background-size: 14px auto;
}
/*TGC追加*/


.notice01 {
	margin-top: 30px;
}

.notice01 .noticeList li {
	padding: 15px 20px;
	font-size: 1.3rem;
	line-height: 1.6;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
}

.notice01 .noticeList li:last-child {
	border-bottom: none;
}

.notice01 .noticeList li .txt {
	display: block;
	font-weight: bold;
}

.notice01 .noticeList li a {
	text-decoration: underline;
}

.notice01 .noticeList li a:hover {
	text-decoration: none;
}

.notice01 .noticeList li .fltImg {
	margin: 5px 0 0 15px;
	float: right;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.notice {
		margin: -45px 15px 30px;
		padding: 2px;
		background-size: 1px 1px;
		-webkit-background-size: 1px 1px;
	}

	.notice .ttl {
		padding: 10px;
		font-size: 1.4em;
	}

	.notice .ttl img {
		margin-top: 4px;
		margin-right: 4px;
		width: 17px;
		height: 16px;
	}

	.notice .newsDl dt {
		padding: 5px 10px 2px;
	}

	.notice .newsDl dd {
		/*padding: 0 10px 7px !important;*/
		padding: 10px 10px 10px 25px!important;
	}

	.notice01 {
		margin: 15px 0 25px;
	}

	.notice01 .noticeList li {
		padding: 10px;
		font-size: 1.2rem;
	}

	.notice01 .noticeList li .fltImg {
		display: none;
	}
}

.banner {
	margin-bottom: 70px;
}

.banner .sliderBox {
	margin-bottom: 7px;
}

.banner .sliderBox .slider {
	padding: 15px 10px;
	margin: 0 auto;
	width: 918px;
	border-top-width: 1px;
	border-top-style: solid;
	border-bottom-width: 1px;
	border-bottom-style: solid;
}

.banner .sliderBox .slider .swiper-slide {
	height: 37px;
	display: table;
	width: 141px;
}

.banner .sliderBox .slider .swiper-slide a {
	display: table-cell;
	vertical-align: middle;
}

.banner .btmInner ul {
	margin-top: 13px;
	float: left;
	width: 543px;
}

.banner .btmInner li {
	margin-right: 10px;
}

.banner .btmInner .link {
	float: right;
	width: 330px;
}

.banner .btmInner .link a {
	display: block;
	text-decoration: none;
	overflow: hidden;
}

.banner .btmInner .link img {
	float: left;
}

.banner .btmInner .link .txt {
	padding: 15px 0 0 130px;
	display: block;
	font-size: 1.1rem;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.banner {
		margin-bottom: 30px;
	}

	.banner .sliderBox {
		margin-bottom: 7px;
		display: block;
	}

	.banner .sliderBox .slider {
		padding: 14px 30px;
		margin: 0 auto;
		width: auto;
	}

	.banner .sliderBox .slider .swiper-slide {
		width: 80px;
		height: auto;
	}

	.banner .sliderBox .slider .swiper-slide img {
		width: 100%;
		height: auto;
	}

	.banner .sliderBox .prev,.banner .sliderBox .next {
		width: 15px;
		height: 50px;
	}

	.banner .sliderBox .prev:before,
	.banner .sliderBox .next:before {
		left: 3px;
	}

	.banner .btmInner {
		margin: 0 15px 10px;
	}

	.banner .btmInner ul {
		margin: 0 0 10px;
		float: none;
		width: auto;
	}

	.banner .btmInner li {
		margin: 0 auto;
		width: 48%;
	}

	.banner .btmInner li img {
		width: 100%;
		height: auto;
	}

	.banner .btmInner .link {
		margin: 0 auto;
		float: none;
		width: 250px;
	}

	.banner .btmInner .link img {
		width: 62px;
		height: 35px;
	}

	.banner .btmInner .link .txt {
		padding: 0 0 0 67px;
		font-size: 1rem;
	}
}

/*------------------------------------------------------------
	kojin/mynet
------------------------------------------------------------*/
.imgBox {
	position: relative;
}

.imgBox .fltImg {
	position: absolute;
	right: 0;
	top: 0;
}

.imgBox p {
	margin: 0 160px 15px 0;
	font-size: 1.4rem;
	line-height: 1.75;
}

.btnBox {
	padding: 15px 0;
	border-width: 2px;
	border-style: solid;
}

.btnBox .link01 {
	margin: 0 auto;
	width: 320px;
}

.btnBox .link01 a {
	padding: 10px 15px 11px;
	display: block;
	font-size: 1.9rem;
	font-weight: bold;
	text-decoration: none;
	overflow: hidden;
	border-radius: 2px;
}

.btnBox .link01 a img {
	margin: 4px 15px 0 0;
	float: left;
}

.btnBox .link01 a .txt {
	margin-right: 12px;
	display: block;
	float: left;
	width: 49px;
	font-size: 1.2rem;
	vertical-align: middle;
	line-height: 1.2;
}

.sBtn01List {
	margin-bottom: 30px;
}

.sBtn01List li {
	margin: 0 10px 10px 0;
	float: left;
}

.sBtn01List .liStyle a {
	padding: 3px 18px;
	line-height: 1.25;
}

.sBtn01List li:nth-child(3n) {
	margin-right: 0;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.imgBox {
		position: inherit;
	}

	.imgBox .fltImg {
		position: inherit;
		right: auto;
		top: auto;
		text-align: center;
	}

	.imgBox p {
		margin: 0 0 15px;
		font-size: 1.2rem;
		line-height: 1.4;
	}

	.btnBox {
		margin-bottom: 10px;
		padding: 15px;
		border-width: 1px;
	}

	.btnBox .link01 {
		width: 100%;
	}

	.btnBox .link01 a {
		padding: 7px 15px 5px;
		font-size: 1.6rem;
	}

	.btnBox .link01 a img {
		margin-top: 5px;
		width: 18px;
		height: 24px;
	}

	.btnBox .link01 a .txt {
		margin-right: 0;
		float: none;
		width: auto;
		font-size: 1.2rem;
		line-height: 1.15;
	}

	.sBtn01List {
		border-bottom-style: solid;
		border-bottom-width: 1px;
	}

	.sBtn01List li {
		margin: 0;
		float: none;
	}

	.sBtn01List .sBtn01 {
		border-bottom: none;
	}

	.sBtn01List .liStyle a {
		padding: 6px 12px;
	}

	.sBtn01List .spStyle a {
		padding: 10px 12px;
	}

}


#main .linkUl02 li {
	float: right;
}

#main .linkUl02 li:first-child {
	float: left;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	#main .linkUl02 li {
		float: none !important;
	}
}

#main .linkUl03 li {
	float: left;
	margin-right: 10px;
}

#main .linkUl03 li:last-child {
	margin-right: 0;
}


#main .linkUl_info li {
	float: left;
	margin-right: 10px;
}

#main .linkUl_info li:nth-of-type(3n) {
	margin-right: 0;
}

#main .linkUl_info li .sBtn01 {
	margin: 10px 0!important;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	#main .linkUl03 li,
	#main .linkUl_info li {
		margin: 0;
		float: none !important;
	}
}


/*------------------------------------------------------------
	detail
------------------------------------------------------------*/
.contsBox li {
	margin-top: 8px;
	padding-left: 1em;
	text-indent: -1em;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.75;
}

.contsBox li p {
	text-indent: 0;
	font-weight: normal;
}

.contsBox li:first-child {
	margin-top: 0;
}

.tableType td a {
	text-decoration: underline;
}

.tableType td a:hover {
	text-decoration: none;
}

.tarTxt {
	text-align: right;
	font-size: 1.4rem;
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.contsBox li {
		margin-top: 5px;
		font-size: 1.2rem;
	}

	.contsBox li p {
		line-height: 1.75;
	}

	.tarTxt {
		font-size: 1.2rem;
	}
}

/* Google検索 ×アイコン削除 */
.gsib_b { display: none!important; }

.w20 {
    width: 20%;
}

.w40 {
    width: 40%;
}

.cm_movie video{width: 100%;}

/* Add Follow Button */
.sendaiHelpfeel {
	position: fixed;
	bottom: 8px;
	right: 0;
	width: 186px;
	z-index: 100000;
	transition: all 0.3s ease;
	transform: translateX(0);
}

.sendaiHelpfeel.is-hidden {
	opacity: 0;
	transform: translateX(50vw);
}

.sendaiHelpfeelBtn {
	position: relative;
	z-index: 1;
	display: block;
}

#sendaiHelpfeelClose {
	position: absolute;
	top: 6px;
	right: 8px;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	z-index: 2;
	cursor: pointer;
	background: #fff;
	opacity: 0;
	transition: opacity 0.3s ease;
}

#sendaiHelpfeelClose:hover {
	opacity: 0.5;
}

@media only screen and (min-width: 1013px) and (max-height: 720px) {
	.comSideUl {
		top: 102px;
	}
}

@media only screen and (min-width: 1013px) and (max-height:610px) {
	.sendaiHelpfeel {
		right: 50px;
	}
}

@media only screen and (min-width: 0) and (max-width: 1012px) {
	.sendaiHelpfeel {
		width: 148.8px;
		bottom: 66px;
		right: -5px;
	}

	#sendaiHelpfeelClose {
		top: 4.8px;
    right: 6.4px;
    width: 22.4px;
    height: 22.4px;
	}
}