@charset "utf-8";
/*
Theme Name: Recruit News
Theme URI: https://www.komatsu-bussan.co.jp/recruit/news/
Description: 小松物産株式会社 採用・求人サイトNews
Version: 1.0
Author: 小松物産株式会社
Author URI: https://www.komatsu-bussan.co.jp/
*/



html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p,
header, hgroup, section, article, aside, hgroup, footer, figure, figcaption, nav {
 margin: 0;
 padding: 0;
 font-size: 100%;
}

body {
 line-height: 1.0;
 -webkit-text-size-adjust: none;
}

article,aside,canvas,details,figcaption,figure,
footer,header,hgroup,menu,nav,section,summary { 
 display:block;
}


ul, ol {
 list-style: none;
}
img {
 max-width : 100%;
 height:auto;
 vertical-align:bottom;
}

h1{margin:0px; text-decoration:none;}
h2{margin:0px;}
h3{margin:0px;}

.top-h{display:none;}

.font-b{font-weight:bold;}
.red{ color:#ff0000; }
.red-b{ color:#ff0000; font-weight:bold; }
.blue-b{color:#0000ff; font-weight:bold;}
.orange-b{color:#ff6600; font-weight:bold;}
.yellow-b{color:#ffcc00; font-weight:bold;}





/*=================================================
 * サイト全体の基本スタイル
 * ================================================= */

body {
 background-color:#fff;
 font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
 font-size: 16px;
 line-height: 1.7;
 color:#333;
 padding: 0; 
}

a:link { color: #333; } 
a:visited { color: #333; } 
a:active { color: #333; } 






/* スマホヘッダー　start */

@media screen and (max-width: 768px) {
.home-header {
 width:100%;
 margin: 0;
 padding: 0;
 background:rgba(40,112,210, 0.9);
}
.contents-home-header {
  width:100%;
  margin: 0;
  padding: 0;
  background:rgba(40,112,210, 0.9);
}
.header-block {
 width:100%;
 margin: 0px auto 0px auto;
 padding: 20px 0 20px 0;
 position:relative;
}
.header-block:after {
 content: '';
 display: block;
 clear: both;
}
.header-left {
 width:100%;
 margin: 0 auto;
 padding:0;
 text-align:center;
}
.logo {
 max-width:240px;
 text-align:left;
}
.header-right {
 margin: 0;
 text-align:right;
}
.menu-block {
 margin: 10px 0;
 text-align:center;
 position:absolute;
 top:0%;
 right:0%;
 z-index:9998;
}

.main-contents {
 margin: 0 auto 0 auto;
 padding:0;
 width:100%;
 height:100%;
}


@keyframes fadein {
from {
    opacity: 0;
    transform: translateY(20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

@keyframes fadein-top {
from {
    opacity: 0;
}
to {
    opacity: 1;
    transform: translateY(0);
}
}


.content-title {
 width:100%;
 margin: 0 auto ;
 padding: 20px 0 20px 0;
 text-align:center;
 background:#3272cb;
}
.content-title-h {
  margin: 0 auto ;
  font-size:20px;
  color:#fff;
  display:block;
  font-weight:bold;
}

.contents-wrapper {
 width:90%;
 margin: 0 auto ;
 padding: 0;
 text-align:center;
}
.contents-wrapper:after {
 content: '';
 display: block;
 clear: both;
}

.contents-left {
 width:90%;
 margin: 0 auto;
 padding: 0;
}
.contents-left-block {
 width:100%;
 margin: 0;
 padding: 20px;
 text-align:left;
}
.post {
 width:100%;
 margin: 60px 0 60px;
 padding: 0;
 text-align:left;
}
.post:after {
 content: '';
 display: block;
 clear: both;
}
.cate-title {
 color: #3272cb;
 font-size:22px;
 margin:20px 0 40px 0;
 padding: 0;
 text-align:left;
 font-weight:bold;
}
.post-title {
 color: #3272cb;
 font-size:22px;
 margin:0;
 padding: 0;
 text-align:left;
}
.post-title a {
 text-decoration:none;
 color:#fff;
}
.post-title a:hover {
 color: #ff9900;
}
.post img {
 margin:20px 0 20px 0;
 padding: 0;
}
.thumbnail-text {
 margin:6px 0 0 0;
 padding: 0;
 text-align:left;
}
.post-date {
 margin:10px 0 10px 0;
 text-align:left;
 font-size:14px;
}
.post p {
 margin:20px 0 0 0;
 text-align:left;
 font-size:16px;
}
table{
  margin:20px auto;
}


.post ul {
  margin: 20px 0 0 0;
  text-align:left;
}
.post ul li {
  margin: 10px 0 0 30px;
  text-align:left;
  list-style-type:disc;
}




.search-box {
 margin: 10px auto 0 0;
 text-align:right;
}
.search-box-main {
 width:250px;
 margin: 10px auto 0 0;
 text-align:right;
}
#searchform{
	position: relative;
	margin-top: 45px;
}
	#s{
		padding: 6px 6px 6px 6px;
		width: 250px;
		-webkit-border-radius: 25px;
		-moz-border-radius: 25px;
		border-radius: 25px; 
		font-size: 15px;
		color:#666;
	}
	#searchsubmit{
		position: absolute;
		top: 2px;
		right: 4px;
		width: 30px;
		height: 30px;
		border: none;
		background: url('./images/search.png') no-repeat 50% 50%;
	}






/* サイドバー */
.sidebar {
 margin: 0;
 padding: 20px auto;
 text-align:center;
}
.sidebar-block li {
 margin: 12px 0 0 20px;
 text-align:left;
 list-style:disc;
}
.sidebar-block h3 {
 margin: 50px auto 0;
 text-align:center;
 font-size:16px;
 border-bottom:1px dotted #ccc;
 color:#3272cb;
}
.sidebar-block {
 margin: 30px auto ;
 text-align:center;
}
.blogtop-nav li {
-moz-border-radius: 3px;    /* Firefox */
-webkit-border-radius: 3px; /* Safari,Chrome */
border-radius: 3px;
background-color: #3272cb; 
text-align:center;
width:90%;
 margin:10px auto 0 auto;
 list-style:none;
}
.blogtop-nav a {
-moz-border-radius: 3px;
-webkit-border-radius: 3px;
border-radius: 3px;
 margin:0;
 padding: 5px;
 display: block;
 text-decoration: none;
 overflow: hidden;
 white-space: nowrap;
 text-overflow: ellipsis;
 color:#ffffff;
 font-size:15px;
 -webkit-transition-duration: 0.3s;
 transition-duration: 0.3s;
}





.global-footer {
 margin: 0px ;
 padding: 10px;
 font-size: 16px;
 text-align: center;
 background:#1a5cb7;
 color:#fff;
}

.footer-company-wrapper {
 width:90%;
 margin: 0 auto ;
 padding: 30px 0 30px 0;
 text-align:center;
}
.footer-company-wrapper:after {
 content: '';
 display: block;
 clear: both;
}

.footer-company-left {
 margin: 0 auto ;
 text-align:left;
}
.footer-logo {
 width:60%;
 margin: 10px auto;
 text-align:center;
}
.footer-address {
 width:90%;
 margin: 20px 0 0 0;
 text-align:left;
 font-size:14px;
}

.footer-company-right {
  margin: 30px auto ;
  text-align:left;
}

.footer-company-right-block {
  margin: 0 0 0 auto ;
  padding: 0;
  text-align:right;
  width:100%;
}
.footer-company-right-block:after {
  content: '';
  display: block;
  clear: both;
}
.footer-company-right-box {
  margin: 20px auto ;
  padding: 0;
  text-align:left;
}

.footer-company-right-box {
  margin: 60px 0 0 auto ;
  padding: 0;
  text-align:center;
  vertical-align:top;
  width:48%;
  display:inline-block;
}

ul.footer-sitemap li {
  list-style-type: none;
  margin: 6px 0 0 20px;
  padding:0;
  font-size:14px;
  text-align:left;
}
ul.footer-sitemap li a {
  color:#fff;
  text-decoration:none;
}
.copyright {
	margin: 0px auto 0px auto;
	font-size:13px;
  color:#fff;
}
.copyright a {
	text-decoration:none;
}


.footer-tel {
 width:50%;
 max-height:100px;
 margin: 0 auto;
 padding: 0;
 background-color: #fff;
 display:inline-block;
 vertical-align:top;
}

.footer-nav li {
-moz-border-radius: 3px;    /* Firefox */
-webkit-border-radius: 3px; /* Safari,Chrome */
border-radius: 3px;
background-color: #277ebe; 
text-align:center;
width:70%;
 margin:60px auto;
}
.footer-nav a {
-moz-border-radius: 3px;
-webkit-border-radius: 3px;
border-radius: 3px;
 margin:0;
 padding: 5px;
 display: block;
 text-decoration: none;
 overflow: hidden;
 white-space: nowrap;
 text-overflow: ellipsis;
 color:#ffffff;
font-size:14px;
 -webkit-transition-duration: 0.3s;
 transition-duration: 0.3s;
}

.contents-title-block {
 width:100%;
 margin:0px auto 0;
 padding:20px 0 20px 0;
 text-align:center;
 background:#f3f0fb;
}
.contents-title-block h1 {
 margin:0 auto;
 color:#433b56;
 font-size:24px;
 text-align:center;
 animation-name: fadein;
 animation-duration: 2s;
}


}
/* スマホ　end */



/* PC　start */
@media screen and (min-width: 769px) {
.home-header {
 width:100%;
 margin: 0;
 padding: 20px 20px;
 background:rgba(40,112,210, 0.9);
 position: fixed;
 top: 0px;
 z-index: 9999;
 justify-content: space-between;
 transition: .5s;
}
.home-header.transform {
  background:rgba(26,92,183, 1.0);
  padding: 0px 0px ;
}

.contents-home-header {
  width:100%;
  margin: 0;
  padding: 10px 20px;
  background:rgba(26,92,183, 1.0);
  position: fixed;
  top: 0px;
  z-index: 9999;
  justify-content: space-between;
  transition: .5s;
}
.contents-home-header.transform {
  background: #fff;
  padding: 10px 20px ;
}

.header-block {
 width:94%;
 margin: 0px auto 0px auto;
 padding: 0;
}
.header-block:after {
 content: '';
 display: block;
 clear: both;
}
.header-left {
 width:24%;
 float:left;
 margin: 16px 0 0 0;
 padding:0 ;
 text-align:left;
}
.logo {
 width:320px;
 text-align:center;
}
.header-right {
 float:right;
 width:76%;
 margin: 0;
 text-align:right;
}
.menu-block {
 margin: 10px 0;
 text-align:right;
}

.main-contents {
 margin: 124px auto 0px auto;
 padding:0 0 60px 0;
 width:100%;
}


.content-title {
 width:100%;
 margin: 0 auto ;
 padding: 40px 0 40px 0;
 text-align:center;
 background:#3272cb;
}
.content-title-h {
  margin: 0 auto ;
  font-size:20px;
  color:#fff;
  display:block;
  font-weight:bold;
}
@keyframes fadein {
from {
    opacity: 0;
    transform: translateY(20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

@keyframes fadein-top {
from {
    opacity: 0;
}
to {
    opacity: 1;
    transform: translateY(0);
}
}


.contents-wrapper {
 width:80%;
 min-width:960px;
 max-width:1400px;
 margin: 0 auto ;
 padding: 0;
 text-align:center;
}
.contents-wrapper:after {
 content: '';
 display: block;
 clear: both;
}

.contents-left {
 float:left;
 width:74%;
 margin: 0;
 padding: 0;
}
.contents-left-block {
 width:100%;
 margin: 0;
 padding: 20px;
 text-align:left;
}
.post {
 width:100%;
 margin: 60px 0 60px;
 padding: 0;
 text-align:left;
}
.post:after {
 content: '';
 display: block;
 clear: both;
}
.cate-title {
 color: #3272cb;
 font-size:22px;
 margin:20px 0 40px 0;
 padding: 0;
 text-align:left;
 font-weight:bold;
}
.post-title {
 color: #3272cb;
 font-size:22px;
 margin:0;
 padding: 0;
 text-align:left;
}
.post-title a {
 text-decoration:none;
 color:#fff;
}
.post-title a:hover {
 color: #ff9900;
}
.post img {
 margin:20px 0 20px 0;
 padding: 0;
}
.thumbnail-text {
 margin:6px 0 0 0;
 padding: 0;
 text-align:left;
}
.post-date {
 margin:10px 0 10px 0;
 text-align:left;
 font-size:14px;
}
.post p {
 margin:20px 0 0 0;
 text-align:left;
 font-size:16px;
}
table{
  margin:20px auto;
}


.post ul {
  margin: 20px 0 0 0;
  text-align:left;
}
.post ul li {
  margin: 10px 0 0 30px;
  text-align:left;
  list-style-type:disc;
}




.search-box {
 margin: 10px auto 0 0;
 text-align:right;
}
.search-box-main {
 width:250px;
 margin: 10px auto 0 0;
 text-align:right;
}
#searchform{
	position: relative;
	margin-top: 45px;
}
	#s{
		padding: 6px 6px 6px 6px;
		width: 250px;
		-webkit-border-radius: 25px;
		-moz-border-radius: 25px;
		border-radius: 25px; 
		font-size: 15px;
		color:#666;
	}
	#searchsubmit{
		position: absolute;
		top: 2px;
		right: 4px;
		width: 30px;
		height: 30px;
		border: none;
		background: url('./images/search.png') no-repeat 50% 50%;
	}



/* サイドバー */
.sidebar {
 float:right;
 width:240px;
 margin: 0;
 padding: 20px 0 20px 0;
}
.sidebar-block li {
 margin: 12px 0 0 20px;
 text-align:left;
 list-style:disc;
}
.sidebar-block li a:hover {
  color:#ff9900;
 }
.sidebar-block h3 {
 margin: 50px auto 0;
 text-align:center;
 font-size:16px;
 border-bottom:1px dotted #ccc;
 color:#3272cb;
}
.sidebar-block {
 margin: 30px auto ;
 text-align:center;
}
.blogtop-nav li {
-moz-border-radius: 3px;    /* Firefox */
-webkit-border-radius: 3px; /* Safari,Chrome */
border-radius: 3px;
background-color: #3272cb; 
text-align:center;
width:90%;
 margin:10px auto 0 auto;
 list-style:none;
}
.blogtop-nav a {
-moz-border-radius: 3px;
-webkit-border-radius: 3px;
border-radius: 3px;
 margin:0;
 padding: 5px;
 display: block;
 text-decoration: none;
 overflow: hidden;
 white-space: nowrap;
 text-overflow: ellipsis;
 color:#ffffff;
 font-size:15px;
 -webkit-transition-duration: 0.3s;
 transition-duration: 0.3s;
}
.blogtop-nav a:hover {
-moz-border-radius: 3px;
-webkit-border-radius: 3px;
border-radius: 3px;
 margin:0;
 padding: 5px;
 display: block;
 text-decoration: none;
 overflow: hidden;
 white-space: nowrap;
 text-overflow: ellipsis;
 color:#ffffff;
font-size:15px;
background-color:#ff9900;
}



.global-footer {
 margin: 0px ;
 padding: 10px;
 background:#1a5cb7;
 font-size: 16px;
 text-align: center;
 color:#fff;
 font-size:14px;
}

.footer-company-wrapper {
 width:80%;
 margin: 0 auto ;
 padding: 30px 0 30px 0;
 text-align:center;
}
.footer-company-wrapper:after {
 content: '';
 display: block;
 clear: both;
}

.footer-company-left {
 width:50%;
 margin: 0 auto ;
 text-align:left;
 float:left;
}
.footer-logo {
 width:300px;
 margin: 10px 0 0 0;
 text-align:left;
}
.footer-address {
 width:90%;
 margin: 20px 0 0 0;
 text-align:left;
}

.footer-company-right {
  width:50%;
  margin: 0 auto ;
  text-align:left;
  float:left;
}

.footer-company-right-box {
  margin: 60px 0 0 auto ;
  padding: 0;
  text-align:center;
  vertical-align:top;
  width:48%;
  display:inline-block;
}

ul.footer-sitemap li {
  list-style-type: none;
  margin: 6px 0 0 20px;
  padding:0;
  font-size:14px;
  text-align:left;
}
ul.footer-sitemap li a {
  color:#fff;
  text-decoration:none;
}

.copyright {
	margin: 0px auto 0px auto;
	font-size:13px;
	color:#fff;
}
.copyright a {
	color:#fff;
	text-decoration:none;
}





}
/* PCメイン　end */


.contents-navi {
margin: 0;
padding: 6px;
text-align:left;
font-size:13px;
}
/* リスト */
ol.topic-path {
margin: 0; /* マージン（上下左右） */
padding: 2px 5px; /* パディング（上下、左右） */
list-style-type: none; /* リストマーク非表示 */
font-size: 13px; /* 文字サイズ */
color: #333;
}
/* リスト項目 */
ol.topic-path li {
padding-left: 2px; /* 左パディング */
display: inline; /* 項目を横並び */
}
/* リスト項目（最初の項目） */
ol.topic-path li.first {
padding-left: 0px; /* 左パディング */
}
/* リンクエリア */
ol.topic-path li a {
padding-right: 15px; /* 右パディング */
}
/* リンク色 */
ol.topic-path li a {
color: #433b56;
}
/* リンク色（マウスオーバー） */
ol.topic-path li a:hover {
color: #ff0000;
}


.navigation{
	overflow: hidden;
	margin: 40px auto 40px auto;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
}

.navigation:after {
 content: '';
 display: block;
 clear: both;
}
.navigation-left{
 float:left;
 text-align:left;
}
.navigation-right{
 float:right;
 text-align:right;
}

.navigation > div{
	width: 50%;
}

.navigation .alignright{
	text-align: right;
}

.navigation a{
	display: block;
	padding: 1em;
	border: none;
}
.navigation a:hover{
	background: #ebe5f9;
	color: #3272cb;
}
.navigation .alignright a:hover{
	border-left: 1px solid #ddd;
}




#nav li a {
  display: block;
  position: relative;
  text-decoration:none;
  color:#fff;
}
#nav .menu-item-has-children > a:after,#nav .menu-item-has-children > a:before {
  display: block;
  content: "";
  position: absolute;
  top: 0; 
  right: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
  width: 10px;
  height: 1px;
  transition: .2s;
}
#nav .menu-item-has-children > a:after {
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 7px solid #fff;
}
#nav .menu-item-has-children > a.open:before{
    background: transparent;
}
#nav .menu-item-has-children > a.open:after{
    width: 0;
    height: 0;
    border-top: 7px solid transparent;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 7px solid #fff;
}
#nav .menu-item-has-children .sub-menu {
  display: none;
}
@media only screen and ( max-width : 767px ) {
  .overlay {
    width: 0;
    height: 0;
    position: fixed;
    z-index: 11;
    top: 0;
    left: 0;
    opacity: 0;
    transition: opacity .5s;
    background: rgba(255,255,255,.7);
  }
  .overlay.open {
    width: 100%;
    height: 100%;
    opacity: 1;
  }
  #main {
    transition: all .5s;
    min-height: 100vh;
  }
  #main.open {
    position: fixed;
    width: 100%;
  }
  #menu_btn {
    top: 12px;
    right: 15px;
    transition: .3s;
    cursor: pointer;
    position: fixed;
    z-index: 9999;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    border:1px solid #ccc;
    background:#1a5cb7;
  }
  .menu-trigger {
    width: 18px;
    height: 16px;
    position: relative;
  }
  .menu-trigger span {
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #fff;
    transition: all .5s;
  }
  .menu-trigger span:nth-of-type(1) {
    top: 0;
  }
  .menu-trigger span:nth-of-type(2) {
    top: 7px;
  }
  .menu-trigger span:nth-of-type(3) {
    bottom: 0;
  }
  #menu_btn.active .menu-trigger span:nth-of-type(1) {
    transform: translateY(7px) rotate(-45deg);
  }
  #menu_btn.active .menu-trigger span:nth-of-type(2) {
    opacity: 0;
  }
  #menu_btn.active .menu-trigger span:nth-of-type(3) {
    transform: translateY(-7px) rotate(45deg);
  }
  #nav {
    width: 280px;
    height: 100%;
    overflow: auto;
    padding: 90px 0;
    background: #1a5cb7;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 12;
    transform: translate(280px);
    transition: all .5s;
  }
  #nav.open {
    transform: translateZ(0);
  }
  #nav li {
    padding: 0 20px;
  }
  #nav li a {
    position: relative;
    padding: 20px;
    color:#fff;
    border-bottom:1px solid fff;
  }
  #nav .menu-item-has-children .sub-menu {
    padding: 20px;
  }
  #nav .menu-item-has-children > a.open:first-of-type {
    color: #fff;
  }
  #nav .menu-item-has-children .sub-menu li {
    padding: 0;
    margin-bottom: 20px;
  }
  #nav .menu-item-has-children .sub-menu li:last-child {
    margin-bottom: 0;
  }
  #nav .menu-item-has-children .sub-menu li a {
    padding: 0;
  }

  #nav .menu-item-has-children > a:after {
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 7px solid #fff;
}
#nav .menu-item-has-children > a.open:before{
    background: transparent;
}
#nav .menu-item-has-children > a.open:after{
    width: 0;
    height: 0;
    border-top: 7px solid transparent;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 7px solid #fff;
}
}

@media print, screen and ( min-width : 768px ) {
  #menu_btn,.overlay {
    display: none;
  }
  #nav {
    margin:0 auto;
    text-align:center;
    align-items: center;
    justify-content: center;
  }
  #nav ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: right;
  }
  #nav li {
    position: relative;
  }
  #nav li a {
    padding: 20px 10px 20px 10px;
    font-size:15px;
  }
  #nav li a:hover {
    color: #faf33f;
  }
  #nav .menu-item-has-children > a {
    padding-right: 40px;
  }
  #nav .menu-item-has-children > a.open:first-of-type,#nav .current-menu-item a {
    color: #fff;
  }
  #nav .current-menu-item li a {
    color: #fff;
    text-align:center;
    margin: 0 auto;
  }
  #nav li ul.sub-menu {
    flex-direction: column;
    background: rgba(26,92,183,0.8);
    position: absolute;
    width: 200px;
    left: 50%;
    top: 100%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    padding: 10px 0;
  }
  #nav li ul.sub-menu li {
    width: 100%;
  }
  #nav li ul.sub-menu li a {
    line-height: 1.6em;
    color: #fff;
    padding: 10px 20px;
  }
  #nav li ul.sub-menu li a:hover {
    color: #faf33f;
  }
}

