﻿@charset "UTF-8";

/*----------------デフォルトCSS初期化------------------*/

html, body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre,
form, fieldset, input, textarea, p, blockquote, th, td, address, options, 
select, table, tr,img  { 
	margin: 0;
	padding: 0;
}
body {
	color: #000000;
	font-size: 100%;
	font-family: "メイリオ", meiryo, Verdana, "ＭＳ Ｐゴシック", sans-serif;
	line-height: 1.7;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

fieldset , img { 
	border: 0;
}

address , caption , cite , code , dfn , em , strong , th , var {
	font-style: normal;
	font-weight: normal;
}

ol , ul {
	list-style: none;
}
li {
	list-style-type: none;
}
caption , th {
	text-align: left;
}

h1 , h2 , h3 , h4 , h5 , h6 {
	font-size: 100%;
	font-weight: normal;
}

q:before , q:after {
	content: '';
}

abbr , acronym {
	border: 0;
}

textarea {
	font-size: 100%;
	font-family: "メイリオ", meiryo, Verdana, "ＭＳ Ｐゴシック", sans-serif;
}



/*----------------スタイルシート初期設定------------------*/
*{
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
body{
	font-size:14px;
}

a{color:#0046bb;text-decoration:underline;}
a:hover{color:#0046bb;text-decoration:none;}
a:visited{color:#0046bb;}
a:active{color:#0046bb;}

img { 
	max-width:100%;
	vertical-align: bottom;
}
.clearfix{
	display: inline-block;
}
* html .clearfix{
	height: 1%;
}
.clearfix{
	display: block;
}
textarea {
	resize : none;
}
.f13{font-size:13px;}
.f14{font-size:14px;}
.f16{font-size:16px;}
.f18{font-size:18px;}
.f24{font-size:24px;}
.txtC{text-align:center;}
.txtT{vertical-align:top;}
.pink{color:#f54e5d;}
.y-green{color:#b2ac4e;}
.bold{font-weight:bold;}
.red{color:#FF0000;}
.m80{
	margin:80px 0;
}

/*----------------レイアウト------------------*/
.line_bg{
}
.line_yellow{
	width:50%;
	float:left;
	background:#FFCA47;
	height:18px;
}
.line_blue{
	width:50%;
	float:right;
	background:#679ADC;
	height:18px;
}
.line{
	width:1100px;
	margin:auto;
	position:relative;
}
.line_img{
	position:absolute;
	top:0px;
	height:18px;
}
.line_img img {
    vertical-align:baseline;
}
#header{
	height:115px;
}
#header_in{
	width:908px;
	margin-left:auto;
	margin-right:auto;
}
#logo{
	float:left;
	width:328px;
	margin:15px 0;
}
#language{
	float:right;
}
#language li{
	float:left;
	margin-top:34px;
	margin-bottom:34px;
}
.ja{
	width:106px;
	margin-left:41px;
}
.cn{
	width:98px;
}
#main{
	text-align:center;
	background:#F2F2F2;
}
#main_in{
	width:1100px;
	height:718px;
	margin:auto;
}
.headline_in{
	width:812px;
	margin:auto;
	margin-top:29px;
	padding-bottom:13px;
	padding-left:10px;
}
.hdline {
    position:relative;
    padding:10px;
    border-bottom:solid 12px #659ade;
	margin-top: 20px;
}

.hdline:before {
    content:"";
    position: absolute;
    bottom:-12px; /* ボーダーの幅 */
    left:0;
    width:18%; /* 色違いのボーダーの横幅。お好みで。 */
    height:12px;
    background-color: #ffcc45;
}
#flobox {
	width: 1100px;
	margin: 0px auto;
}
#floboxl {
	width: 800px;
	margin: 0px;
	float:  left;
}
#floboxr {
	width: 270px;
	margin: 0px;
	float:  right;
	padding-top: 0px;
}
.cl {
	clear: both;
	margin: 0px;
	padding: 0px;
}
#service_in,
#company_in{

}
#service_in{
	margin:67px auto 47px;
}
#service_in p{
	margin-bottom:12px;
}

#service_in2{
	margin:27px auto 27px auto ;
}
#service_in2 p{
	margin-bottom:12px;
}

#company_in{
	margin:77px auto 62px;
}
#company_in p{
	margin-bottom:25px;
}
#link_in{
}
#link_in{
	margin:67px auto 47px;
}
#link_in p{
	margin-bottom:12px;
}
.link_ico a:link {
	display: block;
	font-size: 18px;
	font-weight: normal;
	margin-bottom: 10px;
	background-image: url(images/link_ico.png);
	background-repeat: no-repeat;
	background-position: left center;
	padding-left: 20px;
	text-decoration: underline;
	color: #659ade;
}
.link_ico a:visited {
	font-size: 18px;
	font-weight: normal;
	margin-bottom: 10px;
	background-image: url(images/link_ico.png);
	background-repeat: no-repeat;
	background-position: left center;
	padding-left: 20px;
	text-decoration: underline;
	color: #659ade;
}
.link_ico a:hover {
	font-size: 18px;
	font-weight: normal;
	margin-bottom: 10px;
	background-image: url(images/link_ico.png);
	background-repeat: no-repeat;
	background-position: left center;
	padding-left: 20px;
	text-decoration: none;
	color: #659ade;
}

.link_ico a:active {
	font-size: 18px;
	font-weight: normal;
	margin-bottom: 10px;
	background-image: url(images/link_ico.png);
	background-repeat: no-repeat;
	background-position: left center;
	padding-left: 20px;
	text-decoration: underline;
	color: #659ade;
}
.linkbox {
	padding-bottom: 20px;
	padding-top: 20px;
	border-bottom: solid 2px #CCCCCC;
	margin-bottom: 10px;
}

.linkbox img{
	margin-bottom: 10px;
}
.float_area{
	float:left;
}
#company_in .float_area + .float_area{
	margin-left:104px;
}
.company_contents{
	overflow:hidden;
	margin-bottom:40px;
}
.margin1{
	margin-bottom:33px;
}
.margin2{
	margin-bottom:25px;
}
.bn_a {
	border-left: solid 2px #cccccc;
	border-bottom: solid 1px #cccccc;
	padding-left: 10px;
	padding-bottom: 6px;
	font-size: 20px;
	clear: both;
	margin-bottom: 20px;
}
.flobox_a {
	clear: both;
	padding-bottom: 10px;
}
.flobox_al {
	width: 64%;
	float: left;
	text-align: left;
}
.flobox_ar {
	width: 35%;
	float: right;
	text-align: right;
}
.mgb01 {
	margin-bottom: 20px;
}

.thema {
	margin-bottom: 20px;
}

ol.thema{
  counter-reset:list;
  list-style-type:none;
  font: 14px/1.6 'arial narrow', sans-serif;
  padding: 0px;
  border: solid 1px #669cdc;
	margin-top: 20px;
}
  
ol.thema li{
  position:relative;
  line-height: 30px;
  margin: 7px 0 7px 40px;
  padding-left: 10px;
  font-weight: bold;
  font-size:14px;
}
  
ol.thema li:before{
  counter-increment: list;
  content: counter(list);
  position: absolute;
  left: -35px;
  width: 30px;
  height: 30px;
  background: #669cdc;
  text-align: center;
  color: #fff;
  top: 50%;
  -moz-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
.hdbox_a {
	padding-top: 20px;
	padding-bottom: 20px;
}

#footer{
	padding-top:18px;
}
#footer_in{
	width:812px;
	margin:auto;
	padding:13px 0 12px;
	text-align:center;
}