@charset "utf-8";

@import url("pc.css") screen and (min-width:1001px);
@import url("tb.css") screen and (min-width:768px) and (max-width:1000px);
@import url("sm.css") screen and (max-width:767px);

@import url("pc_tb.css") screen and (min-width:768px);

* {
	margin:0;
	padding:0;
	color: #323232;
	font-family:"メイリオ";
	font-size:16px;
}
ul li{ list-style:none;}
a{ text-decoration:none;
	color: #323232;
}
a:link { color: #0000ff; }
a:visited { color: #000080; }
a:hover { color: #ff0000; }
a:active { color: #ff8000; }

.text_center{
	text-align:center;
}
.text_left{
	text-align:left;
}
.bgC60000{
 background-color:#C60000;
}
.fbold{
	font-weight:bold;
}
.colorFFF{
	color:#FFF;
}
.colorC60000{
	color:#C60000;
}
.f11{
	font-size:11px;
}
.f18{
	font-size:18px;
}
.f21{
	font-size:21px;
}
.f22{
	font-size:22px;
}
.f23{
	font-size:23px;
}
.f24{
	font-size:24px;
}
.f32{
	font-size:32px;
}
.border{
	border:1px solid #CCCCCC;
}
.border_bottm{
	border-bottom:1px solid #CCCCCC;
}

.lh120{
	line-height:120%;;
}

.lh180{
	line-height:180%;;
}

.p20{
	padding:20px;
}

.pl20{
	padding-left:20px;
}


.radius{
	border-radius: 5px;         /* CSS3 */
	-moz-border-radius: 5px;    /* Firefox */
	-webkit-border-radius: 5px; /* Safari,Chrome */
}

ul.list_style_kuromaru li,
ul.list_style_kome li{
	list-style-type: none;
	margin-left:1.5em;/* マーカーを1文字寄せた分、ULにマージンを設定*/
}

ul.list_style_kuromaru li:before {
	content: '● '; /* ←ここにリストマーカーにしたい文字列を設定 */
	font-size:130%;
	margin-left:-1em; /* 1文字分、左に寄せる */
}
ul.list_style_kome li:before {
	content: '※ '; /* ←ここにリストマーカーにしたい文字列を設定 */
	margin-left:-1em; /* 1文字分、左に寄せる */
}
.space30{
	clear:both; height:30px; 
}
ul.listdisc{
	padding-left:20px;
}
ul.listdisc li{
	list-style:disc;
}



#container{
	clear:both;
	padding-bottom:50px;
}


#plist{
	height:44px;
	padding-left:30px;
	background-color:#F2F2F2;
}

#plist ol li {
	display: inline;
	list-style-type: none;
	line-height:44px;
}
#plist ol li a::after  {
	content:" > ";
}


.cate_head{
	background-image:url(/_img/share/bg_h1.png);
	color:#fff;
}
.cate_head_white{
	background-image:url(/_img/share/bg_h1_w.png);
	color:#000;
}
.cate_head_news{
	background-image:url(/_img/share/bg_h1_n.png);
	color:#000;
}
.cate_head_support_edu{
	background-image:url(/_img/share/bg_h1_se.png);
	color:#000;
}

.cate_head::before,
.cate_head_white::before,
.cate_head_bg::before,
.cate_head_support_edu::before{
  border-bottom:2px solid #C60000;
  width: 24%;
  position: absolute;z-index: 1;bottom: 0;left: 0;
  content: "";
}
.cate_head::after,
.cate_head_white::after,
.cate_head_bg::after,
.cate_head_support_edu::after{
  border-bottom:2px solid #656565;
  width: 100%;
  position: absolute;bottom: 0;left: 0;
  content: "";
}


/**トップページ用**/
#container .top_cate{
	display:table-cell;
	width:160px;
	text-align:center;
}
#container .top_cate p{
	padding-left:6px;
	font-size:13px;
	line-height:180%;
	text-align:left;
}

#top_news,
#news{
	clear:both;
	position:relative;
	margin-top:20px;
	padding:20px;
}
#top_news::before{
  border-top: solid 2px #C60000;
  width: 24%;
  position: absolute;z-index: 1;top: 0;left: 0;
  content: "";
}
#top_news::after {
  border-top: solid 2px #656565;
  width: 100%;
  position: absolute;top: 0;left: 0;
  content: "";
}

#top_news table,
#news table{
	margin-top:20px;
}
#top_news table tr td.c,
#news table tr td.c{
	text-align:center;
	white-space:nowrap;
	vertical-align:top;
}

#top_news table tr td,
#news table tr td{
	padding:2px 10px;
}





#container h1{
	font-size:32px;
	text-align:center;
	font-weight:normal;
	padding:50px 0;
}

.sub{
	padding:20px;
}
.sub ul{
	padding-left:30px;
}

.sub2 img{
	margin-top:30px;
}

.sub4.border{
	border:1px solid #CCCCCC;
}
.sub4.h66{
	height:66px;
	display:table-cell;
	vertical-align:middle;
}
.inlineb{
	display:inline-block;
	vertical-align:top; 
}


.sub2 h2{
	font-size:28px;
	margin:10px 0;
}

.sub2 h3{
	font-size:18px;
	font-weight:bold;
	margin-bottom:10px;
}

.sub2 p{
	padding:0 20px;
	line-height:180%;
}

.sub1{
	text-align:center;
}
.sub1 h2{
	font-weight:normal;
	font-size:32px;
	margin-bottom:30px;
}

.sub1 p{
	font-size:18px;
	line-height:180%;
	margin-top:30px;
}
#container #submenu{
	height:44px;
	text-align:center;
	border-bottom:1px solid #CCCCCC;
}

#container #submenu ol li {
	display: inline;
	list-style-type: none;
	line-height:44px;
	padding:0 20px;
}

#container .border_topbottm{
	border-top:1px solid #CCCCCC;
	border-bottom:1px solid #CCCCCC;
	padding:30px 0;
}


.sub2_table,
.sub2_table_noborder{
	display:table;
	border-spacing:4px 0;
}

.sub2_table_nofixed{
	display:table;
	table-layout:auto;
}

.sub2_table{
	padding-bottom:30px;
	border-bottom:1px solid #CCCCCC;
	margin-bottom:30px;
}
.sub3_table{
	display:table;
	table-layout:fixed;
	border-spacing:5px 0;
	width:100%;
}
.sub3{
	display:table-cell;
}
.sub4_table{
	display:table;
	table-layout:fixed;
	border-spacing:12px 0;
	clear:both;
}
.sub2{
	text-align:center;
	display:table-cell;
}
.sub2_nofixed{
	display:table-cell;
	vertical-align:top;
}
.sub4{
	text-align:center;
	display:table-cell;
	margin:4px;
}
.sub2.soltop_bgimg{
	border:1px solid #CCCCCC;
	background:url(/_img/share/bg_sub2.png) top center no-repeat;
	line-height:180%;
}


.sub2_nospace{
	display:table-cell;	
	vertical-align:top;
}

.sub4_nospace{
	display:table-cell;
}

#pruduct_top_half.sub4_table{width:100%;}


.width710{
	display:inline-block;
	clear:left;
}
a.support_inline_block{
	display:inline-block;
	width:200px;
	border:1px solid #CCC;
	text-align:center;
	position:relative;
	right:0;
}

a.full{
	display:block;
	color: inherit;
}
a.nocolor{
	color: inherit;
}

table.full_fixed{
	table-layout:fixed;
	width:100%;
	
}
table.th_va_top tr th{
	vertical-align:top;	
}
table.th_ta_left tr th{
	text-align:left;
}
table.td_va_top tr td{
	vertical-align:top;	
}
table.td_ta_left tr td{
	text-align:left;
}
table.td_prl_10 tr td{
	padding:0 10px;
}



/*フッター*/
.page-top{
    position: fixed;
    bottom: 60px;
    right: 40px;
    padding: 10px;
    background:#999;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    font-size: 16px;
    -ms-filter: "alpha(opacity=80)";
    -moz-opacity: 0.8;
    -khtml-opacity: 0.8;
    opacity: 0.8;
	z-index:10;
}
a.page-top:link { color: #fff; }
a.page-top:visited { color: #fff; }
a.page-top:hover { color: #fff; background:#CCC;}
a.page-top:active { color: #fff; }

#foot2 {
	clear:both;
	font-size:13px;
	padding-bottom:20px;
	margin-top:10px;
	padding-top:5px;
}
#foot2 p{
	float:left;
}