@charset "utf-8";

/**
 *
 *  コンテンツ共通
 *
 */

/*--------------------------------------------------------------------------
   汎用スタイル
---------------------------------------------------------------------------*/

/* テキスト強調
-----------------------------------------------------------------*/
.em-w{
	font-weight: bold;
}
.em-c,
.em-c a{
	color: #FF3300;
}
.em-c02,
.em-c02 a{
	color: #DA101E;
}
.em-c03,
.em-c03 a{
	color: #F7A814;
}
.em-c04,
.em-c04 a{
	color: #D9101E;
}


/* ルビ
-----------------------------------------------------------------*/
ruby rt{
	text-align: left;
}
/* firefoxハック ルビ対応 */
_:-moz-tree-row(hover), ruby{
	position: relative;
	display: inline-block;
	padding-top: 12px;
}
_:-moz-tree-row(hover), ruby rt{
	position: absolute;
	display: inline-block;
	top: 0;
	left: 0;
	width: 120%;
	font-size: 11px;
}
_:-moz-tree-row(hover), a:hover ruby{
	text-decoration: underline;
}

/* 配置
-----------------------------------------------------------------*/
.t-ct{
	text-align: center;
}
.t-lt{
	text-align: left;
}
.t-rt{
	text-align: right;
}
.t-sup{
	position: relative;
	top: -5px;
	font-size: 12px;
	vertical-align: super;
}
/* 縦書 */
/* firefox用 */
_:-moz-tree-row(hover), .t-vrl {
	display: inline-block;
	transform-origin : 50% 50%;
	transform: rotate(-90deg);
}
.t-vrl{
	writing-mode: tb-rl; /* IE独自仕様 */
	writing-mode: vertical-rl;
	-moz-writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
}

/* androidバグ回避用
-----------------------------------------------------------------*/
.dev-sp .p-wrap{
	background-image: url(/maintenance/images/spacer.gif);
}
.dev-sp .p-wrap02{
	display: block;
	background-image: url(/maintenance/images/spacer.gif);
}


/* 段落
-----------------------------------------------------------------*/
.p-gap{
	margin-top: 15px;
}
.p-gap02{
 margin-top: 25px;
}

/* インデント
-----------------------------------------------------------------*/
.note{
	display: inline-block;
	margin-top: 10px;
	text-indent: -1em;
	padding-left: 1em;
	line-height: 1.4;
}
.note._no-gap{
	margin-top: 0;
}

/* イメージ
-----------------------------------------------------------------*/
.img-shadow{
	padding: 4px;
	border: 1px solid #E1E1E1;
	-webkit-box-shadow: 0 0 2px rgba(0,0,0,0.1);
	box-shadow: 0 0 2px rgba(0,0,0,0.1);
	background: #fff;
}

/* レイアウト枠
-----------------------------------------------------------------*/
.b_content{
	width: 978px;
	margin: 0 auto;
}

/* b_section */
.b_section{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	width: 100%;
	margin-top: 30px;
	border: 1px solid #E1E1E1;
	-webkit-box-shadow: 0 0 2px rgba(0,0,0,0.1);
	        box-shadow: 0 0 2px rgba(0,0,0,0.1);
	background: #fff;
}
.b_section:first-child{
	margin-top: 0;
}
.b_section._has-line{
	position: relative;
	padding-top: 3px;
}
.b_section._has-line:before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 4px;
	background: #328AD1;
}

/* b_inline */
.b_inline{
	padding: 30px;
}
.b_inline._prev-ttl{
	padding-top: 0;
}
.b_inline._separate{
	border-top: 1px solid #DEDEDF;
}
.b_inline._bg{
	background: url(/maintenance/images/bg_texture04.png);
}

/* b_inside */
.b_inside{
	margin-top: 35px;
}

/* SP レイアウト枠
-----------------------------------------------------------------*/
.dev-sp .b_content{
	width: 720px;
	padding: 0 30px;
}


/* ボックススタイル
-----------------------------------------------------------------*/
/* box-style01 */
.box-style01{
	margin-top: 15px;
	padding: 3px;
	background: url(/maintenance/images/bg_texture03.png);
}
.box-style01._no-gap{
	margin-top: 0;
}
.box-style01 .box-inner{
	padding: 8px;
	background: #fff;
}

/* box-style02 */
.box-style02{
	margin-top: 20px;
	padding: 20px;
	background: #F0F0F0;
}
.box-style02._no-gap{
	margin-top: 0;
}

/* box-style03 */
.box-style03{
	margin-top: 15px;
	padding: 27px 12px;
	border: 2px solid #D7000F;
	background: #fff;
}
.box-style03._no-gap{
	margin-top: 0;
}


/* アイコン
-----------------------------------------------------------------*/
.ico-link,
a.ico-link{
 color: #102740;
 display: inline-block;
 padding-left: 20px;
 background: url(/maintenance/images/ico_arw05.png) no-repeat 0 50%;
}
.ico-link02,
a.ico-link02{
	color: #102740;
	display: inline-block;
	padding-left: 27px;
	background: url(/maintenance/images/ico_arw03.png) no-repeat 0 50%;
}
.ico-circle{
	padding-left: 1em;
	background: url(/maintenance/images/ico_circle.png) no-repeat 0 .5em;
}
.ico-circle02{
	display: inline-block;
	min-height: 13px;
	padding-left: 20px;
	background: url(/maintenance/images/ico_circle02.png) no-repeat 0 50%;
}


/* リンクアイコン
-----------------------------------------------------------------*/
/* blank */
.link-blank{
	position: relative;
	padding-right: 15px;
}
.link-blank:after{
	content: "";
	display: block;
	position: absolute;
	right: 0;
	bottom: .2em;
	width: 10px;
	height: 9px;
	background: url(/maintenance/images/ico_blank.png) no-repeat;
}
.link-blank02{
	position: relative;
	padding-right: 15px;
}
.link-blank02:after{
	content: "";
	display: block;
	position: absolute;
	right: 0;
	bottom: .2em;
	width: 10px;
	height: 9px;
	background: url(/maintenance/images/ico_blank02.png) no-repeat;
}

/* pdf */
.link-pdf{
	position: relative;
	padding-right: 38px;
}
.link-pdf:after{
	content: "";
	display: block;
	position: absolute;
	right: 0;
	bottom: .1em;
	width: 32px;
	height: 15px;
	background: url(/maintenance/images/ico_pdf.png) no-repeat;
}


/* タイトル
-----------------------------------------------------------------*/
/* ttl-style01 */
.ttl-style01{
	margin-bottom: 18px;
	font-size: 172%;
	font-weight: bold;
	line-height: 1.6;
}
.ttl-style01 .em{
	color: #FFB01E;
}

/* ttl-style02 */
.ttl-style02{
	margin-bottom: 30px;
	padding: 12px 30px;
	background: #328AD1;
	color: #fff;
	font-size: 136%;
	font-weight: bold;
	line-height: 1.4;
}
.ttl-style02._clr02{
	background: #F6A814;
}
.ttl-style02 .sub{
  margin-left: 1em;
  font-size: 12px;
  font-weight: normal;
}

/* ttl-style03 */
.ttl-style03{
	margin-bottom: 25px;
	padding-bottom: 10px;
	border-bottom: 2px solid #328AD1;
	font-size: 129%;
	font-weight: bold;
	line-height: 1.2;
}
.ttl-style03 ._fs-s{
	margin-left: 6px;
	font-size: 12px;
	font-weight: normal;
}
.dev-sp .ttl-style03{
	background-image: url(/maintenance/images/spacer.gif);
}

/* ttl-style04 */
.ttl-style04{
	margin-bottom: 30px;
	padding: 22px 30px 18px;
	border-bottom: 1px solid #E1E1E1;
	background: url(../images/bg_texture05.png);
	font-size: 186%;
	font-weight: bold;
	line-height: 1.2;
}
.ttl-style04 ._fs-s{
	font-size: 14px;
	font-weight: normal;
}
.ttl-style04 ._fs-m{
	font-size: 18px;
	margin-left: 16px;
}
.ttl-style04 ._m0{
	margin:0;
}


/* ttl-style05 */
.ttl-style05{
	margin-bottom: 17px;
	color: #328AD1;
	font-weight: bold;
	line-height: 1;
	background: url(../images/bg_ttl_style05.png) repeat-x 0 50%;
}
.ttl-style05 span{
	display: inline-block;
	background: #fff;
	padding-right: 10px;
}

/* ttl-style06 */
.ttl-style06{
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	margin-bottom: 30px;
	padding: 22px 30px 18px;
	background: url(../images/bg_texture05.png);
	-webkit-box-shadow: 0 0 1px rgba(0,0,0,0.3);
	box-shadow: 0 0 1px rgba(0,0,0,0.3);
	font-size: 186%;
	font-weight: bold;
	line-height: 1.1;
}
.ttl-style06:after{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 4px;
	background: #328AD1;
}
	

/* ボタン
-----------------------------------------------------------------*/
.btn-style01{
	overflow: hidden;
	width: 319px;
}
.btn-style01 a{
	display: block;
	border-radius: 5px;
	border: 2px solid #BED7ED;
	color: #102740;
	text-decoration: none;
	background-color: #fff;
}
.btn-style01 a:hover{
	color: #FFF;
	background-color: #4F9AD7;
	border-color: #1072BD;
}
.btn-style01 .inner{
	display: table-cell;
	padding: 20px 20px 20px 50px;
	font-size: 129%;
	font-weight: bold;
	line-height: 1.4;
	vertical-align: middle;
	background: url(/maintenance/images/ico_arw05.png) no-repeat 20px 50%;
}
.btn-style01 a:hover .inner{
	background: url(/maintenance/images/ico_arw13.png) no-repeat 20px 50%;
}
.btn-style01 .inner ._fs-s{
	font-size: 14px;
}


/* リスト
-----------------------------------------------------------------*/
/* リスト2カラム */
.list-base{
	overflow: hidden;
}
.list-base._clm2{
	margin-right: -20px;
}
.list-base._clm2 li{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	float: left;
	width: 50%;
	margin: 0;
	padding-right: 20px;
}
.list-base._clm2._spc li{
	margin-bottom: 20px;
}

.list-base._clm3{
	margin-right: -10px;
}
.list-base._clm3 li{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	float: left;
	width: 33%;
	margin: 0;
	padding-right: 10px;
}
.list-base._clm3._spc li{
	margin-bottom: 10px;
}

/* インデントリスト */
.list-note{
	margin-top: 15px;
}
.list-note._no-gap{
	margin-top: 0;
}
.list-note li{
	margin-top: 10px;
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.4;
}
.list-note._gap02 li{
	margin-top: 2px;
}
.list-note li:first-child{
	margin-top: 0;
}
/* type */
.list-note._type li{
	padding-left: 2.5em;
	text-indent: -2.5em;
}

/* list-number */
.list-number{
	margin-top: 15px;
	line-height: 1.5;
}
.list-number li{
	margin-top: 2px;
	text-indent: -1.5em;
	padding-left: 1.5em;
}
.list-number .num{
	display: inline-block;
	font-weight: bold;
	width: 1.5em;
	padding: 0;
	text-indent: 0;
}

/* type02 「(0)」 */
.list-number._type02 li{
	text-indent: -2em;
	padding-left: 2em;
}
.list-number._type02 .num{
	text-align: right;
	font-weight: normal;
	width: 1.5em;
	padding: 0 .5em 0 0;
}

/* type03 「ア 」 */
.list-number._type03 li{
	text-indent: -1.5em;
	padding-left: 1.5em;
}
.list-number._type03 .num{
	width: 1.5em;
	padding: 0;
	text-align: left;
	font-weight: normal;
}

/* サークルアイコン */
.list-circle{
	margin-top: 15px;
}
.list-circle._no-gap{
	margin-top: 0;
}
.list-circle li{
	margin-top: 10px;
	padding-left: 15px;
	background: url(/maintenance/images/ico_circle.png) no-repeat 0 .4em;
	line-height: 1.6;
}
.list-circle._gap02 li{
	margin-top: 2px;
}
.list-circle li:first-child{
	margin-top: 0;
}
.list-circle li._no-ico{
	background: none;
}


/* テーブル
-----------------------------------------------------------------*/

.tbl-style{
	width: 100%;
	table-layout: fixed;
}
.tbl-style ._fs-s{
	font-size: 86%;
}
.tbl-style th,
.tbl-style td{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	padding: 8px 10px;
	border: 1px solid #ccc;
	vertical-align: middle;
}
.tbl-style th{
	background: #F1F8FC;
	font-weight: bold;
	font-weight: bold;
}

/* 背景カラー */
.tbl-style._clr01 th{
	background: #EAEAEA;
}

/* テキスト寄せ */
.tbl-style._t-ct td{
	text-align: center;
}

/* スタイルリセット */
.tbl-style ._no-style{
	background: none !important;
	font-weight: normal !important;
}

/* セルボーダー */
.tbl-style .bd-r{
	border-width: 1px 2px 1px 1px;
}

/* 2カラム */
.tbl-style._clm2 th,
.tbl-style._clm2 td{
	width: 50%;
}

/* 3カラム */
.tbl-style._clm3 th,
.tbl-style._clm3 td{
	width: 33.3%;
}

/* 5カラム */
.tbl-style._clm5 th,
.tbl-style._clm5 td{
	width: 20%;
}

/* 6カラム */
.tbl-style._clm6 th,
.tbl-style._clm6 td{
	width: 16%;
}

/* 7カラム */
.tbl-style._clm7 th,
.tbl-style._clm7 td{
 width: 14.2%;
}

/* 8カラム */
.tbl-style._clm8 th,
.tbl-style._clm8 td{
	width: 12.5%;
}


/* 横幅決め打ち指定 */
.tbl-style .w01{
	width: 104px;
}
.tbl-style .w02{
	width: 130px;
}
.tbl-style .w03{
	width: 84px;
}
.tbl-style .w04{
	width: 110px;
}
.tbl-style .w05{
	width: 178px;
}
.tbl-style .w06{
	width: 127px;
}
.tbl-style .w07{
	width: 97px;
}
.tbl-style .w08{
	width: 143px;
}
.tbl-style .w09{
 width: 225px;
}
.tbl-style .w10{
 width: 158px;
}
.tbl-style .w11{
 width: 145px;
}
.tbl-style .w12{
 width: 129px;
}

/* 背景色 */
.tbl-style th.bc-yel{
	background:#FFFDEE;
}

/*--------------------------------------------------------------------------
   共通パーツ
---------------------------------------------------------------------------*/

/* カテゴリタイトル
-----------------------------------------------------------------*/
.cmn_cat-title{
	background: url(/maintenance/images/bg_pagetitle.png);
}
.cmn_cat-title .b_content{
	position: relative;
	height: 160px;
}
.cmn_cat-title img{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}

/* SP カテゴリタイトル
-----------------------------------------------------------------*/
.dev-sp .cmn_cat-title img{
	left: 30px;
}


/* 画像 + テキスト
-----------------------------------------------------------------*/
.cmn_box-img{
	overflow: hidden;
}
.cmn_box-img .col-img._left{
	float: left;
	margin-right: 20px;
}
.cmn_box-img .col-img._right{
	float: right;
	margin-left: 20px;
}
.cmn_box-img .col-txt{
	overflow: hidden;
}

/* 天地中央寄せ */
.cmn_box-img02{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	width: 100%;
}
.cmn_box-img02 .col{
	display: table-cell;
	vertical-align: middle;
}


/* フォーム
-----------------------------------------------------------------*/
/* table */
table.form-tbl{
}

/* input */
input.input-base{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

/* textarea */
textarea.textarea-base{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	resize: vertical;
}


/* ページタイトル
-----------------------------------------------------------------*/
.cmn_page-ttl{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	display: table;
	width: 100%;
	margin-bottom: 20px;
}
.cmn_page-ttl .col-left{
	display: table-cell;
	width: 369px;
	text-align: center;
	vertical-align: middle;
	font-size: 29px;
	font-weight: bold;
	line-height: 1;
}
.cmn_page-ttl .col-right{
	display: table-cell;
}
.cmn_page-ttl .col-right img{
	margin-right: -1px;
}
.cmn_page-ttl .col-right img:not(*:root) {
	margin-right: 0;
}


/* cmn_anchor アンカーリンク
-----------------------------------------------------------------*/
.cmn_anchor{
	margin-bottom: 40px;
	border: 2px solid #328AD1;
	background: #fff;
}
.cmn_anchor a{
	text-decoration: none;
}
.cmn_anchor .link{
	display: inline-block;
	padding-left: 24px;
	background: url(/maintenance/images/ico_arw04.png) no-repeat 0 50%;
	color: #102740;
	font-weight: bold;
}
.cmn_anchor a:hover .link{
	color: #328AD1;
}
.cmn_anchor ul{
	overflow: hidden;
}
.cmn_anchor li{
	float: left;
	text-align: center;
}
.cmn_anchor li a{
	display: block;
	padding: 6px 0;
}
.cmn_anchor li a:hover{
	background-color: #3386C5;
}
.cmn_anchor li a:hover .link{
	background-image: url(../images/ico_arw15.png);
	color: #FFF;
}
.cmn_anchor li .inner{
	display: block;
	padding: 10px 6px;
	background: url(/maintenance/images/line_dot.png) repeat-y 0 0;
}
.cmn_anchor li:first-child .inner{
	background: none;
}
.cmn_anchor._row3{
	width:99.9%;
}
.cmn_anchor._row3 li{
	width: 33.33%;
}
.cmn_anchor._row4 li{
	width: 25%;
}


/* cmn_pagetop ページトップ
-----------------------------------------------------------------*/
.cmn_pagetop{
	margin-top: 12px;
	font-size: 93%;
	text-align: right;
}
.cmn_pagetop a{
	padding-left: 16px;
	background: url(/maintenance/images/ico_pagetop.png) no-repeat 0 50%;
	color: #102740;
	text-decoration: none;
}
.cmn_pagetop a:hover{
	text-decoration: underline;
}


/* cmn_pagination ページネーション
-----------------------------------------------------------------*/
.cmn_pagination{
	margin-top: 40px;
	text-align: center;
	letter-spacing: -.4em;
}
.cmn_pagination ul{
	display: inline-block;
	width: 100%;
}
.cmn_pagination ul li,
.cmn_pagination p{
	display: inline-block;
	margin: 0 5px;
	background:#FFF;
	line-height: 1;
	letter-spacing: normal;
}
.cmn_pagination a,
.cmn_pagination span{
	position: relative;
	display: block;
	padding: 13px 16px 12px;
	border: 1px solid #E0E0E0;
	text-decoration: none;
	color: #102740;
}
.cmn_pagination a:hover,
.cmn_pagination a.active,
.cmn_pagination span{
	background: #3386C5;
	color: #FFF;
	border-color: #3386C5;
}
.cmn_pagination a.no-active{
	cursor: normal;
	visibility: hidden;
}
.cmn_pagination .next{
	margin-left: 40px;
}
.cmn_pagination .prev{
	margin-right: 40px;
}
.cmn_pagination .prev a:after,
.cmn_pagination .next a:after{
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 8px;
	height: 10px;
	margin: -5px 0 0 -4px;
}
.cmn_pagination .prev a:after{
	background: url(/maintenance/images/ico_prev.png) no-repeat;
}
.cmn_pagination .next a:after{
	background: url(/maintenance/images/ico_next.png) no-repeat;
}
.cmn_pagination .prev a:hover:after,
.cmn_pagination .next a:hover:after{
	background-position: 0 -10px;
}


/* インデックスリスト01
-----------------------------------------------------------------*/
.cmn_index-list01{
	margin: 10px 0;
}
.cmn_index-list01 .list{
	margin-top: 30px;
	border: 2px solid #C9DEF0;
	border-radius: 5px;
}
.cmn_index-list01 .list a{
	text-decoration: none;
}
.cmn_index-list01 .list:first-child{
	margin-top: 0;
}
.cmn_index-list01 .list .ttl-style01{
	margin-bottom: 16px;
	font-size: 26px;
}
.cmn_index-list01 .ico-link{
	background-position: 0 55%;
	text-decoration: none;
}
@media screen and (-webkit-min-device-pixel-ratio:0) {
	.cmn_index-list01 .ico-link{
		background-position: 0 60%;
	}
}
@-moz-document url-prefix() {
  .cmn_index-list01 .ico-link{
	background-position: 0 65%;
  }
}
.cmn_index-list01 .list ruby{
	ruby-align: left;
}
.cmn_index-list01 .list .col{
	display: table-cell;
	vertical-align: middle;
}
.cmn_index-list01 .list .img img{
	border-radius: 0 3px 3px 0;
}
.cmn_index-list01 .list .img._fit img{
	margin: -2px;
}
.cmn_index-list01 .list .txt{
	padding: 0px 26px 15px;
	line-height: 1.6;
}
.cmn_index-list01 .list .txt .terminal{
	font-size: 93%;
	font-weight: bold;
}
.cmn_index-list01 .list .txt .address{
	margin-bottom: 11px;
	font-size: 86%;
}
.cmn_index-list01 .list table{
	font-size: 93%;
	background: #fff;
}

/* hover */
.cmn_index-list01 .list.hover{
  border-color: #1877C0;
  background: #4F9AD7;
  text-decoration: none;
}
.cmn_index-list01 .list a:hover ruby{
	text-decoration: none;
}
.cmn_index-list01 .list.hover .ico-link{
	background: url(/maintenance/images/ico_arw13.png) no-repeat;
	background-position: 0 55%;
	background-position: 0 22px¥9;
	color: #fff;
}
.cmn_index-list01 .list.hover .txt .terminal,
.cmn_index-list01 .list.hover .txt .address{
	color: #fff;
}

/* 下部バナー
-----------------------------------------------------------------*/
.cmn_bt-bnr{
	margin-top: 30px;
}
.cmn_bt-bnr ul li{
	display: inline-block;
	border: 2px solid #338AD1;
	-webkit-box-shadow : 0 0 3px rgba(0, 0, 0, 0.5);
	        box-shadow : 0 0 3px rgba(0, 0, 0, 0.5);
}
.cmn_bt-bnr ul{
	width: 738px;
	margin-right: -18px;
}
.cmn_bt-bnr ul li{
	float: left;
	margin-right: 18px;
}
.cmn_bt-bnr a{
	display: block;
}
.cmn_bt-bnr a:hover{
	-ms-filter: "alpha(opacity=70)";
	filter: alpha(opacity=70);
	opacity: .7;
}
