@charset "utf-8";

.cf:before,
.cf:after {
    content: " ";
    display: table;
}

.cf:after {
    clear: both;
}

.cf {
    *zoom: 1;
}

/**
  * common style 
  * ---------------------------------------- */
img { max-width: 100%; }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

form .warning { color: #f00; font-size: 80%; }

.post p {
	letter-spacing: 1px;
	line-height: 1.5;
}

#footer li a {
	background-image: url(img/bg-arrow.png);
	background-repeat: no-repeat;
	background-position: left -8px;
	background-size: 14px;
	padding-left: 10px;
}

iframe {
    max-width: 100%;
}

/**
 * もし事故が起きてしまったら
 * ------------------------------------------- */
.flow img {
	display: block;
	max-width: 100%;
	margin-top: 10px;
	margin-bottom: 10px;
}
.flow h3 {
	font-size: 180%;
	border: none;
	color: #C30D22;
	letter-spacing: 1px;
}
.flow p {
	letter-spacing: 1px;
	line-height: 1.5;
	font-size: 110%;
}
.flow p strong {
	font-weight: bold;
}
.flow p a {
	color: #2ea2cc;
	text-decoration: underline;
}


/**
 * スタッフ紹介
 * ------------------------------------------- */
article.img-and-text {
	margin-bottom: 30px;
}
article.img-and-text .img {
	float: left;
	width: 300px;
	display: block;
}
article.img-and-text .img img{
	display: block;
}
article.img-and-text .text {
	margin-left: 320px;
}
article.img-and-text .text h3 {
	font-size: 190%;
	margin-top: 0;
	margin-bottom: 15px;
	border: none;
}
article.img-and-text .text .comment {
}

/**
 * 事故事例
 * ------------------------------------------- */
div.post.accident h3{
	border: none;
	clear: both;
	font-size: 140%;
}
article.img-and-title {
	float: left;
	margin-bottom: 30px;
	width: 210px;
	margin-right: 8px;
}
article.img-and-title .img img {
	display: block;
}
article.img-and-title .title {
	background: #B4B5B5;
	min-height: 56px;
	vertical-align: middle;
	display: table;
	width: 100%;
} 
article.img-and-title .title h4{
	text-align: center;
	vertical-align: middle;
	display: table-cell;
	padding: 0 10px;
}
article.img-and-title a:hover .title h4{
	color: #fff;
}
 
article.content.accident h3{
	font-size: 140%;
	border: none;
}
article.content.accident .img {
	float: right;
	max-width: 270px;
	margin-left: 10px;
	margin-bottom: 10px;
}
article.content.accident .img img{
	display: block;
}


/**
 * トップページ　スタッフ紹介
 * ----------------------------------------------- */
article.content.staff {
  background: #060441;
  border: 0;
  padding: 30px 21px 15px 21px;
  margin-bottom: 30px;
  border-radius:10px;
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
}
article.content.staff header {
  background: #060441;
  border: 0;
}
article.content.staff header h2,
article.content.staff header h3 {
  color: #fff;
  background: none;
  border: 0;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 3px;
  margin-bottom: 10px;
}
article.content.staff .member {

}
article.content.staff .member .box {
  float: left;
  width: 33.333%;
  box-sizing: border-box;
  margin-bottom: 15px;
  min-height: 180px;
}
article.content.staff .member .box img {
  width: auto;
  height: auto;
}
article.content.staff .member .box .name {
  text-align: center;
  color: #fff;
}
article.content.staff .link {
text-align: right; 
}
article.content.staff .link a {
color: #fff; 
}
article.content.staff .link-02 {
line-height: 40px;
}
article.content.staff .link-02 a {
color: #fff;
background: url(img/bg-arrow.png) no-repeat right -2px;
display: block;
padding: 0 25px 0 0;
float: right;
}
article.content.staff .link-02 a:hover {
filter: alpha(opacity=70);
-moz-opacity:0.7;
opacity:0.7;
}

h2.top-title {
margin-bottom: 20px;
}
h2.top-title img {
vertical-align: bottom;
}

article.content.staff .staff-list {
margin-left: -21px;
}
article.content.staff .staff-list dl {
float: left;
width: 192px;
margin: 0 0 15px 21px;
}
article.content.staff .staff-list dl dt {
margin-bottom: 5px;
}
article.content.staff .staff-list dl dt img {
vertical-align: bottom;
}
article.content.staff .staff-list dl dd {
text-align: center;
color: #fff;
padding: 0;
}
@media only screen and (max-width: 959px){
article.content.staff .staff-list {
margin-left: 0;
}
article.content.staff .staff-list dl {
float: none;
margin: 0 0 15px 0;
}
article.content.staff .staff-list dl,
article.content.staff .staff-list dl dt img {
width: 100%;
}
}

/**
 * 事故事例から学ぶ予防とリスク対策
 * ------------------------------------------- */
article.risk {
	margin-bottom: 30px;
}

article.risk header {
	background-image: url(img/risk-header-bg.png);
	background-repeat: no-repeat;
	background-size: 100%;
	min-height: 38px;
	padding: 7px 10px;
	color: #fff;
}

article.risk header h2 {

}
article.risk div.title {
	margin-bottom: 20px;
}

article.risk ul {
    margin-bottom: 15px;
}
article.risk ul li {
	display:inline-block;
	width: 200px;
	min-height: 175px;
	vertical-align: top;
}
article.risk ul li + li {
	margin-left: 45px;
}
article.risk ul li img {
	display: block;
	margin: auto;
}

article.risk ul li a {
	display: block;
}
article.risk ul li a .memo {
	padding: 5px 0;
	font-size: 90%;
}
article.risk ul li a .about {
	text-align: center;
	color: #fff;
	background: #717071;
	border: 1px solid #aaa;
}
article.risk ul li a .about div {
	border: 1px solid #fff;
}

/**
 * 事故事例から学ぶ予防とリスク対策 2
 * ------------------------------------------- */

article.risk2 {
padding: 10px 0 0 0;
}
article.risk2 h2 {
font-size: 24px;
text-align: center;
padding: 0 0 25px 0;
}
article.risk2 h2 strong {
font-size: 32px;
font-weight: bold;
}
article.risk2 section {
padding: 40px 20px 25px 20px;
background: rgb(201,202,202); /* Old browsers */
background: -moz-linear-gradient(top,  rgba(201,202,202,1) 0%, rgba(239,239,239,1) 10%, rgba(255,255,255,1) 28%, rgba(239,239,239,1) 47%, rgba(137,137,137,1) 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(201,202,202,1)), color-stop(10%,rgba(239,239,239,1)), color-stop(28%,rgba(255,255,255,1)), color-stop(47%,rgba(239,239,239,1)), color-stop(100%,rgba(137,137,137,1))); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(top,  rgba(201,202,202,1) 0%,rgba(239,239,239,1) 10%,rgba(255,255,255,1) 28%,rgba(239,239,239,1) 47%,rgba(137,137,137,1) 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top,  rgba(201,202,202,1) 0%,rgba(239,239,239,1) 10%,rgba(255,255,255,1) 28%,rgba(239,239,239,1) 47%,rgba(137,137,137,1) 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top,  rgba(201,202,202,1) 0%,rgba(239,239,239,1) 10%,rgba(255,255,255,1) 28%,rgba(239,239,239,1) 47%,rgba(137,137,137,1) 100%); /* IE10+ */
background: linear-gradient(to bottom,  rgba(201,202,202,1) 0%,rgba(239,239,239,1) 10%,rgba(255,255,255,1) 28%,rgba(239,239,239,1) 47%,rgba(137,137,137,1) 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c9caca', endColorstr='#898989',GradientType=0 ); /* IE6-9 */

}
article.risk2 section h3 {
color: #c30d23;
font-size: 32px;
font-weight: bold;
text-align: center;
margin-bottom: 10px;
}
article.risk2 section p {
font-family:"ヒラギノ明朝 ProN W6","HiraMinProN-W6","HG明朝E","ＭＳ Ｐ明朝","MS PMincho","MS 明朝",serif;
font-size: 24px;
font-weight: bold;
text-align: center;
line-height: 1.4em;
margin-bottom: 20px;
}
article.risk2 section div {
margin-left: -19px;
}
article.risk2 section div dl {
float: left;
width: 194px;
margin:0 0 10px 19px;
}
article.risk2 section div dl a:hover dt,
article.risk2 section div dl a:hover dd {
filter: alpha(opacity=7);
-moz-opacity:0.7;
opacity:0.7;
}
article.risk2 section div dl a:hover dd {
color: #313131;
}
article.risk2 section div dl dt {
background-color: #a50319;
color: #fff;
border-radius:10px;
-webkit-border-radius:10px;
-moz-border-radius:10px;
width: 194px;
height: 80px;
text-align: center;
line-height: 80px;
font-size: 20px;
margin-bottom: 5px;
}
article.risk2 section div dl dt span {
font-size: 32px;
font-weight: bold;
}
article.risk2 section div dl dd {
padding: 0 5px;
}

@media only screen and (max-width: 959px){
article.risk2 h2,
article.risk2 section h3,
article.risk2 section p {
font-size: 2em;
}
article.risk2 h2 strong {
font-size: 1em;
}
article.risk2 h2 br,
article.risk2 section h3 br,
article.risk2 section p br {
display: none;
}
article.risk2 section div {
margin-left: 0;
}
article.risk2 section div dl {
float: none;
width: 100%;
margin:0 0 10px 0;
}
article.risk2 section div dl dt {
width: 100%;
}
article.risk2 section div dl dd {
font-size: 1.5em;
}
}

/**
 * スタッフ紹介
 * ------------------------------------------- */
.post.staff {

}
.post.staff h3 {
  clear: both;
  border: 0;
  font-size: 120%;
}
.post.staff article {
  float: left;
  width: 212px;
  margin-right: 11px;
}
.post.staff article:nth-child(3n) {
  margin-right: 0px;
}
.post.staff article .text {
  margin: 0;
  float: none;
  text-align: center;
  padding: 15px;
  background: #ccc;
}
.post.staff article .text h3 {
  margin: 0;
  font-weight: bold;
  font-size: 100%;
}
.post.staff article .img {
  max-width: 100%;
  float: none;
  height: 157px;
  overflow: hidden;
}
.post.staff article .img img {
  max-width: 100%;
}

.content.staff {
  
}
.content.staff .img {
  width: 300px;
  margin-right: 15px;
  margin-bottom: 15px;
  float: left;
}
.content.staff .body {

}
.content.staff .body dl {
  border-bottom: 1px dotted #aaa;
}
.content.staff .body dl dt {
  border-top: 1px dotted #aaa;
  padding: 5px 0;
}
.content.staff .body dl dd {
  padding: 5px 0;
}

.content.staff .body.top {
  min-height: 270px;
}
.content.staff .body.top dl {
  margin-left: 315px;
}
.content.staff .body.top dl dt {
  float: left;
  border: 0px;
}
.content.staff .body.top dl dd {
  padding-left: 100px;
  border-top: 1px dotted #aaa;
}

#post-137 h3,
#post-202 h3 {
border: none;
font-size: 14px;
margin: 0 0 10px 0;
}
#post-137 .staff-wrap,
#post-202 .staff-wrap {
margin:0 0 0 -19px;
padding: 0 0 20px 0;
}
#post-137 .staff-wrap dl,
#post-202 .staff-wrap dl {
float: left;
width: 194px;
margin: 0 0 19px 19px;
}
#post-137 .staff-wrap dl dt,
#post-202 .staff-wrap dl dt {
border: 1px solid #b5b5b6;
}
#post-137 .staff-wrap dl dt img,
#post-202 .staff-wrap dl dt img {
vertical-align: bottom;
}
#post-137 .staff-wrap dl a:hover dt img,
#post-202 .staff-wrap dl a:hover dt img {
filter: alpha(opacity=70);
-moz-opacity:0.7;
opacity:0.7;
}
#post-137 .staff-wrap dl dd,
#post-202 .staff-wrap dl dd {
background-color: #b5b5b6;
text-align: center;
line-height: 40px;
padding: 0;
}

@media only screen and (max-width: 959px){
#post-137 .staff-wrap,
#post-202 .staff-wrap {
margin:0;
}
#post-137 .staff-wrap dl,
#post-202 .staff-wrap dl {
float: none;
width: 100%;
margin: 0 0 19px 0;
}
#post-137 .staff-wrap dl img,
#post-202 .staff-wrap dl img {
width: 100%;
}

}

/**
 * ポリシーについて
 * ------------------------------------------- */
div.post.policy {
	padding: 20px 40px; 
}
.policy h2 {
}
.policy h3 {
	border-bottom: 1px solid #f00;
	font-size: 120%;
}
.policy h3 span {
	color: #f00;
}
.policy h4 {
	color: #172987;
	font-size: 150%;
}


/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){

}


/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px){

}

/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){

    .contact {
        float: none;
        text-align: center;
    }
    
    article.risk ul li + li {
        margin-left: 1%;
    }
    article.risk ul li {
        width: 30%;
    }
    article.risk ul li .memo {
        min-height: 60px;
    }

}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){

}


